Android Activity中启动另一应用程序的方法,无需得到类名

简介:   Android Activity中启动另一应用程序的方法,无需得到类名    在网上搜索了一会相关的实现代码,发现所有的文章都说是需要包名和类名。但是人家的程序,我们怎么可能知道哪个是第一个启动的Activity?所以,真正用在项目上,那种方法基本上没什么用的。
 

Android Activity中启动另一应用程序的方法,无需得到类名 

 

在网上搜索了一会相关的实现代码,发现所有的文章都说是需要包名和类名。但是人家的程序,我们怎么可能知道哪个是第一个启动的Activity?所以,真正用在项目上,那种方法基本上没什么用的。于是查看官方文档,发现这样一个方法: 

Java代码   收藏代码
  1. public abstract Intent getLaunchIntentForPackage (String packageName)  



英文原文:Return a “good” intent to launch a front-door activity in a package, for use for example to implement an “open” button when browsing through packages.大概意思就是返回一个程序入口的Intent,就是Java程序的Main方法。 
这下简单了,直接startActivity(返回的intent)即可。

 

Java代码   收藏代码
  1. import java.util.ArrayList;  
  2. import java.util.HashMap;  
  3. import java.util.List;  
  4.    
  5. import android.app.Activity;  
  6. import android.content.Intent;  
  7. import android.content.pm.PackageInfo;  
  8. import android.content.pm.PackageManager;  
  9. import android.os.Bundle;  
  10. import android.view.View;  
  11. import android.widget.AdapterView;  
  12. import android.widget.ListView;  
  13. import android.widget.AdapterView.OnItemClickListener;  
  14.    
  15. public class Main extends Activity {  
  16.     /** Called when the activity is first created. */  
  17.     ListView lv;  
  18.     Adapter adapter;  
  19.     ArrayList<HashMap<String, Object>> items = new ArrayList<HashMap<String, Object>>();  
  20.     PackageManager pm;  
  21.    
  22.     @Override  
  23.     public void onCreate(Bundle savedInstanceState) {  
  24.         super.onCreate(savedInstanceState);  
  25.         setContentView(R.layout.main);  
  26.         lv = (ListView) findViewById(R.id.lv);  
  27.         final PackageManager pm = getPackageManager();  
  28.         // 得到PackageManager对象  
  29.         List<PackageInfo> packs = pm  
  30.                 .getInstalledPackages(PackageManager.GET_UNINSTALLED_PACKAGES);  
  31.         // 得到系统 安装的所有程序包的PackageInfo对象  
  32.    
  33.         for (PackageInfo pi : packs) {  
  34.             HashMap<String, Object> map = new HashMap<String, Object>();  
  35.             map.put("icon", pi.applicationInfo.loadIcon(pm));  
  36.             // 图标  
  37.             map.put("appName", pi.applicationInfo.loadLabel(pm));  
  38.             // 应用名  
  39.             map.put("packageName", pi.packageName);  
  40.             // 包名  
  41.             items.add(map);  
  42.             // 循环读取存到HashMap,再增加到ArrayList.一个HashMap就是一项  
  43.         }  
  44.    
  45.         adapter = new Adapter(this, items, R.layout.piitem, new String[] {  
  46.                 "icon""appName""packageName" }, new int[] { R.id.icon,  
  47.                 R.id.appName, R.id.packageName });  
  48.         // 参数:Context,ArrayList(item的集合),item的layout,包含ArrayList中Hashmap的key的数组,key所对应的值相对应的控件id  
  49.         lv.setAdapter(adapter);  
  50.         lv.setOnItemClickListener(new OnItemClickListener() {  
  51.    
  52.             @Override  
  53.             public void onItemClick(AdapterView<?> parent, View view,  
  54.                     int position, long id) {  
  55.                 // TODO Auto-generated method stub  
  56.                 String packageName = (String) items.get(position).get(  
  57.                         "packageName");  
  58.                 //取到点击的包名  
  59.                 Intent i = pm.getLaunchIntentForPackage(packageName);  
  60.                 //如果该程序不可启动(像系统自带的包,有很多是没有入口的)会返回NULL  
  61.                 if (i != null)  
  62.                     startActivity(i);  
  63.             }  
  64.    
  65.         });  
  66.    
  67.     }  
  68.    
  69. }  
