Android app本地切換logo和名稱
首先呢,在app的AndroidManifest.xml文件里,配置需要替換的logo和app名稱
eg:下面配置了一套默認(rèn)的,兩套用于切換的icon和名稱
android:enabled: 設(shè)為“true”時,就會啟用當(dāng)前別名的Activity,和當(dāng)前的icon和當(dāng)前的應(yīng)用名稱: 設(shè)為“false”時,表示停止使用當(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)用的實際 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è)置包組件(活動、接收器、服務(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需要打包的時候就預(yù)埋到代碼里icon切換的時候和閃退一樣上過含activity-alias包后,如果再更新不含activity-alias包,會導(dǎo)致 APP 從桌面再也找不到的風(fēng)險
到此這篇關(guān)于Android app本地切換logo和名稱的文章就介紹到這了,更多相關(guān)Android 切換logo和名稱內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
android中TabHost的圖標(biāo)(48×48)和文字疊加解決方法
開發(fā)過程中,有時候圖標(biāo)稍微大點,比如48×48的時候,文字就會和圖標(biāo)疊加起來,遇到這種問題我們該怎樣處理呢?本文將詳細(xì)介紹希望對你有所幫助2013-01-01Android中使用ScrollView實現(xiàn)滑動到底部顯示加載更多
本文主要介紹了android利用ScrollView實現(xiàn)滑動到底部顯示加載更多的示例代碼。具有很好的參考價值。下面跟著小編一起來看下吧2017-04-04Android中關(guān)于屏幕的三個小眾知識(寬屏適配、禁止截屏和保持屏幕常亮)
這篇文章主要給大家介紹了Android中關(guān)于屏幕的三個小眾知識,分別是寬屏適配、禁止截屏和保持屏幕常亮的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友們可以參考學(xué)習(xí),下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2017-12-12