1. public class MainActivity extends Activity
  2. {
  3. private Button defaultbutton = null;
  4. @Override
  5. public void onCreate(Bundle savedInstanceState)
  6. {
  7. super.onCreate(savedInstanceState);
  8. setContentView(R.layout.main);
  9. final LinearLayout layout = (LinearLayout) findViewById(R.id.layout);
  10. //默认皮肤
  11. defaultbutton = (Button)findViewById(R.id.defaultButton);
  12. defaultbutton.setOnClickListener(new OnClickListener() {
  13. @Override
  14. public void onClick(View v)
  15. {
  16. layout.setBackgroundResource(R.drawable.netskin);
  17. }
  18. });
  19. //为其他皮肤添加点击按钮
  20. ArrayList<PackageInfo> skinList = getAllSkin();
  21. for (int i = 0; i < skinList.size(); i++)
  22. {
  23. try
  24. {
  25. final Context context = createPackageContext(skinList.get(i).packageName,
  26. Context.CONTEXT_IGNORE_SECURITY);
  27. Button btn = new Button(this);
  28. btn.setLayoutParams(new LayoutParams(LayoutParams.FILL_PARENT, LayoutParams.WRAP_CONTENT));
  29. btn.setText(context.getText(R.string.app_name));
  30. btn.setOnClickListener(new OnClickListener() {
  31. @Override
  32. public void onClick(View v)
  33. {
  34. layout.setBackgroundDrawable(context.getResources().getDrawable(R.drawable.netskin));
  35. }
  36. });
  37. layout.addView(btn);
  38. }
  39. catch (NameNotFoundException e)
  40. {
  41. e.printStackTrace();
  42. }
  43. }
  44. }
  45. /**
  46. * 获取所有已安装的皮肤主题
  47. *
  48. * @return
  49. */
  50. private ArrayList<PackageInfo> getAllSkin()
  51. {
  52. ArrayList<PackageInfo> skinList = new ArrayList<PackageInfo>();
  53. List<PackageInfo> packs = getPackageManager().getInstalledPackages(0);
  54. for (PackageInfo p : packs)
  55. {
  56. if (isSkinPackage(p.packageName))
  57. {
  58. skinList.add(p);
  59. }
  60. }
  61. return skinList;
  62. }
  63. /**
  64. * 判断是否是皮肤主题
  65. *
  66. * @param packageName
  67. * @return
  68. */
  69. private boolean isSkinPackage(String packageName)
  70. {
  71. // 自己制作的皮肤主题包名 例如:sunlight.skin0 sunlight.skin1等等
  72. String rex = "sunlight.skin\\w";
  73. Pattern pattern = Pattern.compile(rex);
  74. Matcher matcher = pattern.matcher(packageName);
  75. return matcher.find();
  76. }
  77. }

main.xml

    1. <?xml version="1.0" encoding="utf-8"?>
    2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    3. android:id="@+id/layout"
    4. android:layout_width="fill_parent"
    5. android:layout_height="fill_parent"
    6. android:orientation="vertical" >
    7. <Button
    8. android:id="@+id/defaultButton"
    9. android:layout_width="fill_parent"
    10. android:layout_height="wrap_content"
    11. android:text="默认皮肤" />
    12. </LinearLayout>

