Android近期任務列表 Recent Applicatoins 分析 + Android PackageManager

轉自 : http://www.cnblogs.com/coding-way/archive/2013/06/05/3118732.html

這裏的近期任務列表就是長按Home鍵出來的那個Dialog,裏面放着近期打開過的應用,當然3.0以上系統的多任務切換鍵也是。

這個Dialog的實現在Android源碼的/frameworks/base/policy/src/com/android/internal/policy/impl/RecentApplicationsDialog.java中。

接下來就對這個源碼分析一下。

  1. public class RecentApplicationsDialog extends Dialog implements OnClickListener {  
  2.     // Elements for debugging support  
  3. //  private static final String LOG_TAG = "RecentApplicationsDialog";  
  4.     private static final boolean DBG_FORCE_EMPTY_LIST = false;  
  5.   
  6.     static private StatusBarManager sStatusBar;  
  7.   
  8.     private static final int NUM_BUTTONS = 8;  
  9.     private static final int MAX_RECENT_TASKS = NUM_BUTTONS * 2;    // allow for some discards  
  10.   
  11.     final TextView[] mIcons = new TextView[NUM_BUTTONS];  
  12.     View mNoAppsText;  
  13.     IntentFilter mBroadcastIntentFilter = new IntentFilter(Intent.ACTION_CLOSE_SYSTEM_DIALOGS);  
  14.   
  15.     class RecentTag {  
  16.         ActivityManager.RecentTaskInfo info;  
  17.         Intent intent;  
  18.     }  
  19.   
  20.     Handler mHandler = new Handler();  
  21.     Runnable mCleanup = new Runnable() {  
  22.         public void run() {  
  23.             // dump extra memory we're hanging on to  
  24.             for (TextView icon: mIcons) {  
  25.                 icon.setCompoundDrawables(nullnullnullnull);  
  26.                 icon.setTag(null);  
  27.             }  
  28.         }  
  29.     };  
  30.   
  31.     public RecentApplicationsDialog(Context context) {  
  32.         super(context, com.android.internal.R.style.Theme_Dialog_RecentApplications);  
  33.   
  34.     }  
  35.   
  36.     /** 
  37.      * We create the recent applications dialog just once, and it stays around (hidden) 
  38.      * until activated by the user. 
  39.      * 
  40.      * @see PhoneWindowManager#showRecentAppsDialog 
  41.      */  
  42.     @Override  
  43.     protected void onCreate(Bundle savedInstanceState) {  
  44.         super.onCreate(savedInstanceState);  
  45.   
  46.         Context context = getContext();  
  47.   
  48.         if (sStatusBar == null) {  
  49.             sStatusBar = (StatusBarManager)context.getSystemService(Context.STATUS_BAR_SERVICE);  
  50.         }  
  51.   
  52.         Window window = getWindow();  
  53.         window.requestFeature(Window.FEATURE_NO_TITLE);  
  54.         window.setType(WindowManager.LayoutParams.TYPE_SYSTEM_DIALOG);  
  55.         window.setFlags(WindowManager.LayoutParams.FLAG_ALT_FOCUSABLE_IM,  
  56.                 WindowManager.LayoutParams.FLAG_ALT_FOCUSABLE_IM);  
  57.         window.setTitle("Recents");  
  58.   
  59.         setContentView(com.android.internal.R.layout.recent_apps_dialog);  
  60.   
  61.         final WindowManager.LayoutParams params = window.getAttributes();  
  62.         params.width = WindowManager.LayoutParams.MATCH_PARENT;  
  63.         params.height = WindowManager.LayoutParams.MATCH_PARENT;  
  64.         window.setAttributes(params);  
  65.         window.setFlags(0, WindowManager.LayoutParams.FLAG_DIM_BEHIND);  
  66.   
  67.         //默認顯示8個  
  68.         mIcons[0] = (TextView)findViewById(com.android.internal.R.id.button0);  
  69.         mIcons[1] = (TextView)findViewById(com.android.internal.R.id.button1);  
  70.         mIcons[2] = (TextView)findViewById(com.android.internal.R.id.button2);  
  71.         mIcons[3] = (TextView)findViewById(com.android.internal.R.id.button3);  
  72.         mIcons[4] = (TextView)findViewById(com.android.internal.R.id.button4);  
  73.         mIcons[5] = (TextView)findViewById(com.android.internal.R.id.button5);  
  74.         mIcons[6] = (TextView)findViewById(com.android.internal.R.id.button6);  
  75.         mIcons[7] = (TextView)findViewById(com.android.internal.R.id.button7);  
  76.         mNoAppsText = findViewById(com.android.internal.R.id.no_applications_message);  
  77.   
  78.         //關鍵在哪,你懂得...  
  79.         for (TextView b: mIcons) {  
  80.             b.setOnClickListener(this);  
  81.         }  
  82.     }  
  83.   
  84.     @Override  
  85.     public boolean onKeyDown(int keyCode, KeyEvent event) {  
  86.         if (keyCode == KeyEvent.KEYCODE_TAB) {  
  87.             // Ignore all meta keys other than SHIFT.  The app switch key could be a  
  88.             // fallback action chorded with ALT, META or even CTRL depending on the key map.  
  89.             // DPad navigation is handled by the ViewRoot elsewhere.  
  90.             final boolean backward = event.isShiftPressed();  
  91.             final int numIcons = mIcons.length;  
  92.             int numButtons = 0;  
  93.             while (numButtons < numIcons && mIcons[numButtons].getVisibility() == View.VISIBLE) {  
  94.                 numButtons += 1;  
  95.             }  
  96.             if (numButtons != 0) {  
  97.                 int nextFocus = backward ? numButtons - 1 : 0;  
  98.                 for (int i = 0; i < numButtons; i++) {  
  99.                     if (mIcons[i].hasFocus()) {  
  100.                         if (backward) {  
  101.                             nextFocus = (i + numButtons - 1) % numButtons;  
  102.                         } else {  
  103.                             nextFocus = (i + 1) % numButtons;  
  104.                         }  
  105.                         break;  
  106.                     }  
  107.                 }  
  108.                 final int direction = backward ? View.FOCUS_BACKWARD : View.FOCUS_FORWARD;  
  109.                 if (mIcons[nextFocus].requestFocus(direction)) {  
  110.                     mIcons[nextFocus].playSoundEffect(  
  111.                             SoundEffectConstants.getContantForFocusDirection(direction));  
  112.                 }  
  113.             }  
  114.   
  115.             // The dialog always handles the key to prevent the ViewRoot from  
  116.             // performing the default navigation itself.  
  117.             return true;  
  118.         }  
  119.   
  120.         return super.onKeyDown(keyCode, event);  
  121.     }  
  122.   
  123.     /** 
  124.      * Dismiss the dialog and switch to the selected application. 
  125.      */  
  126.     public void dismissAndSwitch() {  
  127.         final int numIcons = mIcons.length;  
  128.         RecentTag tag = null;  
  129.         for (int i = 0; i < numIcons; i++) {  
  130.             if (mIcons[i].getVisibility() != View.VISIBLE) {  
  131.                 break;  
  132.             }  
  133.             if (i == 0 || mIcons[i].hasFocus()) {  
  134.                 tag = (RecentTag) mIcons[i].getTag();  
  135.                 if (mIcons[i].hasFocus()) {  
  136.                     break;  
  137.                 }  
  138.             }  
  139.         }  
  140.         if (tag != null) {  
  141.             switchTo(tag);  
  142.         }  
  143.         dismiss();  
  144.     }  
  145.   
  146.     /** 
  147.      * Handler for user clicks.  If a button was clicked, launch the corresponding activity. 
  148.      */  
  149.     public void onClick(View v) {  
  150.         for (TextView b: mIcons) {  
  151.             if (b == v) {  
  152.                 RecentTag tag = (RecentTag)b.getTag();  
  153.                 switchTo(tag);  
  154.                 break;  
  155.             }  
  156.         }  
  157.         dismiss();  
  158.     }  
  159.   
  160.     //  
  161.     private void switchTo(RecentTag tag) {  
  162.         if (tag.info.id >= 0) {  
  163.             // This is an active task; it should just go to the foreground.  
  164.             final ActivityManager am = (ActivityManager)  
  165.                     getContext().getSystemService(Context.ACTIVITY_SERVICE);  
  166.             am.moveTaskToFront(tag.info.id, ActivityManager.MOVE_TASK_WITH_HOME);  
  167.         } else if (tag.intent != null) {  
  168.             tag.intent.addFlags(Intent.FLAG_ACTIVITY_LAUNCHED_FROM_HISTORY  
  169.                     | Intent.FLAG_ACTIVITY_TASK_ON_HOME);  
  170.             try {  
  171.                 getContext().startActivity(tag.intent);  
  172.             } catch (ActivityNotFoundException e) {  
  173.                 Log.w("Recent""Unable to launch recent task", e);  
  174.             }  
  175.         }  
  176.     }  
  177.   
  178.     /** 
  179.      * Set up and show the recent activities dialog. 
  180.      */  
  181.     @Override  
  182.     public void onStart() {  
  183.         super.onStart();  
  184.         reloadButtons();  
  185.         if (sStatusBar != null) {  
  186.             sStatusBar.disable(StatusBarManager.DISABLE_EXPAND);  
  187.         }  
  188.   
  189.         // receive broadcasts  
  190.         getContext().registerReceiver(mBroadcastReceiver, mBroadcastIntentFilter);  
  191.   
  192.         mHandler.removeCallbacks(mCleanup);  
  193.     }  
  194.   
  195.     /** 
  196.      * Dismiss the recent activities dialog. 
  197.      */  
  198.     @Override  
  199.     public void onStop() {  
  200.         super.onStop();  
  201.   
  202.         if (sStatusBar != null) {  
  203.             sStatusBar.disable(StatusBarManager.DISABLE_NONE);  
  204.         }  
  205.   
  206.         // stop receiving broadcasts  
  207.         getContext().unregisterReceiver(mBroadcastReceiver);  
  208.   
  209.         mHandler.postDelayed(mCleanup, 100);  
  210.      }  
  211.   
  212.     /** 
  213.      * Reload the 6 buttons with recent activities 
  214.      */  
  215.     private void reloadButtons() {  
  216.   
  217.         final Context context = getContext();  
  218.         final PackageManager pm = context.getPackageManager();  
  219.         final ActivityManager am = (ActivityManager)  
  220.                 context.getSystemService(Context.ACTIVITY_SERVICE);  
  221.         final List<ActivityManager.RecentTaskInfo> recentTasks =  
  222.                 am.getRecentTasks(MAX_RECENT_TASKS, ActivityManager.RECENT_IGNORE_UNAVAILABLE);  
  223.   
  224.         ActivityInfo homeInfo =   
  225.             new Intent(Intent.ACTION_MAIN).addCategory(Intent.CATEGORY_HOME)  
  226.                     .resolveActivityInfo(pm, 0);  
  227.   
  228.         IconUtilities iconUtilities = new IconUtilities(getContext());  
  229.   
  230.         // Performance note:  Our android performance guide says to prefer Iterator when  
  231.         // using a List class, but because we know that getRecentTasks() always returns  
  232.         // an ArrayList<>, we'll use a simple index instead.  
  233.         int index = 0;  
  234.         int numTasks = recentTasks.size();  
  235.         for (int i = 0; i < numTasks && (index < NUM_BUTTONS); ++i) {  
  236.             final ActivityManager.RecentTaskInfo info = recentTasks.get(i);  
  237.   
  238.             // for debug purposes only, disallow first result to create empty lists  
  239.             if (DBG_FORCE_EMPTY_LIST && (i == 0)) continue;  
  240.   
  241.             Intent intent = new Intent(info.baseIntent);  
  242.             if (info.origActivity != null) {  
  243.                 intent.setComponent(info.origActivity);  
  244.             }  
  245.   
  246.             // Skip the current home activity.  
  247.             if (homeInfo != null) {  
  248.                 if (homeInfo.packageName.equals(  
  249.                         intent.getComponent().getPackageName())  
  250.                         && homeInfo.name.equals(  
  251.                                 intent.getComponent().getClassName())) {  
  252.                     continue;  
  253.                 }  
  254.             }  
  255.   
  256.             intent.setFlags((intent.getFlags()&~Intent.FLAG_ACTIVITY_RESET_TASK_IF_NEEDED)  
  257.                     | Intent.FLAG_ACTIVITY_NEW_TASK);  
  258.             final ResolveInfo resolveInfo = pm.resolveActivity(intent, 0);  
  259.             if (resolveInfo != null) {  
  260.                 final ActivityInfo activityInfo = resolveInfo.activityInfo;  
  261.                 final String title = activityInfo.loadLabel(pm).toString();  
  262.                 Drawable icon = activityInfo.loadIcon(pm);  
  263.   
  264.                 if (title != null && title.length() > 0 && icon != null) {  
  265.                     final TextView tv = mIcons[index];  
  266.                     tv.setText(title);  
  267.                     icon = iconUtilities.createIconDrawable(icon);  
  268.                     tv.setCompoundDrawables(null, icon, nullnull);  
  269.                     RecentTag tag = new RecentTag();  
  270.                     tag.info = info;  
  271.                     tag.intent = intent;  
  272.                     tv.setTag(tag);  
  273.                     tv.setVisibility(View.VISIBLE);  
  274.                     tv.setPressed(false);  
  275.                     tv.clearFocus();  
  276.                     ++index;  
  277.                 }  
  278.             }  
  279.         }  
  280.   
  281.         // handle the case of "no icons to show"  
  282.         mNoAppsText.setVisibility((index == 0) ? View.VISIBLE : View.GONE);  
  283.   
  284.         // hide the rest  
  285.         for (; index < NUM_BUTTONS; ++index) {  
  286.             mIcons[index].setVisibility(View.GONE);  
  287.         }  
  288.     }  
  289.   
  290.     /** 
  291.      * This is the listener for the ACTION_CLOSE_SYSTEM_DIALOGS intent.  It's an indication that 
  292.      * we should close ourselves immediately, in order to allow a higher-priority UI to take over 
  293.      * (e.g. phone call received). 
  294.      */  
  295.     private BroadcastReceiver mBroadcastReceiver = new BroadcastReceiver() {  
  296.         @Override  
  297.         public void onReceive(Context context, Intent intent) {  
  298.             String action = intent.getAction();  
  299.             if (Intent.ACTION_CLOSE_SYSTEM_DIALOGS.equals(action)) {  
  300.                 String reason = intent.getStringExtra(PhoneWindowManager.SYSTEM_DIALOG_REASON_KEY);  
  301.                 if (! PhoneWindowManager.SYSTEM_DIALOG_REASON_RECENT_APPS.equals(reason)) {  
  302.                     dismiss();  
  303.                 }  
  304.             }  
  305.         }  
  306.     };  
  307. }  
  308.   
  309. RecentApplicationsDialog.java完整源碼  