相关文章
|
12月前
|
开发框架 前端开发 Android开发
Flutter 与原生模块(Android 和 iOS)之间的通信机制,包括方法调用、事件传递等,分析了通信的必要性、主要方式、数据传递、性能优化及错误处理,并通过实际案例展示了其应用效果,展望了未来的发展趋势
本文深入探讨了 Flutter 与原生模块(Android 和 iOS)之间的通信机制,包括方法调用、事件传递等,分析了通信的必要性、主要方式、数据传递、性能优化及错误处理,并通过实际案例展示了其应用效果,展望了未来的发展趋势。这对于实现高效的跨平台移动应用开发具有重要指导意义。
1088 4
|
7月前
|
存储 Android开发
如何查看Flutter应用在Android设备上已被撤销的权限?
如何查看Flutter应用在Android设备上已被撤销的权限?
290 64
|
6月前
|
Android开发 开发者
Android自定义view之利用drawArc方法实现动态效果
本文介绍了如何通过Android自定义View实现动态效果,重点使用`drawArc`方法完成圆弧动画。首先通过`onSizeChanged`进行测量,初始化画笔属性,设置圆弧相关参数。核心思路是不断改变圆弧扫过角度`sweepAngle`,并调用`invalidate()`刷新View以实现动态旋转效果。最后附上完整代码与效果图,帮助开发者快速理解并实践这一动画实现方式。
154 0
|
4月前
|
安全 数据库 Android开发
在Android开发中实现两个Intent跳转及数据交换的方法
总结上述内容,在Android开发中,Intent不仅是活动跳转的桥梁,也是两个活动之间进行数据交换的媒介。运用Intent传递数据时需注意数据类型、传输大小限制以及安全性问题的处理,以确保应用的健壯性和安全性。
274 11
|
7月前
|
存储 Android开发 数据安全/隐私保护
如何在Android设备上撤销Flutter应用程序的所有权限?
如何在Android设备上撤销Flutter应用程序的所有权限?
390 64
|
7月前
|
缓存 Android开发 开发者
Flutter环境配置完成后,如何在Android设备上运行Flutter应用程序?
Flutter环境配置完成后,如何在Android设备上运行Flutter应用程序?
1128 62
|
7月前
|
开发工具 Android开发 开发者
在Android设备上运行Flutter应用程序时,如果遇到设备未授权的问题该如何解决?
在Android设备上运行Flutter应用程序时,如果遇到设备未授权的问题该如何解决?
376 61
|
9月前
|
前端开发 Java Shell
【08】flutter完成屏幕适配-重建Android,增加GetX路由,屏幕适配,基础导航栏-多版本SDK以及gradle造成的关于fvm的使用(flutter version manage)-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
【08】flutter完成屏幕适配-重建Android,增加GetX路由,屏幕适配,基础导航栏-多版本SDK以及gradle造成的关于fvm的使用(flutter version manage)-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
558 20
【08】flutter完成屏幕适配-重建Android,增加GetX路由,屏幕适配,基础导航栏-多版本SDK以及gradle造成的关于fvm的使用(flutter version manage)-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
|
9月前
|
Dart 前端开发 Android开发
【09】flutter首页进行了完善-采用android studio 进行真机调试开发-增加了直播间列表和短视频人物列表-增加了用户中心-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
【09】flutter首页进行了完善-采用android studio 进行真机调试开发-增加了直播间列表和短视频人物列表-增加了用户中心-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
243 4
【09】flutter首页进行了完善-采用android studio 进行真机调试开发-增加了直播间列表和短视频人物列表-增加了用户中心-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
|
12月前
|
算法 Java 数据库
Android 应用的主线程在什么情况下会被阻塞?
【10月更文挑战第20天】为了避免主线程阻塞,我们需要合理地设计和优化应用的代码。将耗时操作移到后台线程执行,使用异步任务、线程池等技术来提高应用的并发处理能力。同时,要注意避免出现死循环、不合理的锁使用等问题。通过这些措施,可以确保主线程能够高效地运行,提供流畅的用户体验。
517 58

热门文章

最新文章

下一篇
开通oss服务