您好,登錄后才能下訂單哦!
本篇文章給大家分享的是有關怎么在android中使用SkinManager實現一個換膚功能,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。
一、配置
在app下build.gradle中添加依賴:
//換膚功能 compile 'com.zhy:changeskin:4.0.2'
這樣就配置好了,然后在程序入口進行初始化。
二、全局初始化
在自己創建的繼承application的類中添加:
//換膚sdk初始化 SkinManager.getInstance().init(this);
這個類肯定要在清單文件<application/>節點配置的。
接下來還需要注冊。
三、注冊
在清單文件中添加權限:
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/> <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>
在使用換膚功能的頁面onCreate()中注冊:
//換膚功能頁面注冊 SkinManager.getInstance().register(this);
有注冊當然有注銷啊,在onDestroy方法中取消注冊:
//換膚功能注銷 SkinManager.getInstance().unregister(this);
四、命名規則
1、SkinManager命名規則是:前綴 + “_” + 后綴;
2、前綴、后綴的命名由開發者自行定義;
3、同屬性不同膚色前綴一樣,不同屬性前綴不一樣;
//例如:定義textColor屬性值為@color/skin_text,不同膚色color命名前綴均為skin_text
4、后綴根據膚色主題配置,每個主題所有屬性后綴一樣;
//例如:膚色有黑色、白色兩種主題,如果黑白定義為“black”“white”, //那么不管是textColor還是background屬于黑色主題的后綴就是black,屬于白色主題的后綴就是white。
五、膚色配置
1、在res/values/colors.xml中配置不同皮膚顏色:
<!--黑底白字(默認主題)--> <color name="skin_text">#FFFFFF</color> <!--黑底白字(黑色主題)--> <color name="skin_text_black">#FFFFFF</color> <!--白底黑字(白色主題)--> <color name="skin_text_white">#000000</color>
2、在res/drawable下創建背景shape:
skin_bg.xml(默認主題)
<?xml version="1.0" encoding="utf-8"?> <shape xmlns:android="http://schemas.android.com/apk/res/android" android:shape="rectangle"> <solid android:color="#000000"/> </shape>
skin_bg_black.xml(黑色主題)
<?xml version="1.0" encoding="utf-8"?> <shape xmlns:android="http://schemas.android.com/apk/res/android" android:shape="rectangle"> <solid android:color="#000000"/> </shape>
skin_bg_white.xml(白色主題)
<?xml version="1.0" encoding="utf-8"?> <shape xmlns:android="http://schemas.android.com/apk/res/android" android:shape="rectangle"> <solid android:color="#FFFFFF"/> </shape>
3、在src/drawable下導入不同主題圖片:
//圖片同樣以skin_src.png、skin_src_white.png、skin_src_black.png命名
注意:這三種膚色配置非必須,1常用來配置textColor屬性、2常用來配置background屬性、3常用來配置src屬性,根據項目需要自行設置
六、布局引用
布局中引用直接設置tag屬性。
textColor屬性設置:
<TextView android:id="@+id/title" android:layout_marginTop="@dimen/dp_10" android:gravity="center_horizontal" android:tag="skin:skin_text:textColor" android:text="測試文字" android:textColor="@color/skin_text" android:textSize="@dimen/sp_24" />
background屬性設置:
<RelativeLayout android:layout_width="match_parent" android:layout_height="match_parent" android:background="@drawable/skin_bg" android:tag="skin:skin_bg:background">
src屬性設置:
<ImageView android:src="@drawable/skin_src" android:tag="skin:skin_src:src"/>
注意:使用SkinManager,background屬性不支持@color設置,只能設置@drawable/...
七、tag屬性
分為三部分:
第一部分skin是固定值,不可改變;
第二部分skin_text、skin_bg、skin_src是膚色配置前綴;
第三部分textColor、background、src是膚色配置對應的屬性;
此外,tag屬性支持多屬性配置,用“|”分割,如:
<TextView android:layout_marginTop="@dimen/dp_10" android:background="@drawable/skin_bg" android:gravity="center_horizontal" android:onClick="changeClick" android:tag="skin:skin_text:textColor|skin:skin_bg:background" android:text="測試文字" android:textColor="@color/skin_text" android:textSize="@dimen/sp_24" />
同時設置了textColor和background屬性。
注意:第二部分(skin_text)不必與對應屬性值(android:textColor)的命名(@color/skin_text)完全一致,這里是因為我設置的skin_text為默認主題,如果你設置skin_text_default為默認主題,tag配置不變,屬性值應為@color/skin_text_default
八、換膚代碼
以第七項中的TextView點擊事件實現換膚為布局,在頁面中:
//聲明成員變量,默認false,默認主題為黑色 private boolean isChange; //實現設置點擊事件 public void changeClick(View view){ Log.e(TAG, "點擊改變"); isChange = !isChange; if(isChange){ SkinManager.getInstance().changeSkin("white"); }else{ SkinManager.getInstance().changeSkin("black"); } }
使用changeSkin("后綴")就實現了換膚功能;
如果要在彈窗中添加換膚功能,可以在彈窗布局添加換膚配置后,頁面代碼中調用SkinManager.getInstance()的injectSkin(View view)方法實現。
final Dialog dialog_skin = new Dialog(activity, R.style.MyDialogTheme); View contentView = View.inflate(activity, R.layout.dialog_skin, null); //實現對話框換膚 SkinManager.getInstance().injectSkin(contentView); DialogSkinBinding binding = DataBindingUtil.bind(contentView); dialog_skin.setCanceledOnTouchOutside(true); dialog_skin.show();
以上就是怎么在android中使用SkinManager實現一個換膚功能,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。