從源碼可以看出,關鍵部分有三處。

 

一個很關鍵的內部類:

// 每個任務都包含一個Tag,這個Tag保存着這個App的一些非常有用的信息
    class RecentTag {
        ActivityManager.RecentTaskInfo info;
        Intent intent;
    }

這個RecentTag保存在每個近期任務的圖標裏,並且保存着這個任務的原始信息。

 

剛啓動Dialog時對每個任務的初始化:

  1. private void reloadButtons() {  
  2.   
  3.         final Context context = getContext();  
  4.         final PackageManager pm = context.getPackageManager();  
  5.         final ActivityManager am = (ActivityManager)  
  6.                 context.getSystemService(Context.ACTIVITY_SERVICE);  
  7.                   
  8.         //拿到最近使用的應用的信息列表  
  9.         final List<ActivityManager.RecentTaskInfo> recentTasks =  
  10.                 am.getRecentTasks(MAX_RECENT_TASKS, ActivityManager.RECENT_IGNORE_UNAVAILABLE);  
  11.   
  12.         //自制一個home activity info,用來區分  
  13.         ActivityInfo homeInfo =   
  14.             new Intent(Intent.ACTION_MAIN).addCategory(Intent.CATEGORY_HOME)  
  15.                     .resolveActivityInfo(pm, 0);  
  16.   
  17.         IconUtilities iconUtilities = new IconUtilities(getContext());  
  18.   
  19.         int index = 0;  
  20.         int numTasks = recentTasks.size();  
  21.         //開始初始化每個任務的信息  
  22.         for (int i = 0; i < numTasks && (index < NUM_BUTTONS); ++i) {  
  23.             final ActivityManager.RecentTaskInfo info = recentTasks.get(i);  
  24.   
  25.             //複製一個任務的原始Intent  
  26.             Intent intent = new Intent(info.baseIntent);  
  27.             if (info.origActivity != null) {  
  28.                 intent.setComponent(info.origActivity);  
  29.             }  
  30.   
  31.             //跳過home activity  
  32.             if (homeInfo != null) {  
  33.                 if (homeInfo.packageName.equals(  
  34.                         intent.getComponent().getPackageName())  
  35.                         && homeInfo.name.equals(  
  36.                                 intent.getComponent().getClassName())) {  
  37.                     continue;  
  38.                 }  
  39.             }  
  40.   
  41.             intent.setFlags((intent.getFlags()&~Intent.FLAG_ACTIVITY_RESET_TASK_IF_NEEDED)  
  42.                     | Intent.FLAG_ACTIVITY_NEW_TASK);  
  43.             final ResolveInfo resolveInfo = pm.resolveActivity(intent, 0);  
  44.             if (resolveInfo != null) {  
  45.                 final ActivityInfo activityInfo = resolveInfo.activityInfo;  
  46.                 final String title = activityInfo.loadLabel(pm).toString();  
  47.                 Drawable icon = activityInfo.loadIcon(pm);  
  48.   
  49.                 if (title != null && title.length() > 0 && icon != null) {  
  50.                     final TextView tv = mIcons[index];  
  51.                     tv.setText(title);  
  52.                     icon = iconUtilities.createIconDrawable(icon);  
  53.                     tv.setCompoundDrawables(null, icon, nullnull);  
  54.                     //new一個Tag,保存這個任務的RecentTaskInfo和Intent  
  55.                     RecentTag tag = new RecentTag();  
  56.                     tag.info = info;  
  57.                     tag.intent = intent;  
  58.                     tv.setTag(tag);  
  59.                     tv.setVisibility(View.VISIBLE);  
  60.                     tv.setPressed(false);  
  61.                     tv.clearFocus();  
  62.                     ++index;  
  63.                 }  
  64.             }  
  65.         }  
  66.   
  67.        ...//無關緊要的代碼  
  68.     }  

