Android app本地切換logo和名稱
首先呢,在app的AndroidManifest.xml文件里,配置需要替換的logo和app名稱
eg:下面配置了一套默認(rèn)的,兩套用于切換的icon和名稱
android:enabled: 設(shè)為“true”時(shí),就會(huì)啟用當(dāng)前別名的Activity,和當(dāng)前的icon和當(dāng)前的應(yīng)用名稱: 設(shè)為“false”時(shí),表示停止使用當(dāng)前別名的Activity
android:icon:當(dāng)前別名的應(yīng)用圖標(biāo)
android:label:當(dāng)前別名的應(yīng)用名稱
android:name:別名,命名規(guī)則同Actively
android:targetActivity:通過別名調(diào)用的實(shí)際 Activity 的名稱
<?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.cgg.change_icon"> <application android:allowBackup="true" android:icon="@mipmap/ic_launcher" android:label="@string/app_name" android:supportsRtl="true" android:theme="@style/Theme.ChangeIcon"> <activity android:name=".MainActivity"/> <activity-alias android:name=".DefaultAliasActivity" android:enabled="true" android:icon="@mipmap/ic_launcher" android:label="ChangeIcon" android:targetActivity=".MainActivity"> <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity-alias> <activity-alias android:name=".Alias1Activity" android:enabled="false" android:icon="@mipmap/app_logo_b" android:label="ChangeIcon1" android:targetActivity=".MainActivity"> <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity-alias> <activity-alias android:name=".Alias2Activity" android:enabled="false" android:icon="@mipmap/app_logo_c" android:label="ChangeIcon2" android:targetActivity=".MainActivity"> <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity-alias> </application> </manifest>
然后就是代碼切換:相關(guān)方法介紹一下
通過 PackageManager 在清單文件中所定義的任何組件上切換 啟用/停止 狀態(tài)。
PackageManager.setComponentEnabledSetting
設(shè)置包組件(活動(dòng)、接收器、服務(wù)、提供程序)的啟用設(shè)置。此設(shè)置將覆蓋組件在其清單中設(shè)置的任何啟用狀態(tài)。
參數(shù):
componentName–要啟用的組件
newState–組件的新啟用狀態(tài)。
flags–可選的行為標(biāo)志
package com.cgg.change_icon import android.content.ComponentName import android.content.Context import android.content.pm.PackageManager import androidx.appcompat.app.AppCompatActivity import android.os.Bundle import android.widget.Button import android.widget.ImageView import android.widget.RadioGroup import androidx.annotation.StringDef class MainActivity : AppCompatActivity() { val APP_D = "com.cgg.change_icon.DefaultAliasActivity" val APP_1 = "com.cgg.change_icon.Alias1Activity" val APP_2 = "com.cgg.change_icon.Alias2Activity" private var mPackageManager: PackageManager? = null override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_main) mPackageManager = applicationContext.packageManager findViewById<ImageView>(R.id.iv_0).setOnClickListener { ShowComponent(APP_D) } findViewById<ImageView>(R.id.iv_1).setOnClickListener { ShowComponent(APP_1) } findViewById<ImageView>(R.id.iv_2).setOnClickListener { ShowComponent(APP_2) } } private fun ShowComponent(app: String){ packageManager.run { setComponentEnabledSetting( componentName, PackageManager.COMPONENT_ENABLED_STATE_DISABLED, PackageManager.DONT_KILL_APP ) setComponentEnabledSetting( ComponentName(baseContext, app), PackageManager.COMPONENT_ENABLED_STATE_ENABLED, PackageManager.DONT_KILL_APP ) } } }
布局也貼一下
<?xml version="1.0" encoding="utf-8"?> <androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" tools:context=".MainActivity"> <ImageView android:id="@+id/iv_0" android:layout_width="80dp" android:layout_height="80dp" android:scaleType="centerCrop" android:src="@mipmap/ic_launcher" app:layout_constraintLeft_toLeftOf="parent" app:layout_constraintRight_toRightOf="parent" app:layout_constraintTop_toTopOf="parent" android:layout_marginTop="30dp"/> <ImageView android:id="@+id/iv_1" android:layout_width="80dp" android:layout_height="80dp" android:scaleType="centerCrop" android:src="@mipmap/app_logo_b" app:layout_constraintLeft_toLeftOf="parent" app:layout_constraintRight_toRightOf="parent" app:layout_constraintTop_toBottomOf="@id/iv_0" android:layout_marginTop="30dp"/> <ImageView android:id="@+id/iv_2" android:layout_width="80dp" android:layout_height="80dp" android:scaleType="centerCrop" android:src="@mipmap/app_logo_c" app:layout_constraintLeft_toLeftOf="parent" app:layout_constraintRight_toRightOf="parent" app:layout_constraintTop_toBottomOf="@id/iv_1" android:layout_marginTop="30dp"/> </androidx.constraintlayout.widget.ConstraintLayout>
功能說完了,下面說下缺陷
替換的icon需要打包的時(shí)候就預(yù)埋到代碼里icon切換的時(shí)候和閃退一樣上過含activity-alias包后,如果再更新不含activity-alias包,會(huì)導(dǎo)致 APP 從桌面再也找不到的風(fēng)險(xiǎn)
到此這篇關(guān)于Android app本地切換logo和名稱的文章就介紹到這了,更多相關(guān)Android 切換logo和名稱內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
android中TabHost的圖標(biāo)(48×48)和文字疊加解決方法
開發(fā)過程中,有時(shí)候圖標(biāo)稍微大點(diǎn),比如48×48的時(shí)候,文字就會(huì)和圖標(biāo)疊加起來,遇到這種問題我們?cè)撛鯓犹幚砟??本文將詳?xì)介紹希望對(duì)你有所幫助2013-01-01Java中的final關(guān)鍵字詳解及實(shí)例
這篇文章主要介紹了Java中的final關(guān)鍵字詳解及實(shí)例的相關(guān)資料,需要的朋友可以參考下2017-01-01Android中使用ScrollView實(shí)現(xiàn)滑動(dòng)到底部顯示加載更多
本文主要介紹了android利用ScrollView實(shí)現(xiàn)滑動(dòng)到底部顯示加載更多的示例代碼。具有很好的參考價(jià)值。下面跟著小編一起來看下吧2017-04-04ViewFlipper實(shí)現(xiàn)文字輪播效果
這篇文章主要為大家詳細(xì)介紹了ViewFlipper實(shí)現(xiàn)文字輪播效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-08-08Android中關(guān)于屏幕的三個(gè)小眾知識(shí)(寬屏適配、禁止截屏和保持屏幕常亮)
這篇文章主要給大家介紹了Android中關(guān)于屏幕的三個(gè)小眾知識(shí),分別是寬屏適配、禁止截屏和保持屏幕常亮的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友們可以參考學(xué)習(xí),下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2017-12-12