autoBackupApkDir = “${bakPath}”
// 是否启用覆盖tinkerPatch配置功能,默认值false
// 开启后tinkerPatch配置不生效,即无需添加tinkerPatch
overrideTinkerPatchConfiguration = true
// 编译补丁包时,必需指定基线版本的apk,默认值为空
// 如果为空,则表示不是进行补丁包的编译
// @{link tinkerPatch.oldApk }
baseApk = “ b a k P a t h / {bakPath}/ bakPath/{baseApkDir}/app-release.apk”
// 对应tinker插件applyMapping
baseApkProguardMapping = “ b a k P a t h / {bakPath}/ bakPath/{baseApkDir}/app-release-mapping.txt”
// 对应tinker插件applyResourceMapping
baseApkResourceMapping = “ b a k P a t h / {bakPath}/ bakPath/{baseApkDir}/app-release-R.txt”
// 构建基准包和补丁包都要指定不同的tinkerId,并且必须保证唯一性
tinkerId = “base-1.0.1”
// 构建多渠道补丁时使用
// buildAllFlavorsDir = “ b a k P a t h / {bakPath}/ bakPath/{baseApkDir}”
// 是否启用加固模式,默认为false.(tinker-spport 1.0.7起支持)
// isProtectedApp = true
// 是否开启反射Application模式
enableProxyApplication = false
// 是否支持新增非export的Activity(注意:设置为true才能修改AndroidManifest文件)
supportHotplugComponent = true
}
/**
-
一般来说,我们无需对下面的参数做任何的修改
-
对于各参数的详细介绍请参考:
-
https://github.com/Tencent/tinker/wiki/Tinker-%E6%8E%A5%E5%85%A5%E6%8C%87%E5%8D%97
*/
tinkerPatch {
//oldApk =“ b a k P a t h / {bakPath}/ bakPath/{appName}/app-release.apk”
ignoreWarning = false
useSign = true
dex {
dexMode = “jar”
pattern = [“classes*.dex”]
loader = []
}
lib {
pattern = [“lib//.so”]
}
res {
pattern = [“res/", "r/”, “assets/*”, “resources.arsc”, “AndroidManifest.xml”]
ignoreChange = []
largeModSize = 100
}
packageConfig {
}
sevenZip {
zipArtifact = “com.tencent.mm:SevenZip:1.1.10”
// path = “/usr/local/bin/7za”
}
buildConfig {
keepDexApply = false
//tinkerId = “1.0.1-base”
//applyMapping = “ b a k P a t h / {bakPath}/ bakPath/{appName}/app-release-mapping.txt” // 可选,设置mapping文件,建议保持旧apk的proguard混淆方式
//applyResourceMapping = “ b a k P a t h / {bakPath}/ bakPath/{appName}/app-release-R.txt” // 可选,设置R.txt文件,通过旧apk文件保持ResId的分配
}
}
enableProxyApplication = false的情况
集成Bugly升级SDK之后,我们需要按照以下方式自定义ApplicationLike来实现的应用的代码(以下是示例):
自定义应用程序
public class SampleApplication extends TinkerApplication {
public SampleApplication() {
super(ShareConstants.TINKER_ENABLE_ALL, “xxx.xxx.SampleApplicationLike”,
“com.tencent.tinker.loader.TinkerLoader”, false);
}
}
参数1:tinkerFlags表示Tinker支持的类型dex only,仅库或所有suuport,默认:TINKER_ENABLE_ALL
参数2:delegateClassName Application代理类这里填写你自定义的ApplicationLike
参数3:loaderClassName Tinker的加载器,使用默认即可
参数4:tinkerLoadVerifyFlag加载dex或者lib是否验证md5,默认为false
需要一个应用配置为继承TinkerApplication的类:
自定义ApplicationLike:
public class SampleApplicationLike extends DefaultApplicationLike {
public static final String TAG = “Tinker.SampleApplicationLike”;
public SampleApplicationLike(Application application, int tinkerFlags,
boolean tinkerLoadVerifyFlag, long applicationStartElapsedTime,
long applicationStartMillisTime, Intent tinkerResultIntent) {
super(application, tinkerFlags, tinkerLoadVerifyFlag, applicationStartElapsedTime, applicationStartMillisTime, tinkerResultIntent);
}
@Override
public void onCreate() {
super.onCreate();
// 这里实现SDK初始化,appId替换成你的在Bugly平台申请的appId
// 调试时,将第三个参数改为true
Bugly.init(getApplication(), “900029763”, false);
}
@TargetApi(Build.VERSION_CODES.ICE_CREAM_SANDWICH)
@Override
public void onBaseContextAttached(Context base) {
super.onBaseContextAttached(base);
// you must install multiDex whatever tinker is installed!
MultiDex.install(base);
// 安装tinker
// TinkerManager.installTinker(this); 替换成下面Bugly提供的方法
Beta.installTinker(this);
}
@TargetApi(Build.VERSION_CODES.ICE_CREAM_SANDWICH)
public void registerActivityLifecycleCallback(Application.ActivityLifecycleCallbacks callbacks) {
getApplication().registerActivityLifecycleCallbacks(callbacks);
}
}
enableProxyApplication = true的情况:
public class MyApplication extends Application {
@Override
public void onCreate() {
super.onCreate();
// 这里实现SDK初始化,appId替换成你的在Bugly平台申请的appId
// 调试时,将第三个参数改为true
Bugly.init(this, “900029763”, false);
}
@Override
protected void attachBaseContext(Context base) {
super.attachBaseContext(base);
// you must install multiDex whatever tinker is installed!
MultiDex.install(base);
// 安装tinker
Beta.installTinker();
}
}
在AndroidMainfest.xml中进行以下配置:
- 权限配置
- 活动配置
<activity
android:name=“com.tencent.bugly.beta.ui.BetaActivity”
android:configChanges=“keyboardHidden|orientation|screenSize|locale”
android:theme=“@android:style/Theme.Translucent” />
- 配置FileProvider
<provider
android:name=“android.support.v4.content.FileProvider”
android:authorities=“${applicationId}.fileProvider”
android:exported=“false”
android:grantUriPermissions=“true”>
<meta-data
android:name=“android.support.FILE_PROVIDER_PATHS”
android:resource=“@xml/provider_paths”/>
如果你使用的第三方库也配置了同样的FileProvider,可以通过继承FileProvider类来解决合并冲突的问题,示例如下:
<provider
android:name=“.utils.BuglyFileProvider”
android:authorities=“${applicationId}.fileProvider”
android:exported=“false”
android:grantUriPermissions=“true”
tools:replace=“name,authorities,exported,grantUriPermissions”>
<meta-data
android:name=“android.support.FILE_PROVIDER_PATHS”
android:resource=“@xml/provider_paths”
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数初中级安卓工程师,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年最新Android移动开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频
如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注Android)
最后
对于很多初中级Android工程师而言,想要提升技能,往往是自己摸索成长。而不成体系的学习效果低效漫长且无助。时间久了,付出巨大的时间成本和努力,没有看到应有的效果,会气馁是再正常不过的。
所以学习一定要找到最适合自己的方式,有一个思路方法,不然不止浪费时间,更可能把未来发展都一起耽误了。
如果你是卡在缺少学习资源的瓶颈上,那么刚刚好我能帮到你。以上知识笔记全部免费分享,如有需要获取知识笔记的朋友,可以点击我的GitHub免费领取。
9314)]
[外链图片转存中…(img-OsFyRUnJ-1710825119315)]
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频
如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注Android)
[外链图片转存中…(img-J6A171tz-1710825119315)]
最后
对于很多初中级Android工程师而言,想要提升技能,往往是自己摸索成长。而不成体系的学习效果低效漫长且无助。时间久了,付出巨大的时间成本和努力,没有看到应有的效果,会气馁是再正常不过的。
所以学习一定要找到最适合自己的方式,有一个思路方法,不然不止浪费时间,更可能把未来发展都一起耽误了。
如果你是卡在缺少学习资源的瓶颈上,那么刚刚好我能帮到你。以上知识笔记全部免费分享,如有需要获取知识笔记的朋友,可以点击我的GitHub免费领取。