从0开始 开发一个属于自己的桌面程序

最近在开发一个新项目,需要把应用改成桌面,并引导用户设置为默认桌面,完成后的效果如下图:

1.添加XML

  <activity android:name=".activitys.DeskTop" android:launchMode="singleTop"><intent-filter><category android:name="android.intent.category.HOME" /><category android:name="android.intent.category.DEFAULT" /><action android:name="android.intent.action.MAIN"></action><category android:name="android.intent.category.LAUNCHER"></category></intent-filter></activity>

在主Activity里 添加

<category android:name="android.intent.category.HOME" />
<category android:name="android.intent.category.DEFAULT" />

这样用户在点按Home键的时候,就会弹出对话框,提示选择新的默认桌面

2.主Activity布局文件

布局比较简单,线性布局嵌套GridView,下面留了一点空袭是为了腾出空间放置拨号、短信常用APP

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="match_parent"android:orientation="vertical"android:id="@+id/desktop_linear"><LinearLayoutandroid:layout_width="match_parent"android:layout_height="match_parent"android:layout_weight="2"><GridViewandroid:id="@+id/mgv"android:layout_width="match_parent"android:layout_height="match_parent"android:numColumns="4"></GridView></LinearLayout><LinearLayoutandroid:layout_width="match_parent"android:layout_height="match_parent"android:layout_weight="8"></LinearLayout>
</LinearLayout>

3.获取APP列表

获取手机上已经安装的APP列表,同时过滤掉系统应用