這裏的過程是:先用ActivityManager獲取RecentTasks並生成一個List,然後利用這個List爲Dialog中的每個任務初始化,並生成對應的信息RecentTag。

需要注意的是,RecentTag中的Intent是從對應任務的原始Intent複製過來的,這意味着那個原始Intent的一些Extra參數將會一併複製過來,

我來舉個例子:比如我的App支持從第三方啓動,並且第三方要提供一個token,當然這個token就以Extra參數的形式放進Intent裏,然後通過startActivity()啓動我的App;然後我的App根據這個token來處理,注意這裏,當我的App退出後,再從近期任務裏啓動這個App,之前的那個token還會傳遞給我的App,這裏就會出現錯誤了,原因就是上面分析的。這就是爲什麼從第三方跳轉的應用不會出現在近期任務的列表裏(比如點擊短信裏的url啓動一個瀏覽器,之後近期任務裏只有短信app,不會出現瀏覽器app)。要想不出現在近期任務裏,可以給Intent設置FLAG_ACTIVITY_NO_HISTORY標誌。

 

響應每個任務的點擊事件:

  1. private void switchTo(RecentTag tag) {  
  2.         if (tag.info.id >= 0) {  
  3.             // 這個Task沒有退出,直接移動到前臺  
  4.             final ActivityManager am = (ActivityManager)  
  5.                     getContext().getSystemService(Context.ACTIVITY_SERVICE);  
  6.             am.moveTaskToFront(tag.info.id, ActivityManager.MOVE_TASK_WITH_HOME);  
  7.         } else if (tag.intent != null) {  
  8.             //task退出了的話,id爲-1,則使用RecentTag中的Intent重新啓動  
  9.             tag.intent.addFlags(Intent.FLAG_ACTIVITY_LAUNCHED_FROM_HISTORY  
  10.                     | Intent.FLAG_ACTIVITY_TASK_ON_HOME);  
  11.             try {  
  12.                 getContext().startActivity(tag.intent);  
  13.             } catch (ActivityNotFoundException e) {  
  14.                 Log.w("Recent""Unable to launch recent task", e);  
  15.             }  
  16.         }  
  17.     }  

