Bu belgede, bir uygulamanın diğer uygulamalarla etkileşime geçtiği çeşitli yaygın kullanım alanları sunulmaktadır. Her bölümde uygulamanın nasıl başarıya ulaştırılacağı konusunda yol gösterici bilgiler göz önünde bulundurmanız gereken, sınırlı paket görünürlüğü olan Uygulamanız Android 11 (API düzeyi 30) veya sonraki bir sürümü hedefliyorsa.
Android 11 veya sonraki sürümleri hedefleyen bir uygulama, başka bir uygulamada etkinlik başlatmak için intent kullandığında en basit yaklaşım, intent'i çağırmak ve uygulama yoksa ActivityNotFoundException
istisnalarını ele almaktır.
Uygulamanızın bir bölümü, çağrının
startActivity()
bir öğe eklemesi gibi başarılı olabilir.
Uygulamanızın <queries>
öğesi
manifest'ini kullanabilirsiniz. Bu genellikle bir <intent>
öğesidir.
URL'leri açma
Bu bölümde, Android 11 veya sonraki sürümleri hedefleyen bir uygulamada URL'leri açmayla ilgili çeşitli yöntemler açıklanmaktadır.
URL'leri bir tarayıcıda veya başka bir uygulamada aç
Bir URL'yi açmak için web URL'si yükleme kılavuzunda açıklandığı gibi ACTION_VIEW
intent işlemini içeren bir intent kullanın. Bu intent'i kullanarak startActivity()
işlevini çağırdıktan sonra aşağıdakilerden biri gerçekleşir:
- URL, bir web tarayıcısı uygulamasında açılır.
- URL, derin bağlantı olarak URL'yi destekleyen bir uygulamada açılır.
- Kullanıcının hangi uygulamayı seçmesini sağlayan bir açıklama iletişim kutusu görünür URL'yi açar.
Cihazınızda URL'yi açabilecek bir uygulama yüklü olmadığından
ActivityNotFoundException
hatası oluşur. (Bu olağan dışı bir durumdur.)Uygulamanızın,
ActivityNotFoundException
oluştuğunda bunu yakalayıp işlemesi önerilir.
startActivity()
yöntemi, her bir işlem için
başka bir uygulamanın etkinliğini başlatmak için <queries>
eklemeniz gerekmez
öğesini uygulamanızın manifest dosyasına ekleyin veya mevcut <queries>
öğesine dokunun. Bu durum, URL açan hem örtülü hem de açık intent'ler için geçerlidir.
Tarayıcının kullanılabilir olup olmadığını kontrol etme
Bazı durumlarda, uygulamanız en az bir tarayıcı olduğunu doğrulamak isteyebilir
belirli bir tarayıcının varsayılan tarayıcı olmasına dikkat edin.
kontrol edin. Bu gibi durumlarda
Manifest dosyanızdaki <queries>
öğesinin bir parçası olarak <intent>
öğesi:
<!-- Place inside the <queries> element. --> <intent> <action android:name="android.intent.action.VIEW" /> <category android:name="android.intent.category.BROWSABLE" /> <data android:scheme="https" /> </intent>
queryIntentActivities()
işlevini çağırıp bağımsız değişken olarak bir web intent'i ilettiğinizde, döndürülen listede bazı durumlarda mevcut tarayıcı uygulamaları yer alır. Kullanıcı URL'yi varsayılan olarak tarayıcı dışında bir uygulamada açılacak şekilde yapılandırdıysa liste tarayıcı uygulamalarını içermez.
URL'leri Özel Sekmelerde Aç
Özel Sekmeler,
tarayıcınızın görünümünü ve tarzını özelleştirebilirsiniz. Uygulama manifestinize <queries>
öğesi eklemeniz veya değiştirmeniz gerekmeden bir URL'yi Özel Sekme'de açabilirsiniz.
Ancak cihazınızda Özel Sekmeler'i destekleyen bir tarayıcı olup olmadığını kontrol edebilir veya CustomTabsClient.getPackageName()
simgesini kullanarak Özel Sekmeler ile açılacak belirli bir tarayıcı seçebilirsiniz.
Böyle durumlarda, şu <intent>
öğesini
Manifest dosyanızdaki <queries>
öğesi:
<!-- Place inside the <queries> element. --> <intent> <action android:name="android.support.customtabs.action.CustomTabsService" /> </intent>
Tarayıcı dışı uygulamaların URL'leri işlemesine izin verme
Uygulamanız URL'leri Özel Sekmeler kullanarak açabilse bile,
mümkünse tarayıcı olmayan bir uygulamanın bir URL'yi açmasına izin verin. Bunu sağlamak için
özelliğini kullanıyorsanız, bir intent kullanarak startActivity()
çağrısı yapmayı deneyin
ilk adımı
FLAG_ACTIVITY_REQUIRE_NON_BROWSER
intent işareti Sistem bir ActivityNotFoundException
atarsa uygulamanız şunları yapabilir:
ve ardından URL'yi Özel Sekmede açın.
Bir intent bu işareti içeriyorsa startActivity()
çağrısı, aşağıdaki koşullardan biri gerçekleştiğinde ActivityNotFoundException
atılmasına neden olur:
- Görüşmede doğrudan bir tarayıcı uygulaması başlatılır.
- Aramada kullanıcıya, tek seçeneklerin tarayıcı uygulamaları olduğu bir anlamlandırma iletişim kutusu gösterilir.
Aşağıdaki kod snippet'inde, mantığınızın FLAG_ACTIVITY_REQUIRE_NON_BROWSER
intent işaretini kullanacak şekilde nasıl güncelleneceği gösterilmektedir:
Kotlin
try { val intent = Intent(ACTION_VIEW, Uri.parse(url)).apply { // The URL should either launch directly in a non-browser app (if it's // the default) or in the disambiguation dialog. addCategory(CATEGORY_BROWSABLE) flags = FLAG_ACTIVITY_NEW_TASK or FLAG_ACTIVITY_REQUIRE_NON_BROWSER } startActivity(intent) } catch (e: ActivityNotFoundException) { // Only browser apps are available, or a browser is the default. // So you can open the URL directly in your app, for example in a // Custom Tab. openInCustomTabs(url) }
Java
try { Intent intent = new Intent(ACTION_VIEW, Uri.parse(url)); // The URL should either launch directly in a non-browser app (if it's the // default) or in the disambiguation dialog. intent.addCategory(CATEGORY_BROWSABLE); intent.setFlags(FLAG_ACTIVITY_NEW_TASK | FLAG_ACTIVITY_REQUIRE_NON_BROWSER); startActivity(intent); } catch (ActivityNotFoundException e) { // Only browser apps are available, or a browser is the default. // So you can open the URL directly in your app, for example in a // Custom Tab. openInCustomTabs(url); }
Açıklama amaçlı iletişim kutusundan kaçınma
Kullanıcıların bir URL'yi açtığında görebileceği anlamlandırma iletişim kutusunu göstermek istemiyorsanız ve bu durumlarda URL'yi kendiniz yönetmeyi tercih ediyorsanız FLAG_ACTIVITY_REQUIRE_DEFAULT
intent işaretini ayarlayan bir intent kullanabilirsiniz.
Bir intent bu işareti içeriyorsa startActivity()
çağrısı, çağrının kullanıcıya bir anlamlandırma iletişim kutusu göstereceği durumlarda ActivityNotFoundException
atılmasına neden olur.
Bir intent hem bu işareti hem de
FLAG_ACTIVITY_REQUIRE_NON_BROWSER
intent işareti, startActivity()
çağrısı yapıldığında ActivityNotFoundException
değeri şu koşullardan biri gerçekleştiğinde atılır:
- Arama, tarayıcı uygulamasını doğrudan başlatır.
- Aramada, kullanıcıya bir anlamlandırma iletişim kutusu gösterilir.
Aşağıdaki kod snippet'i, FLAG_ACTIVITY_REQUIRE_NON_BROWSER
öğesinin nasıl kullanılacağını göstermektedir
ve FLAG_ACTIVITY_REQUIRE_DEFAULT
işaret birlikte:
Kotlin
val url = URL_TO_LOAD try { // For this intent to be invoked, the system must directly launch a // non-browser app. val intent = Intent(ACTION_VIEW, Uri.parse(url)).apply { addCategory(CATEGORY_BROWSABLE) flags = FLAG_ACTIVITY_NEW_TASK or FLAG_ACTIVITY_REQUIRE_NON_BROWSER or FLAG_ACTIVITY_REQUIRE_DEFAULT } startActivity(intent) } catch (e: ActivityNotFoundException) { // This code executes in one of the following cases: // 1. Only browser apps can handle the intent. // 2. The user has set a browser app as the default app. // 3. The user hasn't set any app as the default for handling this URL. openInCustomTabs(url) }
Java
String url = URL_TO_LOAD; try { // For this intent to be invoked, the system must directly launch a // non-browser app. Intent intent = new Intent(ACTION_VIEW, Uri.parse(url)); intent.addCategory(CATEGORY_BROWSABLE); intent.setFlags(FLAG_ACTIVITY_NEW_TASK | FLAG_ACTIVITY_REQUIRE_NON_BROWSER | FLAG_ACTIVITY_REQUIRE_DEFAULT); startActivity(intent); } catch (ActivityNotFoundException e) { // This code executes in one of the following cases: // 1. Only browser apps can handle the intent. // 2. The user has set a browser app as the default app. // 3. The user hasn't set any app as the default for handling this URL. openInCustomTabs(url); }
Dosya aç
Uygulamanız dosyaları veya ekleri işliyorsa (örneğin, bir cihazın
bir etkinlik başlatmanın en kolay yolu,
dosyayı işleyebilir. Bunun için ACTION_VIEW
intent işlemini ve belirli dosyayı temsil eden URI'yi içeren bir intent kullanın. Cihazınızda uygulama yoksa uygulamanız ActivityNotFoundException
'yi yakalayabilir. İstisna işleme mantığınızda bir hata gösterebilir veya dosyayı kendiniz işlemeye çalışabilirsiniz.
Uygulamanızın, başka bir uygulamanın belirli bir dosyayı açıp açamayacağını önceden bilmesi gerekiyorsa
<intent>
öğesini,
Manifest'inizde <queries>
öğesi. Biliyorsanız dosya türünü de ekleyin
olduğunu anlayabilir.
<!-- Place inside the <queries> element. --> <intent> <action android:name="android.intent.action.VIEW" /> <!-- If you don't know the MIME type in advance, set "mimeType" to "*/*". --> <data android:mimeType="application/pdf" /> </intent>
Ardından, resolveActivity()
numaralı telefonu arayarak bir uygulamanın kullanılabilir olup olmadığını kontrol edebilirsiniz
inandırıcılığınızı artırır.
URI erişimi ver
Not: URI erişim izinlerinin bu bölümde açıklandığı şekilde beyan edilmesi, Android 11'i (API düzeyi 30) veya sonraki sürümleri hedefleyen uygulamalar için zorunludur ve hedef SDK sürümlerinden ve içerik sağlayıcılarını dışa aktarıp aktarmadıklarına bakılmaksızın tüm uygulamalar için önerilir.
Android 11 veya sonraki sürümleri hedefleyen
içerik URI'sine eriştiğinizde, uygulamanızın niyeti URI erişimini bildirmelidir
izinler
Bunun için aşağıdaki amaç işaretlerinden birini veya ikisini birden ayarlayın:
FLAG_GRANT_READ_URI_PERMISSION
ve
FLAG_GRANT_WRITE_URI_PERMISSION
.
Android 11 ve sonraki sürümlerde URI erişim izinleri, intent'i alan uygulamaya aşağıdaki özellikleri sağlar:
- Belirtilen URI izinlerine bağlı olarak içerik URI'sinin temsil ettiği verileri okuyabilir veya bu verilere yazabilir.
- URI yetkilisi. İçerik sağlayıcıyı içeren uygulama, intent'i gönderen uygulamadan farklı olabilir.
Aşağıdaki kod snippet'i, URI izinleri amaç işaretinin nasıl ekleneceğini göstermektedir Böylece Android 11 veya sonraki sürümleri hedefleyen başka bir uygulama içerik URI'sindeki veriler:
Kotlin
val shareIntent = Intent(Intent.ACTION_VIEW).apply { flags = Intent.FLAG_GRANT_READ_URI_PERMISSION data = CONTENT_URI_TO_SHARE_WITH_OTHER_APP }
Java
Intent shareIntent = new Intent(Intent.ACTION_VIEW); shareIntent.setFlags(FLAG_GRANT_READ_URI_PERMISSION); shareIntent.setData(CONTENT_URI_TO_SHARE_WITH_OTHER_APP);
Hizmetlere bağlanın
Uygulamanızın otomatik olarak görünmeyen bir hizmetle etkileşime geçmesi gerekiyorsa <queries>
öğesinde uygun intent işlemini belirtebilirsiniz. Aşağıdaki bölümlerde, sık erişilen hizmetlerin kullanıldığı örnekler verilmiştir.
Metin okuma motoruna bağlanma
Uygulamanız bir metin okuma (TTS) motoruyla etkileşime geçiyorsa manifest dosyanıza <queries>
öğesinin parçası olarak aşağıdaki <intent>
öğesini ekleyin:
<!-- Place inside the <queries> element. --> <intent> <action android:name="android.intent.action.TTS_SERVICE" /> </intent>
Konuşma tanıma hizmetine bağlanma
Uygulamanız bir konuşma tanıma hizmetiyle etkileşimde bulunuyorsa aşağıdakileri ekleyin:
Manifest dosyanızdaki <queries>
öğesinin bir parçası olarak <intent>
öğesi:
<!-- Place inside the <queries> element. --> <intent> <action android:name="android.speech.RecognitionService" /> </intent>
Medya tarayıcısı hizmetlerine bağlanın
Uygulamanız bir istemci medya tarayıcısı uygulaması ise manifest dosyanızdaki <queries>
öğesinin bir parçası olarak aşağıdaki <intent>
öğesini ekleyin:
<!-- Place inside the <queries> element. --> <intent> <action android:name="android.media.browse.MediaBrowserService" /> </intent>
Özel işlevler sağlama
Uygulamanızın özelleştirilebilir işlemler gerçekleştirmesi veya özelleştirilebilir öğeleri göstermesi gerekiyorsa
etkileşimlerine dayalı olarak e-posta gönderenlerden ibaret kullanıyorsanız, bu
amaç filtresini kullanarak özel davranış
imza
manifest dosyanızdaki <queries>
öğesinin bir bölümüdür. Aşağıdaki bölümlerde, sık karşılaşılan çeşitli senaryolar için ayrıntılı talimatlar verilmektedir.
SMS uygulamaları için sorgu
Uygulamanızın, cihaza yüklenen SMS uygulamaları grubu hakkında bilgi alması gerekiyorsa (ör. cihazın varsayılan SMS işleyicisinin hangi uygulama olduğunu kontrol etmek için) manifest dosyanızdaki <queries>
öğesinin bir parçası olarak aşağıdaki <intent>
öğesini ekleyin:
<!-- Place inside the <queries> element. --> <intent> <action android:name="android.intent.action.SENDTO"/> <data android:scheme="smsto" android:host="*" /> </intent>
Özel paylaşım sayfası oluşturma
Mümkünse sistem tarafından sağlanan
paylaşım sayfası. Alternatif olarak:
aşağıdaki <intent>
öğesini, <queries>
öğesinin bir parçası olarak dahil edin
manifest dosyanız:
<!-- Place inside the <queries> element. --> <intent> <action android:name="android.intent.action.SEND" /> <!-- Replace with the MIME type that your app works with, if needed. --> <data android:mimeType="image/jpeg" /> </intent>
Uygulamanızın mantığında paylaşım sayfası oluşturma süreci (ör.
queryIntentActivities()
, diğer kriterlere kıyasla
Android 11'den önceki sürümleri kullanıyorsanız.
Özel metin seçimi işlemlerini göster
Kullanıcılar uygulamanızda metin seçtiğinde metin seçimi
araç çubuğu
seçili metin üzerinde gerçekleştirilebilecek olası işlemler kümesini gösterir. Bu
Araç çubuğu diğer uygulamalardaki özel işlemleri gösterir, aşağıdakileri de ekleyin
Manifest dosyanızdaki <queries>
öğesinin bir parçası olarak <intent>
öğesi:
<!-- Place inside the <queries> element. --> <intent> <action android:name="android.intent.action.PROCESS_TEXT" /> <data android:mimeType="text/plain" /> </intent>
Bir kişi için özel veri satırlarını gösterme
Uygulamalar özel veriler ekleyebilir satırlarını Kişiler'e ekleyin Sağlayıcı. Bir kişiler uygulamasının bu özel verileri göstermesi için şunları yapabilirsiniz:
- Diğer uygulamalardaki
contacts.xml
dosyasını okuyun. - Özel MIME türüne karşılık gelen bir simge yükleyin.
Uygulamanız bir kişi uygulamasıysa manifest dosyanıza <queries>
öğesinin bir parçası olarak aşağıdaki <intent>
öğelerini ekleyin:
<!-- Place inside the <queries> element. --> <!-- Lets the app read the contacts.xml file from other apps. --> <intent> <action android:name="android.accounts.AccountAuthenticator" /> </intent> <!-- Lets the app load an icon corresponding to the custom MIME type. --> <intent> <action android:name="android.intent.action.VIEW" /> <data android:scheme="content" android:host="com.android.contacts" android:mimeType="vnd.android.cursor.item/*" /> </intent>