public static List<AppInfo> GetAppList1(Context context){List<AppInfo> list=new ArrayList<>();PackageManager pm = context.getPackageManager();Intent mainIntent = new Intent(Intent.ACTION_MAIN, null);mainIntent.addCategory(Intent.CATEGORY_LAUNCHER);List<ResolveInfo> activities   = pm.queryIntentActivities(mainIntent, 0);for(ResolveInfo info : activities){String packName = info.activityInfo.packageName;if(packName.equals(context.getPackageName())){continue;}AppInfo mInfo = new AppInfo();mInfo.setIco(info.activityInfo.applicationInfo.loadIcon(pm));mInfo.setName(info.activityInfo.applicationInfo.loadLabel(pm).toString());mInfo.setPackageName(packName);// 为应用程序的启动Activity 准备IntentIntent launchIntent = new Intent();launchIntent.setComponent(new ComponentName(packName,info.activityInfo.name));mInfo.setIntent(launchIntent);list.add(mInfo);}return list;}

AppInfo的类也放出来

public class AppInfo {private String packageName; //包名private Drawable ico;       //图标private String Name;        //应用标签private Intent intent;     //启动应用程序的Intent ,一般是Action为Main和Category为Lancher的Activitypublic Intent getIntent() {return intent;}public void setIntent(Intent intent) {this.intent = intent;}public String getPackageName() {return packageName;}public void setPackageName(String packageName) {this.packageName = packageName;}public Drawable getIco() {return ico;}public void setIco(Drawable ico) {this.ico = ico;}public String getName() {return Name;}public void setName(String name) {Name = name;}
}

4.自定义BaseAdapter填充GridView数据

public class DeskTopGridViewBaseAdapter extends BaseAdapter {Context context;List<AppInfo> appInfos=new ArrayList<>();public DeskTopGridViewBaseAdapter(List<AppInfo> appInfos,Context context){this.appInfos=appInfos;this.context=context;}@Overridepublic int getCount() {return appInfos.size();}@Overridepublic Object getItem(int position) {return appInfos.get(position);}@Overridepublic long getItemId(int position) {return position;}@Overridepublic View getView(int position, View convertView, ViewGroup parent) {Holder holder=null;if (convertView==null){convertView = LayoutInflater.from(context).inflate(R.layout.desktop_gridview_item,null);holder=new Holder();holder.ico=(ImageView) convertView.findViewById(R.id.iv);holder.Name=(TextView) convertView.findViewById(R.id.tv);convertView.setTag(holder);}else {holder= (Holder) convertView.getTag();}holder.ico.setImageDrawable(appInfos.get(position).getIco());holder.Name.setText(appInfos.get(position).getName());return convertView;}static class Holder{ImageView ico;TextView Name;}

R.layout.desktop_gridview_item的布局文件

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="match_parent"android:orientation="vertical"android:gravity="center"><ImageViewandroid:layout_margin="5dp"android:id="@+id/iv"android:layout_width="wrap_content"android:layout_height="wrap_content"android:maxHeight="60dp"/><TextViewandroid:layout_margin="5dp"android:id="@+id/tv"android:layout_width="match_parent"android:layout_height="wrap_content"android:gravity="center"android:maxLines="1"android:text="Lable"/>
</LinearLayout>

5.在主Activity里填充数据,并给GridView的Item设置点击事件,点击图标之后打开该App

 private void initAppList() {appInfos=GetApps.GetAppList1(this);DeskTopGridViewBaseAdapter deskTopGridViewBaseAdapter=new DeskTopGridViewBaseAdapter(appInfos,this);mGridView.setAdapter(deskTopGridViewBaseAdapter);mGridView.setOnItemClickListener(new AdapterView.OnItemClickListener() {@Overridepublic void onItemClick(AdapterView<?> parent, View view, int position, long id) {
//                Intent intent=appInfos.get(position).getIntent();
//                startActivity(intent);Intent intent = getPackageManager().getLaunchIntentForPackage(appInfos.get(position).getPackageName());if (intent != null) {intent.putExtra("type", "110");intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);startActivity(intent);}}});}

到这里基本就打工搞成了,我们继续设置一下主Activity的背景为当前用户的桌面壁纸

 //设置背景WallpaperManager manager =WallpaperManager.getInstance(this);Drawable drawable=manager.getDrawable();linearLayout.setBackground(drawable);

这里需要注意,需要动态申请这两个权限,注意 是动态申请

<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />

继续,弹出对话框,让用户设置为默认桌面,这里针对小米、华为、普通安卓都有处理,我直接把代码贴出来

//桌面相关操作public class Desktop {private Context context;public Desktop(Context context) {this.context = context;}/*** 清除默认桌面(采用先设置一个空的桌面为默认然后在将该空桌面禁用的方式来实现)**/@SuppressLint("WrongConstant")public void clearDefaultLauncher() {PackageManager pm = context.getPackageManager();String pn = context.getPackageName();String hn = MockHome.class.getName();ComponentName mhCN = new ComponentName(pn, hn);Intent homeIntent = new Intent("android.intent.action.MAIN");homeIntent.addCategory("android.intent.category.HOME");homeIntent.addCategory("android.intent.category.DEFAULT");homeIntent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);pm.setComponentEnabledSetting(mhCN, 1, 1);context.startActivity(homeIntent);pm.setComponentEnabledSetting(mhCN, 0, 1);}//弹出选择默认桌面public void SetDefaultLauncher(){try {Intent  paramIntent = new Intent("android.intent.action.MAIN");paramIntent.setComponent(new ComponentName("android", "com.android.internal.app.ResolverActivity"));paramIntent.addCategory("android.intent.category.DEFAULT");paramIntent.addCategory("android.intent.category.HOME");context.startActivity(paramIntent);}catch (Exception e){e.printStackTrace();}try {Intent  paramIntent1 = new Intent("android.intent.action.MAIN");paramIntent1.setComponent(new ComponentName("com.huawei.android.internal.app", "com.huawei.android.internal.app.HwResolverActivity"));paramIntent1.addCategory("android.intent.category.DEFAULT");paramIntent1.addCategory("android.intent.category.HOME");context.startActivity(paramIntent1);}catch (Exception e){e.printStackTrace();startHuaweiSettingActOfDefLauncher();}}//打开华为设置页面,让用户选择默认桌面public void startHuaweiSettingActOfDefLauncher() {IntentFilter localIntentFilter = new IntentFilter();localIntentFilter.addAction(Intent.ACTION_MAIN);//"android.intent.action.MAIN"localIntentFilter.addCategory(Intent.CATEGORY_HOME);//"android.intent.category.HOME"Intent localIntent3 = new Intent(localIntentFilter.getAction(0));localIntent3.addCategory(localIntentFilter.getCategory(0));Intent localIntent4 = new Intent();localIntent4.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);localIntent4.setClassName("com.android.settings", "com.android.settings.Settings$PreferredSettingsActivity");localIntent4.putExtra("preferred_app_package_name", context.getPackageName());localIntent4.putExtra("preferred_app_class_name", context.getClass().getName());localIntent4.putExtra("is_user_confirmed", true);localIntent4.putExtra("preferred_app_intent", localIntent3);localIntent4.putExtra("preferred_app_intent_filter", localIntentFilter);localIntent4.putExtra("preferred_app_label", "默认桌面设置");context.startActivity(localIntent4);}//获取当前默认桌面,如果不是本App则弹出设置默认桌面对话框public void getDefaultHome() {final Intent intent = new Intent(Intent.ACTION_MAIN);intent.addCategory(Intent.CATEGORY_HOME);final ResolveInfo res = context.getPackageManager().resolveActivity(intent, 0);if (res.activityInfo == null) {//获取失败} else if (res.activityInfo.packageName.equals("android")) {// No default selectedclearDefaultLauncher();SetDefaultLauncher();} else {if (!res.activityInfo.packageName.equals("net.xiaomy.dxsjb.client")){clearDefaultLauncher();SetDefaultLauncher();}}}
}

这里注意:清除默认桌面,需要一个空的Activity,这里贴上xml文件代码,再自行添加一个Activity类就好

 <activity android:name=".activitys.MockHome" android:enabled="false"><intent-filter><action android:name="android.intent.action.MAIN" /><category android:name="android.intent.category.DEFAULT" /><category android:name="android.intent.category.HOME" /></intent-filter></activity>

我这里在主Activity里调用:

 //设置默认桌面Desktop desktop=new Desktop(this);desktop.getDefaultHome();

好了,到这里就算完成了,欢迎留言评论交流,转载请注明出处!

自己新开发的免费内网穿透项目小蚂蚁内网穿透,支持HTTP、TCP全端口映射,戳我进内网穿透官网www.xiaomy.net!

Android安卓-开发一个android桌面相关推荐

  1. 看故事自学Android安卓开发,Android安卓王国历险记第1集:Android问世

    在神秘而古老的东方文明古老国度,蓬莱岛一直是一个谜.同样在西方蛮夷岛国也住着一些科技怪咖,在硅谷岛上面到处都是科技大厦耸立着,比如巨鳄帮谷歌,美艳帮苹果,以及大众帮微软.为了找寻未来移动科技领域操作系 ...

  2. python安卓开发-一个Android开发者自学Python的心路历程

    前言 本人主要从事Android开发,也做过微信小程序,有时还会在Java那边客串一把(谁让Android是用的Java呢@~@),最近在自学Python,已有半月有余.因近年来,技术迭代快速,前端更 ...

  3. 开发一个android桌面

    本文的原文连接是: http://blog.csdn.net/freewebsys/article/details/53363731 未经博主允许不得转载. 博主地址是:http://blog.csd ...

  4. Win7环境下搭建Android安卓开发环境

    Win7环境下搭建Android安卓开发环境(原创教程) 此教程以32位win7旗舰版系统为基础,其它版本系统请根据情况自行调整.教程在2012年9月16日写,所有软件为当时的最新版. 准备文件(文件 ...

  5. 适合新手看的安卓开发书android studio

    第一行代码 Android 第2版 第二版 郭霖 手机app Android 安卓开发从入门到精通程序设计编程教程教材书籍  https://s.click.taobao.com/RkUcrzv 推荐 ...

  6. Android安卓开发集成微信第三方扫描二维码登录-超级无敌具详细

    Android安卓开发中集成微信二维码登录的步骤: 写在前面的: 该教程使用AS作为演示,使用ecplise请参照微信官方文档下载相应jar等所需参考文档和资源.在最后,我会附上这个Activity的 ...

  7. 基于Android Tv制作一个Tv桌面(二)

    标题基于Android Tv制作一个Tv桌面(二) 这里是获取APP的各种信息,不知道为什么这一步只能在主类MainActivity 上进行,不能在其他的类进行此操作,也许是我见识短浅的原因吧,因为其 ...

  8. android安卓开发入门视频教程资料百度网盘下载

    android安卓开发入门视频教程资料讲解安卓核心基础,包含视频+笔记,适合新手入门学习. 百度网盘:https://pan.baidu.com/s/1uciMAAa97nm5RSLILtdPdg&a ...

  9. android中的插件开发框架,设计并开发一个 Android 的插件化框架

    结合动态加载系列文章的分析,现在开始设计并开发一个 Android 的插件化框架,命名为 Frontia.Frontia 有 "前端" 的意思,寓意着 Android 插件能像前端 ...

最新文章

  1. 【运维学习笔记】运维入门
  2. linux挂载分区失败,Ubuntu分区挂载错误与Grub引导错误的修复
  3. js调用linux命令,xshell调用js脚本开发
  4. 【深度学习入门到精通系列】使用Plotly绘制气泡图(以U-Net等网络性能比较为例)
  5. python真的那么火吗-现在为什么 Python 这么火?
  6. [Eclipse]GEF入门系列(九、增加易用性)
  7. html标签缺省(自带)样式大全
  8. Linux 高可用(HA)集群之keepalived
  9. this全面解析, 如何定位this指向,一文总结,再也不怕面试官追问啦
  10. apache arm 交叉编译_移植apache2 ARM版 – 交叉编译apache2 | 学步园
  11. 宁波大学计算机网络实验五,宁波大学计算机网络实验答案
  12. 团队作业4——第一次项目冲刺 FiRsT DaY
  13. PyInstaller:编译exe与反编译
  14. java语言求101~200之间的质数(素数)
  15. Ember 从0到1
  16. [Constraints 18-5210] No constraints selected for write.
  17. 计算机系统结构——量化研究方法(第三版)
  18. STM32 USB组合设备HID+MIDI
  19. 【泛微ecology】E-Mobile 7 win+linux 安装包(版本20210409)
  20. 游戏服务器 协议 安全问题,游戏服务器开发安全问题

热门文章

  1. 牛客训练赛10 B栈和排序(栈)
  2. 九大难关!细数高新技术企业研发费用核算难点及应对方法!
  3. CPA十六--债务重组的界定(转载)
  4. 【已解决】【亲测有效】git绿色、红色图标不显示的问题
  5. Android日志输出
  6. Redis高级篇-多级缓存
  7. 阿里云更换系统或还原初始设置
  8. MT7688学习笔记(17)——OpenWRT与电脑之间SCP文件传输
  9. premiere pro cc 导入中文字幕不乱码
  10. cad详图怎么画_初学CAD如何能画的快,出图迅速?15个小技巧分钟成高手