如果該Task沒有退出,只是切到後臺,則切換到前臺;如果已經退出,就要重新啓動了。

這裏的Intent就是之前說的,重複使用的舊Intent了,這裏注意,系統添加了FLAG_ACTIVITY_LAUNCHED_FROM_HISTORY和FLAG_ACTIVITY_TASK_ON_HOME標誌,所以我們可以在App中通過判斷Intent的flag是否包含這兩個來判斷是否是從近期任務裏啓動的。注意FLAG_ACTIVITY_TASK_ON_HOME標誌是Api 11添加的,所以11一下的之判斷FLAG_ACTIVITY_LAUNCHED_FROM_HISTORY就行了。


============================================================================================================================

本節內容是如何獲取Android系統中應用程序的信息,主要包括packagename、label、icon、佔用大小等。具體分爲兩個 部分,計劃如下:
第一部分: 獲取應用程序的packagename、label、icon等 ;

第二部分: 獲取應用程序的佔用大小,包括:緩存大小(cachsize)、數據大小(datasize)。

每部分都爲您準備了簡單豐富的實例,您一定不會錯過。

Android系統爲我們提供了很多服務管理的類,包括ActivityManager、PowerManager(電源管理)、AudioManager(音頻管理)

等。除此之外,還提供了一個PackageManger管理類,它的主要職責是管理應用程序包。 通過它,我們就可以獲取應用程序信息。

