一、自定義Uri與外部啓動
1、概述
上篇我們講了Uri的結構,在這篇中,我們將看看如何利用自定義的URI來啓動我的的應用。 有時,我們要通過外部Uri鏈接來啓動我們的應用,主要是通過Uri隱式Intent匹配的方式:
- Uri uri = Uri.parse("qijian://test.uri.activity?action=1");
- Intent intent = new Intent("android.qijian.schemeurl.activity");
- intent.setData(uri);
- startActivity(intent);
我們的應用在隱式匹配Intent時,使用的語法爲:
- <activity
- android:name=".SecondActivity"
- android:label="@string/title_activity_second">
- <intent-filter>
- <action android:name="android.qijian.schemeurl.activity" />
- <category android:name="android.intent.category.DEFAULT" />
- <data
- android:scheme="qijian"
- android:host="test.uri.activity" />
- </intent-filter>
- </activity>
這樣,第三方就能通過這個Uri來匿名啓動我們的Activity了。
2、實例
(1)、新建用於外部啓動的Activity
首先,我們先建一個應用,命名爲:SchemeURL,在這個應用中我們新建一個Activity命名爲:secondActivity,其XML代碼如下:
(這個Activity是爲了在外部啓動,爲了標識這個Activity是這個應用的,把背景色改成了黃色,文字改上了“SchemeURL 的Activity”)
- <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:background="#ffff00"
- tools:context="com.harvic.com.schemeurl.SecondActivity">
- <TextView
- android:text="SchemeURL 的Activity"
- android:layout_width="wrap_content"
- android:layout_height="wrap_content" />
- </RelativeLayout>
在SecondAcitivity中添加上Intent-filter用於隱式啓動Intent,由於我們定義的Uri格式爲:qijian://test.uri.activity?action=1,所以我們固定schemeurl和host,通過query來傳遞參數即可;
除了Uri匹配,我這裏還添加上了Action:“android.qijian.schemeurl.activity”,所以我們在第三方隱式匹配時要同時通過Uri和action來同時匹配才能通過這裏的Intent-filter
- <activity
- android:name=".SecondActivity"
- android:label="@string/title_activity_second">
- <intent-filter>
- <action android:name="android.qijian.schemeurl.activity" />
- <category android:name="android.intent.category.DEFAULT" />
- <data
- android:scheme="qijian"
- android:host="test.uri.activity" />
- </intent-filter>
- </activity>
這個應用的外觀是這個樣子的:當點擊按鈕時,調起SchemeURL的SecondActivity:
代碼爲:
- Button btn = (Button) findViewById(R.id.btn_try);
- btn.setOnClickListener(new View.OnClickListener() {
- @Override
- public void onClick(View v) {
- Uri uri = Uri.parse("qijian://test.uri.activity?action=1");
- Intent intent = new Intent("android.qijian.schemeurl.activity");
- intent.setData(uri);
- startActivity(intent);
- }
- });
在上面,我們已經能夠通過Uri來進入我們的應用,我們上面只是固定了Uri的scheme部分和host部分,對於其它部分並沒有固定,所以我們可以通過其它部分來傳遞參數,進而完成指定的功能:比較進入指定的頁面或做出指定的操作,等
比如,我們在SchemeURL中,對Uri進行接收,並將結果顯示出來:
- public class SecondActivity extends Activity {
- @Override
- protected void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- setContentView(R.layout.activity_second);
- Intent intent = getIntent();
- if (null != intent) {
- Uri uri = intent.getData();
- if (uri == null) {
- return;
- }
- String acionData = uri.getQueryParameter("action");
- TextView tv = (TextView)findViewById(R.id.qijian_test_tv);
- tv.append("\n傳過來的action值爲:" + acionData);
- }
- }
- }
源碼在文章底部給出;
二、特殊應用:Notification與應用啓動
有關通過Uri啓動APP的經典應用,應當數通過推送消息啓動我們應用的指定頁面或做出特定的操作了。這部分,我們就看看如何通過推送的通知欄消息來進入我們的應用。
效果如下:
- 首先:SchemeURL工程代碼都不變,我們依然通過隱式匹配Intent來啓動SecondActivity.
- 然後:在UseSchemeURL工程中新加一個按鈕,當點擊時,發送Notification通知,點擊跳轉到SchemeURL工程的SecondActivity
- private void pushNotify() {
- NotificationManager notifyManager = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
- NotificationCompat.Builder builder;
- builder = new NotificationCompat.Builder(this);
- builder.setSmallIcon(R.drawable.ic_launcher)
- .setLargeIcon(BitmapFactory.decodeResource(getResources(), R.drawable.ic_launcher))
- .setContentTitle("harvic")
- .setContentText("test schemeURL")
- .setTicker("有新消息")
- .setOngoing(false)
- .setWhen(System.currentTimeMillis())
- .setPriority(Notification.PRIORITY_DEFAULT)
- .setAutoCancel(true);
- Uri uri = Uri.parse("qijian://test.uri.activity?action=1");
- Intent intent = new Intent("android.qijian.schemeurl.activity");
- intent.setData(uri);
- PendingIntent pendingIntent = PendingIntent.getActivity(this, 0, intent, PendingIntent.FLAG_UPDATE_CURRENT);
- builder.setContentIntent(pendingIntent);
- Notification notification = builder.build();
- notifyManager.notify(1111, notification);
- }
即如下代碼:
- Uri uri = Uri.parse("qijian://test.uri.activity?action=1");
- Intent intent = new Intent("android.qijian.schemeurl.activity");
- intent.setData(uri);
- PendingIntent pendingIntent = PendingIntent.getActivity(this, 0, intent, PendingIntent.FLAG_UPDATE_CURRENT);
三、有關path、pathPrefix、pathPattern 之間的區別
細心的同學可能在AndroidManifest.xml中已經發現,Intent-filter的data域除了scheme、host、port這些已知的還有三個參數我們沒用過——path、pathPrefix、pathPattern;它們也是用來隱式匹配Intent的,即:
- <activity
- android:name=".SecondActivity"
- android:label="@string/title_activity_second">
- <intent-filter>
- <action android:name="android.qijian.schemeurl.activity" />
- <category android:name="android.intent.category.DEFAULT" />
- <data
- android:scheme="qijian"
- android:host="test.uri.activity"
- android:path=""
- android:pathPrefix=""
- android:pathPattern=""/>
- </intent-filter>
- </activity>
- path: 用來匹配完整的路徑,如:http://example.com/blog/abc.html,這裏將 path 設置爲 /blog/abc.html 才能夠進行匹配;
- pathPrefix: 用來匹配路徑的開頭部分,拿上面的 Uri 來說,這裏將 pathPrefix 設置爲 /blog 就能進行匹配了;
- pathPattern: 用表達式來匹配整個路徑,這裏需要說下匹配符號與轉義。
1、“” 用來匹配0次或更多,如:“a” 可以匹配“a”、“aa”、“aaa”…
2、“.” 用來匹配任意字符,如:“.” 可以匹配“a”、“b”,“c”…
3、因此 “.*” 就是用來匹配任意字符0次或更多,如:“.*html” 可以匹配 “abchtml”、“chtml”,“html”,“sdf.html”…
轉義:
因爲當讀取 Xml 的時候,“\” 是被當作轉義字符的(當它被用作 pathPattern 轉義之前),因此這裏需要兩次轉義,讀取 Xml 是一次,在 pathPattern 中使用又是一次。如:“” 這個字符就應該寫成 “\”,“\” 這個字符就應該寫成 “\\”。
樣例:匹配 http 以 “.pdf” 結尾的路徑
如果我們想要匹配 http 以 “.pdf” 結尾的路徑,使得別的程序想要打開網絡 pdf 時,用戶能夠可以選擇我們的程序進行下載查看。
我們可以將 scheme 設置爲 “http”,pathPattern 設置爲 “.*\.pdf”,整個 intent-filter 設置爲:
- <intent-filter>
- <action android:name="android.intent.action.VIEW"></action>
- <category android:name="android.intent.category.DEFAULT"></category>
- <data android:scheme="http" android:pathPattern=".*\\.pdf"></data>
- </intent-filter>
四、特殊:如何從網頁中通過Uri啓動我們的應用
如果想要從網頁中點擊一個鏈接跳轉到我們的應用,那除了Intent-filter中的各種匹配工作,還應該加上一個屬性:
- <category android:name="android.intent.category.BROWSABLE"/>
- <activity
- android:name=".SecondActivity"
- android:label="@string/title_activity_second">
- <intent-filter>
- <action android:name="android.qijian.schemeurl.activity" />
- <category android:name="android.intent.category.DEFAULT" />
- <category android:name="android.intent.category.BROWSABLE"/>
- <data
- android:scheme="qijian"
- android:host="test.uri.activity"/>
- </intent-filter>
- </activity>
參考文章:《intent-filter 之 data 「scheme, host, port, mimeType, path, pathPrefix, pathPattern」》
1、Part1:自定義Uri與外部啓動
2、PART2:特殊應用:Notification與應用啓動
每個文件夾裏面包含兩個工程:
1、SchemeURL:這裏提供第三方調用的SecondActivity
2、UseScheme:在這個APP裏通過隱式匹配調用SchemeURL的SecondActivity
如果本文有幫到你,記得關注哦
源碼下載地址:http://download.csdn.net/detail/harvic880925/8551159
請大家尊重原創者版權,轉載請標明出處:http://blog.csdn.net/harvic880925/article/details/44781557 謝謝
Uri詳解之二——通過自定義Uri外部啓動APP與Notification啓動