Android - Amaçlar ve Filtreler
Android Intentgerçekleştirilecek bir işlemin özet bir açıklamasıdır. İle kullanılabilirstartActivity Bir Aktivite başlatmak için, broadcastIntent ilgili herhangi bir BroadcastReceiver bileşenine göndermek ve startService(Intent) veya bindService(Intent, ServiceConnection, int) bir arka plan Hizmeti ile iletişim kurmak için.
The intent itself, an Intent object, is a passive data structure holding an abstract description of an operation to be performed.
Örneğin, bir e-posta istemcisi başlatması gereken ve Android cihazınızı kullanarak bir e-posta gönderen bir Etkinliğiniz olduğunu varsayalım. Bu amaçla, Etkinliğiniz uygun olanla birlikte bir ACTION_SEND gönderirchooser, Android Intent Resolver'a. Belirtilen seçici, kullanıcının e-posta verilerinizi nasıl göndereceğini seçmesi için uygun arayüzü sağlar.
Intent email = new Intent(Intent.ACTION_SEND, Uri.parse("mailto:"));
email.putExtra(Intent.EXTRA_EMAIL, recipients);
email.putExtra(Intent.EXTRA_SUBJECT, subject.getText().toString());
email.putExtra(Intent.EXTRA_TEXT, body.getText().toString());
startActivity(Intent.createChooser(email, "Choose an email client from..."));
Yukarıdaki sözdizimi, bir e-posta etkinliği başlatmak için startActivity yöntemini çağırıyor ve sonuç aşağıda gösterildiği gibi olmalıdır -
Örneğin, Android cihazınızdaki bir web tarayıcısında URL'yi açması gereken bir Aktiviteniz olduğunu varsayalım. Bu amaçla, Aktiviteniz ACTION_WEB_SEARCH Amacını, verilen URL'yi web tarayıcısında açmak için Android Amaç Çözümleyiciye gönderir. Niyet Çözümleyici, bir Etkinlikler listesini ayrıştırır ve Amacınıza en uygun olanı, bu durumda Web Tarayıcısı Etkinliğini seçer. Amaç Çözümleyici daha sonra web sayfanızı web tarayıcısına iletir ve Web Tarayıcısı Etkinliğini başlatır.
String q = "tutorialspoint";
Intent intent = new Intent(Intent.ACTION_WEB_SEARCH );
intent.putExtra(SearchManager.QUERY, q);
startActivity(intent);
Yukarıdaki örnek şu şekilde aranacaktır: tutorialspoint android arama motorunda ve bir etkinliğinizdeki öğretici noktanın sonucunu verir
Her bir bileşen türüne - faaliyetler, hizmetler ve yayın alıcıları - amaçların iletilmesi için ayrı mekanizmalar vardır.
Sr.No | Yöntem ve Açıklama |
---|---|
1 |
Context.startActivity() Intent nesnesi, yeni bir aktivite başlatmak veya yeni bir şey yapmak için mevcut bir aktiviteyi almak için bu yönteme iletilir. |
2 |
Context.startService() Intent nesnesi, bir hizmeti başlatmak veya devam eden bir hizmete yeni talimatlar sunmak için bu yönteme iletilir. |
3 |
Context.sendBroadcast() Amaç nesnesi, mesajı tüm ilgili yayın alıcılarına iletmek için bu yönteme geçirilir. |
Amaç Nesneleri
Bir Niyet nesnesi, Android sistemi tarafından kullanılan bilgilerin yanı sıra amacı alan bileşen tarafından kullanılan bir bilgi paketidir.
Bir Intent nesnesi, ilettiği veya gerçekleştireceği şeye bağlı olarak aşağıdaki bileşenleri içerebilir -
Aksiyon
Bu, Niyet nesnesinin zorunlu bir parçasıdır ve gerçekleştirilecek eylemi - ya da yayın amaçları söz konusu olduğunda, gerçekleşen ve raporlanmakta olan eylemi adlandıran bir dizedir. Eylem, büyük ölçüde niyet nesnesinin geri kalanının nasıl yapılandırıldığını belirler. Intent sınıfı, farklı amaçlara karşılık gelen bir dizi eylem sabitini tanımlar. İşte Android Amaçlı Standart Eylemlerin bir listesi
Bir Intent nesnesindeki eylem setAction () yöntemi ile ayarlanabilir ve getAction () tarafından okunabilir.
Veri
Bir amaç filtresine bir veri özelliği ekler. Belirtim, yalnızca bir veri türü (mimeType özniteliği), yalnızca bir URI veya hem bir veri türü hem de bir URI olabilir. Bir URI, parçalarının her biri için ayrı özniteliklerle belirtilir -
URL biçimini belirten bu öznitelikler isteğe bağlıdır, ancak aynı zamanda karşılıklı olarak bağımlıdır -
- Amaç filtresi için bir şema belirtilmezse, diğer tüm URI öznitelikleri göz ardı edilir.
- Filtre için bir ana bilgisayar belirtilmezse, bağlantı noktası özelliği ve tüm yol nitelikleri yok sayılır.
SetData () yöntemi, verileri yalnızca bir URI olarak belirtir, setType () bunu yalnızca bir MIME türü olarak belirtir ve setDataAndType (), bunu hem bir URI hem de MIME türü olarak belirtir. URI getData () tarafından ve tür getType () tarafından okunur.
Bazı eylem / veri çifti örnekleri şunlardır:
Sr.No. | Eylem / Veri Çifti ve Açıklama |
---|---|
1 | ACTION_VIEW content://contacts/people/1 Tanımlayıcısı "1" olan kişi hakkındaki bilgileri görüntüleyin. |
2 |
ACTION_DIAL content://contacts/people/1 Telefon çeviriciyi doldurulmuş kişi ile görüntüleyin. |
3 |
ACTION_VIEW tel:123 Telefon çeviriciyi verilen numara doldurulmuş olarak görüntüleyin. |
4 |
ACTION_DIAL tel:123 Telefon çeviriciyi verilen numara doldurulmuş olarak görüntüleyin. |
5 |
ACTION_EDIT content://contacts/people/1 Tanımlayıcısı "1" olan kişi hakkındaki bilgileri düzenleyin. |
6 |
ACTION_VIEW content://contacts/people/ Kullanıcının göz atabileceği bir kişi listesi görüntüleyin. |
7 |
ACTION_SET_WALLPAPER Duvar kağıdını seçmek için ayarları göster |
8 |
ACTION_SYNC Veriler senkronize olacak, Sabit Değer android.intent.action.SYNC |
9 |
ACTION_SYSTEM_TUTORIAL Platform tanımlı öğreticiyi başlatacak (Varsayılan eğitim veya başlangıç öğreticisi) |
10 |
ACTION_TIMEZONE_CHANGED Saat diliminin ne zaman değiştiğini gösterir |
11 |
ACTION_UNINSTALL_PACKAGE Varsayılan kaldırıcıyı çalıştırmak için kullanılır |
Kategori
Kategori, Niyet nesnesinin isteğe bağlı bir parçasıdır ve amacı işlemesi gereken bileşen türü hakkında ek bilgi içeren bir dizedir. AddCategory () yöntemi bir Intent nesnesine bir kategori yerleştirir, removeCategory () önceden eklenen bir kategoriyi siler ve getCategories () o anda nesnede bulunan tüm kategorilerin kümesini alır. İşte Android Amaç Standart Kategorilerinin bir listesi .
Bir Niyete karşılık gelen uygun etkinliği seçmek için kategorileri nasıl kullandığımızı anlamak için aşağıdaki bölümde Niyet Filtreleri ile ilgili ayrıntıları kontrol edebilirsiniz.
Ekstralar
Bu, amacı işleyen bileşene iletilmesi gereken ek bilgiler için anahtar / değer çiftleri halinde olacaktır. Ekstralar, sırasıyla putExtras () ve getExtras () yöntemleri kullanılarak ayarlanabilir ve okunabilir. İşte Android Intent Standard Ekstra Verilerinin bir listesi
Bayraklar
Bu bayraklar, Intent nesnesinin isteğe bağlı bir parçasıdır ve Android sistemine bir etkinliğin nasıl başlatılacağını ve başlatıldıktan sonra nasıl ele alınacağını vb. Öğretir.
Sr.No | Bayraklar ve Açıklama |
---|---|
1 |
FLAG_ACTIVITY_CLEAR_TASK Context.startActivity () 'ye iletilen bir Amaç içinde ayarlanmışsa, bu bayrak, etkinlik başlatılmadan önce etkinlikle ilişkilendirilecek tüm mevcut görevlerin temizlenmesine neden olur. Diğer bir deyişle, etkinlik, normalde boş olan bir görevin yeni kökü haline gelir ve tüm eski etkinlikler tamamlanır. Bu sadece FLAG_ACTIVITY_NEW_TASK ile birlikte kullanılabilir. |
2 |
FLAG_ACTIVITY_CLEAR_TOP Ayarlanmışsa ve başlatılan etkinlik mevcut görevde zaten çalışıyorsa, bu etkinliğin yeni bir örneğini başlatmak yerine, üstündeki diğer tüm etkinlikler kapatılacak ve bu Amaç (şimdi başa dön) yeni bir Niyet olarak eski etkinlik. |
3 |
FLAG_ACTIVITY_NEW_TASK Bu bayrak genellikle bir "başlatıcı" tarzı davranış sergilemek isteyen etkinlikler tarafından kullanılır: kullanıcıya, yapılabilecek ayrı şeylerin bir listesini verir, aksi takdirde bunları başlatan etkinlikten tamamen bağımsız olarak çalışır. |
Bileşen Adı
Bu isteğe bağlı alan bir androiddir ComponentNameActivity, Service veya BroadcastReceiver sınıfını temsil eden nesne. Ayarlanmışsa, Intent nesnesi belirlenen sınıfın bir örneğine teslim edilir, aksi takdirde Android, uygun bir hedefi bulmak için Intent nesnesindeki diğer bilgileri kullanır.
Bileşen adı setComponent (), setClass () veya setClassName () tarafından belirlenir ve getComponent () tarafından okunur.
Amaç Türleri
Android tarafından desteklenen aşağıdaki iki tür amaç vardır
Açık Amaçlar
Açık niyet uygulama iç dünyasına bağlanacak, farz edin ki bir aktiviteyi başka bir aktiviteye bağlamak istiyorsanız, bu alıntıyı açık bir niyetle yapabiliriz, aşağıdaki resim birinci aktiviteyi ikinci aktiviteye düğmesini tıklayarak bağlar.
Bu amaçlar, hedef bileşeni adıyla belirtir ve tipik olarak, bir alt hizmet başlatma veya bir kardeş etkinlik başlatma gibi uygulama içi mesajlar için kullanılır. Örneğin -
// Explicit Intent by specifying its class name
Intent i = new Intent(FirstActivity.this, SecondActivity.class);
// Starts TargetActivity
startActivity(i);
Örtülü Amaçlar
Bu amaçlar bir hedefi adlandırmaz ve bileşen adı alanı boş bırakılır. Örtük amaçlar genellikle diğer uygulamalardaki bileşenleri etkinleştirmek için kullanılır. Örneğin -
Intent read1=new Intent();
read1.setAction(android.content.Intent.ACTION_VIEW);
read1.setData(ContactsContract.Contacts.CONTENT_URI);
startActivity(read1);
Yukarıdaki kod aşağıda gösterildiği gibi sonuç verecektir
Niyeti alan hedef bileşen, getExtras()kaynak bileşen tarafından gönderilen ekstra verileri alma yöntemi. Örneğin -
// Get bundle object at appropriate place in your code
Bundle extras = getIntent().getExtras();
// Extract data using passed keys
String value1 = extras.getString("Key1");
String value2 = extras.getString("Key2");
Misal
Aşağıdaki örnek, çeşitli yerleşik Android uygulamalarını başlatmak için bir Android Intent'in işlevselliğini göstermektedir.
Adım | Açıklama |
---|---|
1 | Bir Android uygulaması oluşturmak için Android studio IDE'yi kullanacaksınız ve bunu com.example.saira_000.myapplication paketinin altında Uygulamam olarak adlandıracaksınız . |
2 | Değiştir src / main / java / MainActivity.java dosyası ve iki düğme yani karşılık gelen iki dinleyici tanımlamak için kodu ekleyin. Tarayıcıyı Başlatın ve Telefonu Başlatın. |
3 | Doğrusal düzende üç düğme eklemek için düzen XML dosyasını res / layout / activity_main.xml'yi değiştirin. |
4 | Android öykünücüsünü başlatmak ve uygulamada yapılan değişikliklerin sonucunu doğrulamak için uygulamayı çalıştırın. |
Aşağıda, değiştirilen ana aktivite dosyasının içeriği yer almaktadır src/com.example.My Application/MainActivity.java.
package com.example.saira_000.myapplication;
import android.content.Intent;
import android.net.Uri;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
public class MainActivity extends AppCompatActivity {
Button b1,b2;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
b1=(Button)findViewById(R.id.button);
b1.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Intent i = new Intent(android.content.Intent.ACTION_VIEW,
Uri.parse("http://www.example.com"));
startActivity(i);
}
});
b2=(Button)findViewById(R.id.button2);
b2.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Intent i = new Intent(android.content.Intent.ACTION_VIEW,
Uri.parse("tel:9510300000"));
startActivity(i);
}
});
}
}
Aşağıdakilerin içeriği olacak res/layout/activity_main.xml dosya -
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
android:paddingBottom="@dimen/activity_vertical_margin"
tools:context=".MainActivity">
<TextView
android:id="@+id/textView1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Intent Example"
android:layout_alignParentTop="true"
android:layout_centerHorizontal="true"
android:textSize="30dp" />
<TextView
android:id="@+id/textView2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Tutorials point"
android:textColor="#ff87ff09"
android:textSize="30dp"
android:layout_below="@+id/textView1"
android:layout_centerHorizontal="true" />
<ImageButton
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/imageButton"
android:src="@drawable/abc"
android:layout_below="@+id/textView2"
android:layout_centerHorizontal="true" />
<EditText
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/editText"
android:layout_below="@+id/imageButton"
android:layout_alignRight="@+id/imageButton"
android:layout_alignEnd="@+id/imageButton" />
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Start Browser"
android:id="@+id/button"
android:layout_alignTop="@+id/editText"
android:layout_alignRight="@+id/textView1"
android:layout_alignEnd="@+id/textView1"
android:layout_alignLeft="@+id/imageButton"
android:layout_alignStart="@+id/imageButton" />
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Start Phone"
android:id="@+id/button2"
android:layout_below="@+id/button"
android:layout_alignLeft="@+id/button"
android:layout_alignStart="@+id/button"
android:layout_alignRight="@+id/textView2"
android:layout_alignEnd="@+id/textView2" />
</RelativeLayout>
Aşağıdakilerin içeriği olacak res/values/strings.xml iki yeni sabit tanımlamak için -
<?xml version="1.0" encoding="utf-8"?>
<resources>
<string name="app_name">My Applicaiton</string>
</resources>
Aşağıdaki varsayılan içeriktir AndroidManifest.xml -
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.saira_000.myapplication">
<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:supportsRtl="true"
android:theme="@style/AppTheme">
<activity android:name=".MainActivity">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>
</manifest>
Hadi çalıştırmayı deneyelim My Applicationuygulama. Senin yarattığını varsayıyorumAVDortam kurulumu yapılırken. Uygulamayı Android Studio'dan çalıştırmak için, projenizin etkinlik dosyalarından birini açın
Şimdi tıklayın Start Browser yapılandırılmış bir tarayıcı başlatan ve aşağıda gösterildiği gibi http://www.example.com'u görüntüleyen düğme -
Benzer şekilde, önceden verilen telefon numarasını çevirmenize olanak tanıyan Telefonu Başlat düğmesini kullanarak telefon arayüzünü başlatabilirsiniz.
Amaç Filtreleri
Başka bir etkinliği çağırmak için bir Niyetin nasıl kullanıldığını gördünüz. Android OS, bir Niyetle ilişkilendirilmiş belirli eylem kümesi, kategoriler, veri şeması yardımıyla Niyeti işleyebilen Etkinlikler, Hizmetler ve Yayın alıcılarının yerini belirlemek için filtreler kullanır. Kullanacaksın<intent-filter> Herhangi bir etkinlik, hizmet veya yayın alıcısı ile ilişkili eylemleri, kategorileri ve veri türlerini listelemek için bildirim dosyasındaki öğesi.
Aşağıdaki bir bölümün bir örneğidir AndroidManifest.xml bir etkinlik belirtmek için dosya com.example.My Application.CustomActivity belirtilen iki eylemden biri, bir kategori ve bir veri tarafından çağrılabilir -
<activity android:name=".CustomActivity"
android:label="@string/app_name">
<intent-filter>
<action android:name="android.intent.action.VIEW" />
<action android:name="com.example.My Application.LAUNCH" />
<category android:name="android.intent.category.DEFAULT" />
<data android:scheme="http" />
</intent-filter>
</activity>
Bu etkinlik yukarıda belirtilen filtrelerle birlikte tanımlandığında, diğer etkinlikler bu etkinliği android.intent.action.VIEWveya kullanarak com.example.My Application.LAUNCH kategorilerinin olması koşuluyla eylem android.intent.category.DEFAULT.
<data> öğesi, çağrılacak etkinlik tarafından beklenen veri türünü belirtir ve yukarıdaki örnekte, özel etkinliğimiz verilerin "http: //" ile başlamasını bekler.
Bir niyetin birden fazla faaliyet veya hizmetin filtrelerinden geçebileceği bir durum olabilir, kullanıcıya hangi bileşeni etkinleştireceği sorulabilir. Hedef bulunamazsa bir istisna ortaya çıkar.
Bir etkinliği başlatmadan önce aşağıdaki test Android kontrolleri vardır -
Bir <intent-filter> filtresi yukarıda gösterildiği gibi birden fazla eylemi listeleyebilir ancak bu liste boş olamaz; bir filtre en az bir <action> öğesi içermelidir, aksi takdirde tüm amaçları engeller. Birden fazla eylemden bahsedilirse, Android etkinliği başlatmadan önce belirtilen eylemlerden birini eşleştirmeye çalışır.
Bir filtre <intent-filter> sıfır, bir veya birden fazla kategori listeleyebilir. Belirtilen bir kategori yoksa, Android her zaman bu testi geçer, ancak birden fazla kategoriden bahsedilirse, kategori testini geçmek için amaç nesnesindeki her kategori filtredeki bir kategoriyle eşleşmelidir.
Her <data> öğesi bir URI ve bir veri türü (MIME ortam türü) belirtebilir. Gibi ayrı özellikler vardırscheme, host, port, ve pathURI'nin her bölümü için. Hem bir URI hem de bir veri türü içeren bir Amaç nesnesi, yalnızca türünün filtrede listelenen bir türle eşleşmesi durumunda testin veri türü bölümünü geçirir.
Misal
Aşağıdaki örnek, yukarıdaki örneğin bir modifikasyonudur. Burada, bir amaç içinde tanımlanan iki etkinliği çağırıyorsa Android'in çatışmayı nasıl çözdüğünü, ardından bir filtre kullanarak özel bir etkinliğin nasıl başlatılacağını ve üçüncüsü, Android'in bir amaç için tanımlanan uygun etkinliği kaydetmemesi durumunda bir istisna durumunu göreceğiz.
Adım | Açıklama |
---|---|
1 | Bir Android uygulaması oluşturmak için android stüdyosunu kullanacak ve bunu com.example.tutorialspoint7.myapplication paketinin altında Uygulamam olarak adlandıracaksınız ; . |
2 | Değiştir src / Main / Java / MainActivity.java dosya ve düzen dosyasında tanımlanan üç düğmenin karşılık gelen üç dinleyici tanımlamak için kodu ekleyin. |
3 | Farklı amaçlarla çağrılacak bir özel etkinliğe sahip olmak için yeni bir src / Main / Java / CustomActivity.java dosyası ekleyin . |
4 | Doğrusal düzende üç düğme eklemek için düzen XML dosyasını res / layout / activity_main.xml'yi değiştirin. |
5 | Amaç üzerinden aktarılan verileri göstermek için basit bir <TextView> eklemek için bir düzen XML dosyası res / layout / custom_view.xml ekleyin. |
6 | Özel etkinliği çağırma amacınıza yönelik kuralları tanımlamak için AndroidManifest.xml'yi <intent-filter> ekleyecek şekilde değiştirin . |
7 | Android öykünücüsünü başlatmak ve uygulamada yapılan değişikliklerin sonucunu doğrulamak için uygulamayı çalıştırın. |
Aşağıda, değiştirilen ana aktivite dosyasının içeriği yer almaktadır src/MainActivity.java.
package com.example.tutorialspoint7.myapplication;
import android.content.Intent;
import android.net.Uri;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
public class MainActivity extends AppCompatActivity {
Button b1,b2,b3;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
b1=(Button)findViewById(R.id.button);
b1.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Intent i = new Intent(android.content.Intent.ACTION_VIEW,
Uri.parse("http://www.example.com"));
startActivity(i);
}
});
b2 = (Button)findViewById(R.id.button2);
b2.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Intent i = new Intent("com.example.
tutorialspoint7.myapplication.
LAUNCH",Uri.parse("http://www.example.com"));
startActivity(i);
}
});
b3 = (Button)findViewById(R.id.button3);
b3.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Intent i = new Intent("com.example.
My Application.LAUNCH",
Uri.parse("https://www.example.com"));
startActivity(i);
}
});
}
}
Aşağıda, değiştirilen ana aktivite dosyasının içeriği yer almaktadır src/com.example.My Application/CustomActivity.java.
package com.example.tutorialspoint7.myapplication;
import android.app.Activity;
import android.net.Uri;
import android.os.Bundle;
import android.widget.TextView;
/**
* Created by TutorialsPoint7 on 8/23/2016.
*/
public class CustomActivity extends Activity {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.custom_view);
TextView label = (TextView) findViewById(R.id.show_data);
Uri url = getIntent().getData();
label.setText(url.toString());
}
}
Aşağıdakilerin içeriği olacak res/layout/activity_main.xml dosya -
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context="com.example.tutorialspoint7.myapplication.MainActivity">
<TextView
android:id="@+id/textView1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Intent Example"
android:layout_alignParentTop="true"
android:layout_centerHorizontal="true"
android:textSize="30dp" />
<TextView
android:id="@+id/textView2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Tutorials point"
android:textColor="#ff87ff09"
android:textSize="30dp"
android:layout_below="@+id/textView1"
android:layout_centerHorizontal="true" />
<ImageButton
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/imageButton"
android:src="@drawable/abc"
android:layout_below="@+id/textView2"
android:layout_centerHorizontal="true" />
<EditText
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/editText"
android:layout_below="@+id/imageButton"
android:layout_alignRight="@+id/imageButton"
android:layout_alignEnd="@+id/imageButton" />
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Start Browser"
android:id="@+id/button"
android:layout_alignTop="@+id/editText"
android:layout_alignLeft="@+id/imageButton"
android:layout_alignStart="@+id/imageButton"
android:layout_alignEnd="@+id/imageButton" />
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Start browsing with launch action"
android:id="@+id/button2"
android:layout_below="@+id/button"
android:layout_alignLeft="@+id/button"
android:layout_alignStart="@+id/button"
android:layout_alignEnd="@+id/button" />
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Exceptional condition"
android:id="@+id/button3"
android:layout_below="@+id/button2"
android:layout_alignLeft="@+id/button2"
android:layout_alignStart="@+id/button2"
android:layout_toStartOf="@+id/editText"
android:layout_alignParentEnd="true" />
</RelativeLayout>
Aşağıdakilerin içeriği olacak res/layout/custom_view.xml dosya -
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical" android:layout_width="match_parent"
android:layout_height="match_parent">
<TextView android:id="@+id/show_data"
android:layout_width="fill_parent"
android:layout_height="400dp"/>
</LinearLayout>
Aşağıdakilerin içeriği olacak res/values/strings.xml iki yeni sabit tanımlamak için -
<?xml version="1.0" encoding="utf-8"?>
<resources>
<string name="app_name">My Application</string>
</resources>
Aşağıdaki varsayılan içeriktir AndroidManifest.xml -
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.tutorialspoint7.myapplication">
<application
android:allowBackup = "true"
android:icon = "@mipmap/ic_launcher"
android:label = "@string/app_name"
android:supportsRtl = "true"
android:theme = "@style/AppTheme">
<activity android:name = ".MainActivity">
<intent-filter>
<action android:name = "android.intent.action.MAIN" />
<category android:name = "android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<activity android:name="com.example.tutorialspoint7.myapplication.CustomActivity">
<intent-filter>
<action android:name = "android.intent.action.VIEW" />
<action android:name = "com.example.tutorialspoint7.myapplication.LAUNCH" />
<category android:name = "android.intent.category.DEFAULT" />
<data android:scheme = "http" />
</intent-filter>
</activity>
</application>
</manifest>
Hadi çalıştırmayı deneyelim My Applicationuygulama. Senin yarattığını varsayıyorumAVDortam kurulumu yapılırken. Uygulamayı Android Studio'dan çalıştırmak için, projenizin etkinlik dosyalarından birini açın
Şimdi ilk düğme olan "Tarayıcıyı GÖRÜNÜM Eylemiyle Başlat" ile başlayalım. Burada özel etkinliğimizi bir "android.intent.action.VIEW" filtresi ile tanımladık ve Android tarafından tanımlanan ve web tarayıcısını başlatan VIEW işlemine karşı zaten bir varsayılan etkinlik var, bu nedenle android, gerçekleştirdiğiniz etkinliği seçmek için aşağıdaki iki seçeneği görüntüler başlatmak istiyorum.
Şimdi Tarayıcı'yı seçerseniz, Android web tarayıcısını başlatacak ve example.com web sitesini açacak, ancak IndentDemo seçeneğini seçerseniz, Android yalnızca geçilen verileri yakalayan ve aşağıdaki gibi bir metin görünümünde görüntüleyen CustomActivity'yi başlatacak -
Şimdi geri düğmesini kullanarak geri dönün ve "Tarayıcıyı BAŞLAT Eylemiyle Başlat" düğmesini tıklayın, burada Android, etkinliği tanımlamak için filtre uygular ve yalnızca özel etkinliğinizi başlatır
Yine, geri düğmesini kullanarak geri dönün ve "İstisna Durumu" düğmesini tıklayın, burada Android verilen amaç için geçerli bir filtre bulmaya çalışır, ancak bu sefer verileri şu şekilde kullandık çünkü tanımlanmış geçerli bir etkinlik bulamaz. https onun yerine http doğru bir işlem yapıyor olsak da, Android bir istisna oluşturuyor ve aşağıdaki ekranı gösteriyor -