引入: AnroidManifest.xml文件節點說明: 

相關類的介紹

PackageItemInfo類
          說明: AndroidManifest.xml文件中所有節點的基類,提供了這些節點的基本信息:a label、icon、 meta-data。它並不

     直接使用,而是由子類繼承然後調用相應方法。

          常用字段:

               public int icon           獲得該資源圖片在R文件中的值 (對應於android:icon屬性)

               public int labelRes     獲得該label在R文件中的值(對應於android:label屬性)

               public String name   獲得該節點的name值 (對應於android:name屬性)

               public String packagename   獲得該應用程序的包名 (對應於android:packagename屬性)

         常用方法:

              Drawable  loadIcon(PackageManager pm)               獲得當前應用程序的圖像

              CharSequence  loadLabel(PackageManager pm)     獲得當前應用程序的label

  

 ActivityInfo類  繼承自 PackageItemInfo
          說明: 獲得應用程序中<activity/>或者 <receiver />節點的信息 。我們可以通過它來獲取我們設置的任何屬性,包括

      theme 、launchMode、launchmode等

             常用方法繼承至PackageItemInfo類中的loadIcon()和loadLabel()

 

   ServiceInfo 類
          說明: 同ActivityInfo類似 ,同樣繼承自 PackageItemInfo,只不過它表示的是<service>節點信息。

 

   ApplicationInfo類 繼承自  PackageItemInfo
         說明:獲取一個特定引用程序中<application>節點的信息。

         字段說明:

      flags字段: FLAG_SYSTEM 系統應用程序

                   FLAG_EXTERNAL_STORAGE 表示該應用安裝在sdcard中

         常用方法繼承至PackageItemInfo類中的loadIcon()和loadLabel()

 

  ResolveInfo類
        說明:根據<intent>節點來獲取其上一層目錄的信息,通常是<activity>、<receiver>、<service>節點信息。

       常用字段:

             public  ActivityInfo  activityInfo     獲取 ActivityInfo對象,即<activity>或<receiver >節點信息

             public ServiceInfo   serviceInfo     獲取 ServiceInfo對象,即<activity>節點信息

       常用方法:

             Drawable loadIcon(PackageManager pm)             獲得當前應用程序的圖像

             CharSequence loadLabel(PackageManager pm)  獲得當前應用程序的label

 

 PackageInfo類
       說明:手動獲取AndroidManifest.xml文件的信息 。

       常用字段:

           public String    packageName                   包名

           public ActivityInfo[]     activities                   所有<activity>節點信息

           public ApplicationInfo applicationInfo       <application>節點信息,只有一個

           public ActivityInfo[]    receivers                  所有<receiver>節點信息,多個

           public ServiceInfo[]    services                  所有<service>節點信息 ,多個

 