Android进阶2之APK方式换肤的更多相关文章

  1. Android APK方式换肤实现原理

    现在很多APP都有换肤的功能,例如微博,QQ等应用.这些应用的换肤原理是什么? 在用微博的时候,不难发现,当你要换肤时,先下载并安装一个皮肤apk,然后选择这个皮肤,就可以了. 这种方式就是把皮肤打包 ...

  2. Android实现apk插件方式换肤

    换肤思路: 1.什么时候换肤? xml加载前换肤,如果xml加载后换肤,用户将会看见换肤之前的色彩,用户体验不好. 2.皮肤是什么? 皮肤就是apk,是一个资源包,包含了颜色.图片等. 3.什么样的控 ...

  3. Android中插件开发篇之----应用换肤原理解析

    一.前言 今天又到周末了,感觉时间过的很快呀.又要写blog了.那么今天就来看看应用的换肤原理解析.在之前的一篇博客中我说道了Android中的插件开发篇的基础:类加载器的相关知识.没看过的同学可以转 ...

  4. Android QMUI实战:实现APP换肤功能,并自动适配手机深色模式

    Android换肤功能已不是什么新鲜事了,市面上有很多第三方的换肤库和实现方案. 之所以选择腾讯的QMUI库来演示APP的换肤功能,主要原因: 1.换肤功能的实现过程较简单.容易理解: 2.能轻松适配 ...

  5. Android 换肤功能的实现(Apk插件方式)

    一.概述 由于Android 没有提供一套统一的换肤机制,我猜可能是因为国外更注重功能和体验的原因 所以国内如果要做一个漂亮的换肤方案,需要自己去实现. 目前换肤的方法大概有三种方案: (1)把皮肤资 ...

  6. Android 打造自己的个性化应用(一):应用程序换肤主流方式的分析与概述

    Android平台api没有特意为换肤提供一套简便的机制,这可能是外国的软件更注重功能和易用,不流行换肤.系统不提供直接支持,只能自行研究. 换肤,可以认为是动态替换资源(文字.颜色.字体大小.图片. ...

  7. Android App插件式换肤实现方案

    背景 目前很多app都具有换肤功能,用户可以根据需要切换不同的皮肤,为使我们的App支持换肤功能,给用户提供更好的体验,在这里对换肤原理进行研究总结,并选择一个合适的换肤解决方案. 换肤介绍 App换 ...

  8. Android动态换肤(二、apk免安装插件方式)

    在上一篇文章Android动态换肤(一.应用内置多套皮肤)中,我们了解到,动态换肤无非就是调用view的setBackgroundResource(R.drawable.id)等方法设置控件的背景或者 ...

  9. Android逆向之旅---动态方式破解apk进阶篇(IDA调试so源码)

    Android逆向之旅---动态方式破解apk进阶篇(IDA调试so源码) 来源 https://blog.csdn.net/jiangwei0910410003/article/details/51 ...

随机推荐

  1. Spring+iBatis+Atomikos实现JTA事务

    Atomikos是一个公司名字,旗下最著名的莫过于其Atomikos的事务管理器产品. 产品分两个:一个是开源的TransactionEssentials,一个是商业的ExtremeTransacti ...

  2. codeforces 680E Bear and Square Grid 巧妙暴力

    这个题是个想法题 先预处理连通块,然后需要用到一种巧妙暴力,即0变1,1变0,一列列添加删除 复杂度O(n^3) #include <cstdio> #include <iostre ...

  3. 仿酷狗音乐播放器开发日志二十四 选项设置窗体的实现(附328行xml布局源码)

    转载请说明原出处,谢谢~~ 花了两天时间把仿酷狗的选项设置窗体做出来了,当然了只是做了外观.现在开学了,写代码的时间减少,所以整个仿酷狗的工程开发速度减慢了.今天把仿酷狗的选项设置窗体的布局代码分享出 ...

  4. Flume OG 与 Flume NG 的区别

    1.Flume OG:Flume original generation 即Flume 0.9.x版本    Flume NG:Flume next generation ,即Flume 1.x版本 ...

  5. Python学习之eventlet.greenpool

    该模块提供对 greenthread 池的支持. greenthread 池提供了一定数量的备用 greenthread ,有效限制了孵化 greenthread 过多导致的内存不足,当池子中没有足够 ...

  6. HDU 1536 sg-NIM博弈类

    题意:每次可以选择n种操作,玩m次,问谁必胜.c堆,每堆数量告诉. 题意:sg—NIM系列博弈模板题 把每堆看成一个点,求该点的sg值,异或每堆sg值. 将多维转化成一维,性质与原始NIM博弈一样. ...

  7. restsharp发送服务端请求回传session

    今天工作遇到这样一个场景,我需要获取一个游戏目录列表,这个列表接口在线上已经存在,但是这个接口需要登录认证后才能获取到,所以实现这个功能我打算分两部来做: 1.首先调登录接口,以写上session 2 ...

  8. Bias/variance tradeoff

    线性回归中有欠拟合与过拟合,例如下图: 则会形成欠拟合, 则会形成过拟合. 尽管五次多项式会精确的预测训练集中的样本点,但在预测训练集中没有的数据,则不能很好的预测,也就是说有较大的泛化误差,上面的右 ...

  9. Windows 窗体—— 键盘输入工作原理

    方法 注释 PreFilterMessage 此方法在应用程序级截获排队的(也称为已发送的)Windows 消息. PreProcessMessage 此方法在 Windows 消息处理前在窗体和控件 ...

  10. Spark SQL概念学习系列之Spark SQL 架构分析(四)

    Spark SQL 与传统 DBMS 的查询优化器 + 执行器的架构较为类似,只不过其执行器是在分布式环境中实现,并采用的 Spark 作为执行引擎. Spark SQL 的查询优化是Catalyst ...