前言
butterknife相信大家并不陌生,它的引入使我们的项目初始化代码大大简化,非常不错,在主项目中的引用我在我的csdn中已经介绍过
butterknife的使用
今天主要讲讲butterknife在Library中引用时出现的问题
本篇文章参考以下链接
butterknife官网
ButtonKnife在library中引用“Attribute value must be constant”报错解决
在此表示感谢!
今天涉及到的知识点有
- butterknife版本使用注意事项
- butterknife在Library中引用步骤
- butterknife在Library中使用时涉及到点击事件的写法问题
一.butterknife版本使用注意事项
截至我写这篇文章的时候,butterknife版本已经更新到 8.8.1,本着用最新版本的原则,是不是我们该将butterknife的依赖版本提升至8.8.1呢?答案是不一定。由于我们项目一直用的是Java语言所写,而butterknife早在8.6.0版本已经全全一直到Kotlin上面去了,如果你代码是kotlin所写,那么更新最新版本倒也没什么,但如果你也是java写的项目,提升至最新版本的话只会报以下错误
所以我们只能用java版的比较高的版本,我用的是8.5.1,这是我们需要注意的。
二. butterknife在Library中引用步骤
假设你的项目中已经新建了一个你自己的Library,然后你的项目结构类似如下:
-------root
------app_module
---app的build.gradle
------library_module
---library的build.gradle
----project的build.gradle
2.1在你的project的build.gradle中做如下设置
- 在project的build.gradle中 buildscript--->repositories中添加如下代码:
mavenCentral()
- 在project的build.gradle中 buildscript--->dependencies中添加如下代码:
//避免butterKnife在library中使用出现id冲突
classpath 'com.jakewharton:butterknife-gradle-plugin:8.5.1'
即在project的build.gradle中需要处理的关于butterknife代码如下:
//在这里引入config.gradle
apply from:"config.gradle"
buildscript {
repositories {
google()
jcenter()
mavenCentral()
}
dependencies {
classpath 'com.android.tools.build:gradle:3.0.0'
//避免butterKnife在library中使用出现id冲突
classpath 'com.jakewharton:butterknife-gradle-plugin:8.5.1'
// NOTE: Do not place your application dependencies here; they belong
// in the individual module build.gradle files
}
}
allprojects {
//此处代码省略
//......
}
task clean(type: Delete) {
delete rootProject.buildDir
}
2.2在你的library的build.gradle中设置
在你的library的build.gradle的头部添加一行引入性代码:
apply plugin: 'com.jakewharton.butterknife'
然后在library的build.gradle添加butterknife依赖:
//butterKnife
compile librarys.compile_butterknife
annotationProcessor librarys.annotationProcessor_butterknife_compiler
整个引入代码类似下面这样:
apply plugin: 'com.android.library'
apply plugin: 'com.jakewharton.butterknife'
//android配置
def config = rootProject.ext.android
//相关库依赖
def librarys = rootProject.ext.supportDependencies
android {
//此处省略
//......
}
buildTypes {
release {
//此处省略
//......
}
}
}
dependencies {
implementation fileTree(dir: 'libs', include: ['*.jar'])
//==========基础库============
//此处省略
//......
//================第三方库============
//butterKnife
compile librarys.compile_butterknife
annotationProcessor librarys.annotationProcessor_butterknife_compiler
}
这里库的引用我是对build.gradle进行统一管理后引入的,所以引入库写法和一般依赖写法有差别,至于build.gradle统一管理知识之前讲过,这里就不做讲解了
三.butterknife在Library中使用时涉及到点击事件的写法问题
第一,二步写好之后,就是在类中进行使用了,下面以一个button为例做以说明
3.1 在library一个类中对应的xml中布下一个按钮:
//布局中button以上代码此处省略
//......
<Button
android:id="@+id/btn_confirm"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:padding="@dimen/dp_5"
android:textColor="#057bfe"
android:gravity="center"
android:textSize="14sp"/>
//布局中button以下代码此处省略
//......
3.2 在library一个类中对Button初始化
按在app module中的初始化方式应该为:
@BindView(R.id.btn_confirm)
Button mBtnConfirm;
但在library中则需要将此处的R替换成R2,则在library中Button初始化变成:
@BindView(R2.id.btn_confirm)
Button mBtnConfirm;
3.3 在library一个类中对Button设置点击事件
一般的在app module中的设置点击事件是这样的:
@Override
public void onClick(View v) {
super.onClick(v);
switch (v.getId()){
case R.id.btn_confirm:
//逻辑代码
//......
break;
default:
break;
}
}
但在Library中则有所不同,点击事件需要这样写:
@Override
public void onClick(View v) {
super.onClick(v);
if (v.getId() == R.id.btn_confirm) {
//点击确定事件处理
//......
} else if (v.getId() == R.id.btn_cancel) {
//点击取消事件处理
//......
}
}
这里需要注意的是,点击事件的分类不再用switch-case来表示,而要用 if-else方式,还有控件的id仍用控件原xml中写的id表示,不能用R2替换R来判断点击事件
即上面代码,若你用
if (v.getId() == R2.id.btn_confirm) {
//点击确定事件处理
//......
}
来表示确定点击事件是错误的,要用v.getId() == R.id.btn_confirm来明确表示具体的点击事件
ok,今天关于butterknife在Library中的具体引用需要注意的事项就介绍到这里了,谢谢诶。