PackageManger 類
      說明: 獲得已安裝的應用程序信息 。可以通過getPackageManager()方法獲得。

      常用方法:

          public abstract PackageManager  getPackageManager()  

               功能:獲得一個PackageManger對象

         public abstrac  tDrawable    getApplicationIcon(StringpackageName)

               參數: packageName 包名

               功能:返回給定包名的圖標,否則返回null

 

       public abstract ApplicationInfo   getApplicationInfo(String packageName, int flags)

 

               參數:packagename 包名

                           flags 該ApplicationInfo是此flags標記,通常可以直接賦予常數0即可

               功能:返回該ApplicationInfo對象

 

          public abstract List<ApplicationInfo>  getInstalledApplications(int flags)

               參數:flag爲一般爲GET_UNINSTALLED_PACKAGES,那麼此時會返回所有ApplicationInfo。我們可以對ApplicationInfo

                     的flags過濾,得到我們需要的。

               功能:返回給定條件的所有PackageInfo

 

          public abstract List<PackageInfo>  getInstalledPackages(int flags) 

             參數如上

             功能:返回給定條件的所有PackageInfo

 

       public abstractResolveInfo  resolveActivity(Intent intent, int flags)

            參數:  intent 查尋條件,Activity所配置的action和category

                          flags: MATCH_DEFAULT_ONLY    :Category必須帶有CATEGORY_DEFAULT的Activity,才匹配

                                      GET_INTENT_FILTERS         :匹配Intent條件即可

                                                  GET_RESOLVED_FILTER    :匹配Intent條件即可

            功能 :返回給定條件的ResolveInfo對象(本質上是Activity)

 

       public abstract  List<ResolveInfo>  queryIntentActivities(Intent intent, int flags)

            參數同上

            功能 :返回給定條件的所有ResolveInfo對象(本質上是Activity),集合對象

 

      public abstract ResolveInfo  resolveService(Intent intent, int flags)

           參數同上

           功能 :返回給定條件的ResolveInfo對象(本質上是Service)

 

     public abstract List<ResolveInfo> queryIntentServices(Intent intent, int flags)

          參數同上

          功能 :返回給定條件的所有ResolveInfo對象(本質上是Service),集合對象




發佈了54 篇原創文章 · 獲贊 3 · 訪問量 44萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章