首先呢,在app的AndroidManifest.xml文件里,配置需要替换的logo和app名称
eg:下面配置了一套默认的,两套用于切换的icon和名称
android:enabled: 设为“true”时,就会启用当前别名的Activity,和当前的icon和当前的应用名称: 设为“false”时,表示停止使用当前别名的Activity
android:icon:当前别名的应用图标
android:label:当前别名的应用名称
android:name:别名,命名规则同Actively
android:targetActivity:通过别名调用的实际 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>
然后就是代码切换:相关方法介绍一下
通过 PackageManager 在清单文件中所定义的任何组件上切换 启用/停止 状态。
PackageManager.setComponentEnabledSetting
设置包组件(活动、接收器、服务、提供程序)的启用设置。此设置将覆盖组件在其清单中设置的任何启用状态。
参数:
componentName–要启用的组件
newState–组件的新启用状态。
flags–可选的行为标志
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>
csdn下载地址:3分意思意思
github下载地址:待补充
原文地址:https://blog.csdn.net/CGG92/article/details/122854932
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.7code.cn/show_40018.html
如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!