Butter Knife 8

  1. // 部分代码省略…
  1. @Override
  1. public View getView(int position, View view, ViewGroup parent) {
  1. ViewHolder holder;
  1. if (view != null) {
  1. holder = (ViewHolder) view.getTag();
  1. } else {
  1. view = inflater.inflate(R.layout.testlayout, parent, false);
  1. holder = new ViewHolder(view);
  1. view.setTag(holder);
  1. }
  1. holder.name.setText(”诺诺”);
  1. // etc…
  1. return view;
  1. }
  1. static class ViewHolder {
  1. @BindView(R.id.title) TextView name;
  1. @BindView(R.id.job_title) TextView jobTitle;
  1. public ViewHolder(View view) {
  1. ButterKnife.bind(this, view);
  1. }
  1. }
  1. }

public class MyAdapter extends BaseAdapter {

// 部分代码省略...

@Override

public View getView(int position, View view, ViewGroup parent) {

ViewHolder holder;
if (view != null) {
  holder = (ViewHolder) view.getTag();
} else {
  view = inflater.inflate(R.layout.testlayout, parent, false);
  holder = new ViewHolder(view);
  view.setTag(holder);
}
holder.name.setText("诺诺");
// etc...
return view;

}

static class ViewHolder {

@BindView(R.id.title) TextView name;
@BindView(R.id.job_title) TextView jobTitle;
public ViewHolder(View view) {
  ButterKnife.bind(this, view);
}

}

}

六.Butter Knife的使用


1.快速生成注解view和onclick代码

操作流程如图:(AS上操作)

首先将鼠标放置在初始化view布局文件的位置上,然后按快捷键Shift+Alt+S –> Alt+Insert –>Ctrl+Shif+F12,最后选择生成view和点击事件。

第一步:

第二步:

第三步:(注:上面的选项,自己勾选试试自动生成的代码效果就明白了。非常简单。)

2.使用注意事项

1)ButterKinfe的注解标签因版本不同而有所变化。8.0.0之前的Bind标签在8.0.0之后变成了BindView,

而8.7.0之后在绑定view时,要用R2.id.XXX,而不再是常用的R.id.XXX。

Note:我在实际使用时用R.id.XXX和R2.id.XXX都可以,目前本人并未发现有什么异常。自动生成代码时是R.id.XXX;建议使用R2.id.XXX。因为网上都说使用R2是因为library中的R字段的id值不是final类型的,但是你的应用module中确是final类型的……

2)默认情况下,@bind和 listener 的绑定是必需的。如果无法找到目标视图,将抛出一个异常。

要抑制此行为并创建可选绑定,可以将@Nullable注解添加到字段中,或将@Optional注解添加到方法。

**Note:**任何被命名为@Nullable的注解都可以用于成员变量。鼓励使用Android的”support-annotations”库中的@Nullable注解。

eg:

[java] view plain copy

print ?

  1. @Nullable
  1. @BindView(R.id.might_not_be_there)
  1. TextView mightNotBeThere;
  1. @Optional
  1. @OnClick(R.id.maybe_missing)
  1. public void onMaybeMissingClicked() {
  1. // TODO …
  1. }
@Nullable
@BindView(R.id.might_not_be_there) 
TextView mightNotBeThere;
@Optional
@OnClick(R.id.maybe_missing) 
public void onMaybeMissingClicked() {
    // TODO ...
}

3.绑定注解

(注:此处作个统计,后面会有详细解释)

@BindView—->绑定一个view;id为一个view 变量

@BindViews  —-> 绑定多个view;id为一个view的list变量

@BindArray—-> 绑定string里面array数组;@BindArray(R.array.city ) String[] citys ;

@BindBitmap—->绑定图片资源为Bitmap;@BindBitmap( R.mipmap.wifi ) Bitmap bitmap;

@BindBool —->绑定boolean值

@BindColor —->绑定color;@BindColor(R.color.colorAccent) int black;

@BindDimen —->绑定Dimen;@BindDimen(R.dimen.borth_width) int mBorderWidth;

@BindDrawable —-> 绑定Drawable;@BindDrawable(R.drawable.test_pic) Drawable mTestPic;

@BindFloat —->绑定float

@BindInt —->绑定int

@BindString —->绑定一个String id为一个String变量;@BindString( R.string.app_name ) String meg;

4.事件注解

(注:此处作个统计,后面会有详细解释)

@OnClick—->点击事件

@OnCheckedChanged —->选中,取消选中

@OnEditorAction —->软键盘的功能键

@OnFocusChange —->焦点改变

@OnItemClick item—->被点击(注意这里有坑,如果item里面有Button等这些有点击的控件事件的,需要设置这些控件属性focusable为false)

@OnItemLongClick item—->长按(返回真可以拦截onItemClick)

@OnItemSelected —->item被选择事件

@OnLongClick —->长按事件

@OnPageChange —->页面改变事件

@OnTextChanged —->EditText里面的文本变化事件

@OnTouch —->触摸事件

@Optional —->

选择性注入,如果当前对象不存在,就会抛出一个异常,为了压制这个异常,可以在变量或者方法上加入一下注解,让注入变成选择性的,如果目标View存在,则注入, 不存在,则什么事情都不做=如下代码

eg:

[java] view plain copy

print ?

  1. @Optional
  1. @OnCheckedChanged(R.id.cb_test)
  1. public void onCheckedChanged(CompoundButton buttonView,boolean isChecked){
  1. if(isChecked){
  1. tvTest.setText(”被选中…”);
  1. }else{
  1. tvTest.setText(”被取消…”);
  1. }
  1. }

@Optional

@OnCheckedChanged(R.id.cb_test)

public void onCheckedChanged(CompoundButton buttonView,boolean isChecked){

if(isChecked){
    tvTest.setText("被选中...");
}else{
    tvTest.setText("被取消...");
}

}

5.绑定view

1)@BindView() : 布局id 注解

eg:

[java] view plain copy

print ?

  1. @BindView( R2.id.button)
  1. public Button button;

@BindView( R2.id.button)

public Button button;

Note:

button 的修饰类型不能是:private 或者 static 。 否则会报错:错误: @BindView fields must not be private or static. (com.ButterknifeActivity.button)

2)@BindViews(): 布局内多个控件 id 注解

eg:

[java] view plain copy

print ?

  1. public class MainActivity extends AppCompatActivity {
  1. @BindViews({ R2.id.button1, R2.id.button2,  R2.id.button3})
  1. public List buttonList ;
  1. @Override
  1. protected void onCreate(Bundle savedInstanceState) {
  1. super.onCreate(savedInstanceState);
  1. setContentView(R.layout.activity_main);
  1. ButterKnife.bind(this);
  1. buttonList.get( 0 ).setText( “hello 1 ”);
  1. buttonList.get( 1 ).setText( “hello 2 ”);
  1. buttonList.get( 2 ).setText( “hello 3 ”);
  1. }
  1. }

public class MainActivity extends AppCompatActivity {

@BindViews({ R2.id.button1, R2.id.button2,  R2.id.button3})
public List<Button> buttonList ;
@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    ButterKnife.bind(this);
    buttonList.get( 0 ).setText( "hello 1 ");
    buttonList.get( 1 ).setText( "hello 2 ");
    buttonList.get( 2 ).setText( "hello 3 ");
}

}

6.绑定资源

(注:只举例常用的几个,使用方式的都是类似的,有不会用的可以给我评论留言。)

1)@BindString() :绑定string 字符串

eg:

[java] view plain copy

print ?

  1. public class ButterknifeActivity extends AppCompatActivity {
  1. @BindView(R2.id.button) //绑定button 控件
  1. public Button button ;
  1. @BindString(R2.string.app_name)  //绑定资源文件中string字符串
  1. String str;
  1. @Override
  1. protected void onCreate(Bundle savedInstanceState) {
  1. super.onCreate(savedInstanceState);
  1. setContentView(R.layout.activity_butterknife);
  1. //绑定activity
  1. ButterKnife.bind( this ) ;
  1. button.setText( str );
  1. }
  1. }

public class ButterknifeActivity extends AppCompatActivity {

@BindView(R2.id.button) //绑定button 控件
public Button button ;
@BindString(R2.string.app_name)  //绑定资源文件中string字符串
String str;
@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_butterknife);
    //绑定activity
    ButterKnife.bind( this ) ;
    button.setText( str );
}

}

2)@BindArray() : 绑定string里面array数组

eg:

// 资源文件R.array.city

[html] view plain copy

print ?

  1. <resources>
  1. <string name=“app_name”>城市</string>
  1. <string-array name=“city”>
  1. <item>北京市</item>
  1. <item>天津市</item>
  1. <item>哈尔滨市</item>
  1. <item>大连市</item>
  1. <item>香港市</item>
  1. </string-array>
  1. </resources>
<string name="app_name">城市</string>
<string-array name="city">
    <item>北京市</item>
    <item>天津市</item>
    <item>哈尔滨市</item>
    <item>大连市</item>
    <item>香港市</item>
</string-array>

//示例

[java] view plain copy

print ?

  1. public class ButterknifeActivity extends AppCompatActivity {
  1. @BindView(R2.id.button) //绑定button 控件
  1. public Button button ;
  1. @BindString(R2.string.app_name)  //绑定资源文件中string字符串
  1. String str;
  1. @BindArray(R2.array.city)  //绑定string里面array数组
  1. String [] citys ;
  1. @Override
  1. protected void onCreate(Bundle savedInstanceState) {
  1. super.onCreate(savedInstanceState);
  1. setContentView(R.layout.activity_butterknife);
  1. //绑定activity
  1. ButterKnife.bind( this ) ;
  1. button.setText(citys[0]);
  1. }
  1. }

public class ButterknifeActivity extends AppCompatActivity {

@BindView(R2.id.button) //绑定button 控件
public Button button ;
@BindString(R2.string.app_name)  //绑定资源文件中string字符串
String str;
@BindArray(R2.array.city)  //绑定string里面array数组
String [] citys ;
@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_butterknife);
    //绑定activity
    ButterKnife.bind( this ) ;
    button.setText(citys[0]);
}

}

3)@BindBitmap( ) : 绑定Bitmap 资源

eg:

[java] view plain copy

print ?

  1. public class ButterknifeActivity extends AppCompatActivity {
  1. @BindView( R2.id.imageView ) //绑定ImageView 控件
  1. public ImageView imageView ;
  1. @BindBitmap(R2.drawable.bm)//绑定Bitmap 资源
  1. public Bitmap bitmap ;
  1. @Override
  1. protected void onCreate(Bundle savedInstanceState) {
  1. super.onCreate(savedInstanceState);
  1. setContentView(R.layout.activity_butterknife);
  1. //绑定activity
  1. ButterKnife.bind( this ) ;
  1. imageView.setImageBitmap(bitmap);
  1. }
  1. }

public class ButterknifeActivity extends AppCompatActivity {

@BindView( R2.id.imageView ) //绑定ImageView 控件
public ImageView imageView ;
@BindBitmap(R2.drawable.bm)//绑定Bitmap 资源
public Bitmap bitmap ;
@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_butterknife);
    //绑定activity
    ButterKnife.bind( this ) ;
    imageView.setImageBitmap(bitmap);
}

}

**Note:**这里的图片资源引用存在一个小问题:drawable文件夹下的图片使用R或R2引用都没问题;但是mipmap文件夹下的图片资源引用目前只能使用R。

4)@BindColor( ) : 绑定一个颜色值

eg:

[java] view plain copy

print ?

  1. public class ButterknifeActivity extends AppCompatActivity {
  1. @BindView( R2.id.button)  //绑定一个控件
  1. public Button button;
  1. @BindColor( R2.color.colorAccent ) //具体色值在color文件中
  1. int black ;  //绑定一个颜色值
  1. @Override
  1. protected void onCreate(Bundle savedInstanceState) {
  1. super.onCreate(savedInstanceState);
  1. setContentView(R.layout.activity_butterknife);
  1. //绑定activity
  1. ButterKnife.bind( this ) ;
  1. button.setTextColor(  black );
  1. }
  1. }

public class ButterknifeActivity extends AppCompatActivity {

@BindView( R2.id.button)  //绑定一个控件
public Button button;
@BindColor( R2.color.colorAccent ) //具体色值在color文件中
int black ;  //绑定一个颜色值
@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_butterknife);
    //绑定activity
    ButterKnife.bind( this ) ;
    button.setTextColor(  black );
}

}

7.点击事件绑定

(注:只举例常用的几个,使用方式的都是类似的,有不会用的可以给我评论留言。)

Note:不用声明view,不用setOnClickLisener()就可以绑定点击事件

1)绑定事件

@OnClick( ) : 绑定控件点击事件

@OnLongClick( ) : 绑定控件长按事件

eg:

[java] view plain copy

print ?

  1. public class ButterknifeActivity extends AppCompatActivity {
  1. @OnClick(R2.id.button1 )   //给 button1 设置一个点击事件
  1. public void showToast(){
  1. Toast.makeText(this, “is a click”, Toast.LENGTH_SHORT).show();
  1. }
  1. @OnLongClick( R2.id.button1 )    //给 button1 设置一个长按事件
  1. public boolean showToast2(){
  1. Toast.makeText(this, “is a long click”, Toast.LENGTH_SHORT).show();
  1. return true ;
  1. }
  1. @Override
  1. protected void onCreate(Bundle savedInstanceState) {
  1. super.onCreate(savedInstanceState);
  1. setContentView(R.layout.activity_butterknife);
  1. //绑定activity
  1. ButterKnife.bind( this ) ;
  1. }
  1. }

public class ButterknifeActivity extends AppCompatActivity {

@OnClick(R2.id.button1 )   //给 button1 设置一个点击事件
public void showToast(){
    Toast.makeText(this, "is a click", Toast.LENGTH_SHORT).show();
}
@OnLongClick( R2.id.button1 )    //给 button1 设置一个长按事件
public boolean showToast2(){
    Toast.makeText(this, "is a long click", Toast.LENGTH_SHORT).show();
    return true ;
}
@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_butterknife);
    //绑定activity
    ButterKnife.bind( this ) ;
}

}

2)指定多个id绑定事件

eg:

[java] view plain copy

print ?

  1. public class ButterknifeActivity extends AppCompatActivity {
  1. //提示:这是可以自动生成的,大家不要什么都手动敲哦
  1. @OnClick({R.id.ll_product_name, R.id.ll_product_lilv, R.id.ll_product_qixian, R.id.ll_product_repayment_methods})
  1. public void onViewClicked(View view) {
  1. switch (view.getId()) {
  1. case R.id.ll_product_name:
  1. System.out.print(”我是点击事件1”);
  1. break;
  1. case R.id.ll_product_lilv:
  1. System.out.print(”我是点击事件2”);
  1. break;
  1. case R.id.ll_product_qixian:
  1. System.out.print(”我是点击事件3”);
  1. break;
  1. case R.id.ll_product_repayment_methods:
  1. System.out.print(”我是点击事件4”);
  1. break;
  1. }
  1. }
  1. @Override
  1. protected void onCreate(Bundle savedInstanceState) {
  1. super.onCreate(savedInstanceState);
  1. setContentView(R.layout.activity_butterknife);
  1. //绑定activity
  1. ButterKnife.bind( this ) ;
  1. }
  1. }

public class ButterknifeActivity extends AppCompatActivity {

//提示:这是可以自动生成的,大家不要什么都手动敲哦
@OnClick({R.id.ll_product_name, R.id.ll_product_lilv, R.id.ll_product_qixian, R.id.ll_product_repayment_methods})
public void onViewClicked(View view) {
    switch (view.getId()) {
        case R.id.ll_product_name:
            System.out.print("我是点击事件1");
            break;
        case R.id.ll_product_lilv:
            System.out.print("我是点击事件2");
            break;
        case R.id.ll_product_qixian:
            System.out.print("我是点击事件3");
            break;
        case R.id.ll_product_repayment_methods:
            System.out.print("我是点击事件4");
            break;
    }
}
@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_butterknife);
    //绑定activity
    ButterKnife.bind( this ) ;
}

}

Note:下面是错误的写法,多条点击事件不可以用R2的方式:

eg:

[java] view plain copy

print ?

  1. public class ButterknifeActivity extends AppCompatActivity {
  1. @OnClick({R2.id.ll_product_name, R2.id.ll_product_lilv, R2.id.ll_product_qixian, R2.id.ll_product_repayment_methods})
  1. public void onViewClicked(View view) {
  1. switch (view.getId()) {
  1. case R2.id.ll_product_name:
  1. System.out.print(”我是点击事件1”);
  1. break;
  1. case R2.id.ll_product_lilv:
  1. System.out.print(”我是点击事件2”);
  1. break;
  1. case R2.id.ll_product_qixian:
  1. System.out.print(”我是点击事件3”);
  1. break;
  1. case R2.id.ll_product_repayment_methods:
  1. System.out.print(”我是点击事件4”);
  1. break;
  1. }
  1. }
  1. @Override
  1. protected void onCreate(Bundle savedInstanceState) {
  1. super.onCreate(savedInstanceState);
  1. setContentView(R.layout.activity_butterknife);
  1. //绑定activity
  1. ButterKnife.bind( this ) ;
  1. }
  1. }

public class ButterknifeActivity extends AppCompatActivity {

@OnClick({R2.id.ll_product_name, R2.id.ll_product_lilv, R2.id.ll_product_qixian, R2.id.ll_product_repayment_methods})  
public void onViewClicked(View view) {  
    switch (view.getId()) {  
        case R2.id.ll_product_name:  
            System.out.print("我是点击事件1");  
            break;  
        case R2.id.ll_product_lilv:  
            System.out.print("我是点击事件2");  
            break;  
        case R2.id.ll_product_qixian:  
            System.out.print("我是点击事件3");  
            break;  
        case R2.id.ll_product_repayment_methods:  
            System.out.print("我是点击事件4");  
            break;  
    }  
}  
@Override  
protected void onCreate(Bundle savedInstanceState) {  
    super.onCreate(savedInstanceState);  
    setContentView(R.layout.activity_butterknife);  
    //绑定activity  
    ButterKnife.bind( this ) ;  
}  

}

如果一定要使用R2的写法,可以单一逐次写,下面写法是正确的

eg:

[java] view plain copy

print ?

  1. public class ButterknifeActivity extends AppCompatActivity {
  1. @OnClick(R2.id.ll_product_name)
  1. public void onViewClicked1(View view) {
  1. System.out.print(”我是点击事件1”);
  1. }
  1. @OnClick(R2.id.ll_product_lilv)
  1. public void onViewClicked2(View view) {
  1. System.out.print(”我是点击事件2”);
  1. }
  1. @OnClick(R2.id.ll_product_qixian)
  1. public void onViewClicked3(View view) {
  1. System.out.print(”我是点击事件3”);
  1. }
  1. @OnClick(R2.id.ll_product_repayment_methods)
  1. public void onViewClicked4(View view) {
  1. System.out.print(”我是点击事件4”);
  1. }
  1. @Override
  1. protected void onCreate(Bundle savedInstanceState) {
  1. super.onCreate(savedInstanceState);
  1. setContentView(R.layout.activity_butterknife);
  1. //绑定activity
  1. ButterKnife.bind( this ) ;
  1. }
  1. }

public class ButterknifeActivity extends AppCompatActivity {

@OnClick(R2.id.ll_product_name)  
public void onViewClicked1(View view) {  
   System.out.print("我是点击事件1");             
}  
@OnClick(R2.id.ll_product_lilv)  
public void onViewClicked2(View view) {  
   System.out.print("我是点击事件2");   
} 
@OnClick(R2.id.ll_product_qixian)  
public void onViewClicked3(View view) {  
   System.out.print("我是点击事件3");             
}  
@OnClick(R2.id.ll_product_repayment_methods)  
public void onViewClicked4(View view) {  
   System.out.print("我是点击事件4");             
}  
@Override  
protected void onCreate(Bundle savedInstanceState) {  
    super.onCreate(savedInstanceState);  
    setContentView(R.layout.activity_butterknife);  
    //绑定activity  
    ButterKnife.bind( this ) ;  
}  

}

3)自定义View使用注解事件

Note:不用指定id,直接注解OnClick

eg:

[java] view plain copy

print ?

  1. public class MyButton extends Button {
  1. @OnClick
  1. public void onClick() {}
  1. }

public class MyButton extends Button {

@OnClick

public void onClick() {}

}

8.绑定监听

(**注:**本来不打算详细贴这段代码的,英文说明文档中就有,想想为了便于新生理解,还是贴出来吧。前后对比学习,很快就容易理解了。)

1)Listeners可以自动配置到方法中。

eg:

[java] view plain copy

print ?

  1. @OnClick(R.id.submit)
  1. public void submit(View view) {
  1. // TODO submit data to server…
  1. }

@OnClick(R.id.submit)

public void submit(View view) {

// TODO submit data to server…

}

2)对监听器方法的所有参数都是可选的。

eg:

[java] view plain copy

print ?

  1. @OnClick(R.id.submit)
  1. public void submit() {
  1. // TODO submit data to server…
  1. }

@OnClick(R.id.submit)

public void submit() {

// TODO submit data to server…

}

3)定义一个特定类型,它将自动被转换。

eg:

[java] view plain copy

print ?

  1. @OnClick(R.id.submit)
  1. public void sayHi(Button button) {//看参数这里的变化就明白了
  1. button.setText(”Hello!”);
  1. }

@OnClick(R.id.submit)

public void sayHi(Button button) {//看参数这里的变化就明白了
  button.setText("Hello!");
}
4)在单个绑定中指定多个id,用于公共事件处理。

(注:其实这里讲的就是上面的指定多个id绑定点击事件处理,不只是点击事件,其他事件监听也是可以的。很容易理解,不贴代码了。)

5)自定义视图可以通过不指定ID来绑定到它们自己的监听器。

eg:

[java] view plain copy

print ?

  1. public class FancyButton extends Button {
  1. @OnClick
  1. public void onClick() {
  1. // TODO do something!
  1. }
  1. }

public class FancyButton extends Button {

@OnClick

public void onClick() {

// TODO do something!

}

}

6) Listener中多方法注解

方法注解,其对应的监听器有多个回调,可用于绑定到其中任何一个。每个注解都有一个它绑定的默认回调。使用回调参数指定一个替换。

eg:以Spinner为例

原始方式:

[java] view plain copy

print ?

  1. Spinner s=new Spinner(this);
  1. //原始方法:Spinner 条目选择监听事件 正常写法
  1. s.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener(){
  1. @Override
  1. public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {
  1. }
  1. @Override
  1. public void onNothingSelected(AdapterView<?> parent) {
  1. }
  1. });

Spinner s=new Spinner(this);

    //原始方法:Spinner 条目选择监听事件 正常写法
    s.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener(){
        @Override
        public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {
        }
        @Override
        public void onNothingSelected(AdapterView<?> parent) {
        }
    });

Butter Knife 注解方式:

[java] view plain copy

print ?

  1. public class ButterknifeActivity extends AppCompatActivity {
  1. /*利用注解对Spinner item  作选择监听事件处理方式*/
  1. @OnItemSelected(R.id.my_spiner)//默认callback为ITEM_SELECTED
  1. void onItemSelected(int position) {
  1. Toast.makeText(this, “position: ” + position, Toast.LENGTH_SHORT).show();
  1. }
  1. /*
  1. * 注解onNothingSelected,需要在注解参数添加一个callback,
  1. * 注意的是Spinner中只要有数据,默认都会选中第0个数据,所以想进入到onNothingSelected()方法,就需要把Adapter中的数据都清空
  1. */
  1. @OnItemSelected(value = R.id.my_spiner, callback = OnItemSelected.Callback.NOTHING_SELECTED)
  1. void onNothingSelected() {
  1. Toast.makeText(this, “Nothing”, Toast.LENGTH_SHORT).show();
  1. }
  1. @Override
  1. protected void onCreate(Bundle savedInstanceState) {
  1. super.onCreate(savedInstanceState);
  1. setContentView(R.layout.activity_butterknife);
  1. //绑定activity
  1. ButterKnife.bind( this ) ;
  1. Spinner s=new Spinner(this);
  1. }
  1. }

public class ButterknifeActivity extends AppCompatActivity {

/*利用注解对Spinner item  作选择监听事件处理方式*/
@OnItemSelected(R.id.my_spiner)//默认callback为ITEM_SELECTED
void onItemSelected(int position) {
    Toast.makeText(this, "position: " + position, Toast.LENGTH_SHORT).show();
}
/*
* 注解onNothingSelected,需要在注解参数添加一个callback,
* 注意的是Spinner中只要有数据,默认都会选中第0个数据,所以想进入到onNothingSelected()方法,就需要把Adapter中的数据都清空
*/
@OnItemSelected(value = R.id.my_spiner, callback = OnItemSelected.Callback.NOTHING_SELECTED)
void onNothingSelected() {
    Toast.makeText(this, "Nothing", Toast.LENGTH_SHORT).show();
}
@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_butterknife);
    //绑定activity
    ButterKnife.bind( this ) ;
    Spinner s=new Spinner(this);
}

}

7) @OnCheckedChanged监听的使用

原方法应是:setOnCheckedChangeListener()

在使用注解@OnCheckedChanged的时候,出现了CompoundButton这个参数,因为理解有误,传参有误,还出现了无法转换成CompoundButton的bug。正常使用该注解时,格式如下:

[java] view plain copy

print ?

  1. @OnCheckedChanged({R.id.XXX})
  1. public void OnCheckedChangeListener(CompoundButton view, boolean ischanged ){
  1. }

@OnCheckedChanged({R.id.XXX})

public void OnCheckedChangeListener(CompoundButton view, boolean ischanged ){

}

参数是CompoundButton是变化的按钮控件事件id,ischanged是指该控件是否被点击改变。

具体使用请看示例:

eg:

xml文件:

(注:这里只是举例,方便大家理解,其他相关按钮控件也是通用的。不要纠结具体布局,有看不明白的地方可以给我留言。)

[java] view plain copy

print ?

  1. <?xml version=“1.0” encoding=“utf-8”?>  
  1. <LinearLayout xmlns:android=”http://schemas.android.com/apk/res/android”
  1. android:layout_width=”match_parent”
  1. android:layout_height=”match_parent”
  1. android:orientation=”vertical”>
  1. <RadioGroup
  1. android:id=”@+id/rg_main”
  1. android:layout_width=”fill_parent”
  1. android:layout_height=”48dp”
  1. android:layout_alignParentBottom=”true”
  1. android:background=”@color/white”
  1. android:orientation=”horizontal”>
  1. <RadioButton
  1. android:id=”@+id/rg_home”
  1. android:layout_width=”match_parent”
  1. android:layout_height=”match_parent”
  1. android:focusable=”false”
  1. android:text=”@string/nav_one” />
  1. <RadioButton
  1. android:id=”@+id/rg_wealth”
  1. android:layout_width=”match_parent”
  1. android:layout_height=”match_parent”
  1. android:focusable=”false”
  1. android:text=”@string/nav_two” />
  1. <RadioButton
  1. android:id=”@+id/rg_account”
  1. android:layout_width=”match_parent”
  1. android:layout_height=”match_parent”
  1. android:focusable=”false”
  1. android:text=”@string/nav_four” />
  1.   
<?xml version="1.0" encoding="utf-8"?>

<LinearLayout xmlns:android=“http://schemas.android.com/apk/res/android”

android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<RadioGroup
    android:id="@+id/rg_main"
    android:layout_width="fill_parent"
    android:layout_height="48dp"
    android:layout_alignParentBottom="true"
    android:background="@color/white"
    android:orientation="horizontal">
    <RadioButton
        android:id="@+id/rg_home"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:focusable="false"
        android:text="@string/nav_one" />
    <RadioButton
        android:id="@+id/rg_wealth"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:focusable="false"
        android:text="@string/nav_two" />
    <RadioButton
        android:id="@+id/rg_account"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:focusable="false"
        android:text="@string/nav_four" />
</RadioGroup>

类文件中的监听写法:

[java] view plain copy

print ?

  1. @OnCheckedChanged({R.id.rg_home,R.id.rg_wealth,R.id.rg_account})
  1. public void OnCheckedChangeListener(CompoundButton view, boolean ischanged ){
  1. switch (view.getId()) {
  1. case R.id.rg_home:
  1. if (ischanged){//注意:这里一定要有这个判断,只有按钮被点击了,ischanged状态发生改变,才会执行下面的内容
  1. //这里写你的按钮变化状态的UI及相关逻辑
  1. }
  1. break;
  1. case R.id.rg_wealth:
  1. if (ischanged) {
  1. //这里写你的按钮变化状态的UI及相关逻辑
  1. }
  1. break;
  1. case R.id.rg_account:
  1. if (ischanged) {
  1. //这里写你的按钮变化状态的UI及相关逻辑
  1. }
  1. break;
  1. default:
  1. break;
  1. }
  1. }

@OnCheckedChanged({R.id.rg_home,R.id.rg_wealth,R.id.rg_account})

public void OnCheckedChangeListener(CompoundButton view, boolean ischanged ){
    switch (view.getId()) {
        case R.id.rg_home:
            if (ischanged){//注意:这里一定要有这个判断,只有按钮被点击了,ischanged状态发生改变,才会执行下面的内容
                //这里写你的按钮变化状态的UI及相关逻辑
            }
            break;
        case R.id.rg_wealth:
            if (ischanged) {
                //这里写你的按钮变化状态的UI及相关逻辑
            }
            break;
        case R.id.rg_account:
            if (ischanged) {
                //这里写你的按钮变化状态的UI及相关逻辑
            }
            break;
        default:
            break;
    }
}

9.使用findById

Butter Knife仍然包含了findById()方法,用于仍需从一个view ,Activity,或者Dialog上初始化view的时候,并且它可以自动转换类型。

eg:

[java] view plain copy

print ?

  1. View view = LayoutInflater.from(context).inflate(R.layout.thing, null);
  1. TextView firstName = ButterKnife.findById(view, R.id.first_name);
  1. TextView lastName = ButterKnife.findById(view, R.id.last_name);
  1. ImageView iv = ButterKnife.findById(view, R.id.iv);

View view = LayoutInflater.from(context).inflate(R.layout.thing, null);

TextView firstName = ButterKnife.findById(view, R.id.first_name);

TextView lastName = ButterKnife.findById(view, R.id.last_name);

ImageView iv = ButterKnife.findById(view, R.id.iv);

10.设置多个view的属性

apply()

作用:允许您立即对列表中的所有视图进行操作。

Action和Setter接口

作用:Action和Setter接口允许指定简单的行为。

eg:

[java] view plain copy

print ?

  1. public class ButterknifeActivity extends AppCompatActivity {
  1. @BindViews({R2.id.first_name, R2.id.middle_name, R2.id.last_name})
  1. List nameViews;
  1. @Override
  1. protected void onCreate(Bundle savedInstanceState) {
  1. super.onCreate(savedInstanceState);
  1. setContentView(R.layout.activity_butterknife);
  1. //绑定activity
  1. ButterKnife.bind(this);
  1. //看不懂的小伙伴,多敲几遍代码,实际操作一下自然就懂了。相信我!如果你重复敲了10遍以上的代码,并认真思考了还没懂,欢迎给我评论留言。
  1. //设置多个view的属性
  1. //方式1:传递值
  1. ButterKnife.apply(nameViews, DISABLE);
  1. //方式2:指定值
  1. ButterKnife.apply(nameViews, ENABLED, false);
  1. 方式3 设置View的Property
  1. ButterKnife.apply(nameViews, View.ALPHA, 0.0f);//一个Android属性也可以用于应用的方法。
  1. }
  1. /*
  1. * Action接口设置属性
  1. */
  1. static final ButterKnife.Action DISABLE = new ButterKnife.Action() {
  1. @Override
  1. public void apply(View view, int index) {
  1. view.setEnabled(false);//目的是使多个view都具备此属性
  1. }
  1. };
  1. /*
  1. * Setter接口设置属性
  1. */
  1. static final ButterKnife.Setter<View, Boolean> ENABLED = new ButterKnife.Setter<View, Boolean>() {
  1. @Override
  1. public void set(View view, Boolean value, int index) {
  1. view.setEnabled(value);//目的是使多个view都具备此属性,可变boolean值是可以传递的
  1. }
  1. };
  1. }

public class ButterknifeActivity extends AppCompatActivity {

@BindViews({R2.id.first_name, R2.id.middle_name, R2.id.last_name})

最后

小编这些年深知大多数初中级Android工程师,想要提升自己,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助

因此我收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人

都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

资料⬅专栏获取
/80007661)10.设置多个view的属性

apply()

作用:允许您立即对列表中的所有视图进行操作。

Action和Setter接口

作用:Action和Setter接口允许指定简单的行为。

eg:

[java] view plain copy

print ?

  1. public class ButterknifeActivity extends AppCompatActivity {
  1. @BindViews({R2.id.first_name, R2.id.middle_name, R2.id.last_name})
  1. List nameViews;
  1. @Override
  1. protected void onCreate(Bundle savedInstanceState) {
  1. super.onCreate(savedInstanceState);
  1. setContentView(R.layout.activity_butterknife);
  1. //绑定activity
  1. ButterKnife.bind(this);
  1. //看不懂的小伙伴,多敲几遍代码,实际操作一下自然就懂了。相信我!如果你重复敲了10遍以上的代码,并认真思考了还没懂,欢迎给我评论留言。
  1. //设置多个view的属性
  1. //方式1:传递值
  1. ButterKnife.apply(nameViews, DISABLE);
  1. //方式2:指定值
  1. ButterKnife.apply(nameViews, ENABLED, false);
  1. 方式3 设置View的Property
  1. ButterKnife.apply(nameViews, View.ALPHA, 0.0f);//一个Android属性也可以用于应用的方法。
  1. }
  1. /*
  1. * Action接口设置属性
  1. */
  1. static final ButterKnife.Action DISABLE = new ButterKnife.Action() {
  1. @Override
  1. public void apply(View view, int index) {
  1. view.setEnabled(false);//目的是使多个view都具备此属性
  1. }
  1. };
  1. /*
  1. * Setter接口设置属性
  1. */
  1. static final ButterKnife.Setter<View, Boolean> ENABLED = new ButterKnife.Setter<View, Boolean>() {
  1. @Override
  1. public void set(View view, Boolean value, int index) {
  1. view.setEnabled(value);//目的是使多个view都具备此属性,可变boolean值是可以传递的
  1. }
  1. };
  1. }

public class ButterknifeActivity extends AppCompatActivity {

@BindViews({R2.id.first_name, R2.id.middle_name, R2.id.last_name})

最后

小编这些年深知大多数初中级Android工程师,想要提升自己,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助

因此我收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。

[外链图片转存中…(img-efHg69gN-1719050367990)]

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人

都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

资料⬅专栏获取

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/32106.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

电路仿真实战设计教程--平均电流控制原理与仿真实战教程

1.平均电流控制原理: 平均电流控制的方块图如下,其由外电路电压误差放大器作电压调整器产生电感电流命令信号,再利用电感电流与电流信号的误差经过一个电流误差放大器产生PWM所需的控制电压,最后由控制电压与三角波比较生成开关管的驱动信号。 2.电流环设计: 根据状态平…

外部存储器

外部存储器是主存的后援设备&#xff0c;也叫做辅助存储器&#xff0c;简称外存或辅存。 它的特点是容量大、速度慢、价格低&#xff0c;可以脱机保存信息&#xff0c;属于非易失性存储器。 外存主要有&#xff1a;光盘、磁带、磁盘&#xff1b;磁盘和磁带都属于磁表面存储器…

【Java毕业设计】基于JavaWeb的服务出租系统

本科毕业设计论文 题目&#xff1a;房屋交易平台设计与实现 系 别&#xff1a; XX系&#xff08;全称&#xff09; 专 业&#xff1a; 软件工程 班 级&#xff1a; 软件工程15201 学生姓名&#xff1a; 学生学号&#xff1a; 指导教师&#xff1a; 导师1 导师2 文章目录 摘…

从零对Transformer的理解(台大李宏毅)

Self-attention layer自注意力 对比与传统cnn和rnn&#xff0c;都是需要t-1时刻的状态然后得到t时刻的状态。我不知道这样理解对不对&#xff0c;反正从代码上看我是这么认为的。而transformer的子注意力机制是在同一时刻产生。意思就是输入一个时间序列&#xff0c;在计算完权…

PostgreSQL的学习心得和知识总结(一百四十五)|深入理解PostgreSQL数据库之ShowTransactionState的使用及父子事务有限状态机

目录结构 注&#xff1a;提前言明 本文借鉴了以下博主、书籍或网站的内容&#xff0c;其列表如下&#xff1a; 1、参考书籍&#xff1a;《PostgreSQL数据库内核分析》 2、参考书籍&#xff1a;《数据库事务处理的艺术&#xff1a;事务管理与并发控制》 3、PostgreSQL数据库仓库…

信息技术课如何禁止学生玩游戏

在信息技术课上禁止学生玩游戏是一个常见的挑战&#xff0c;但可以通过一系列策略和工具来有效地实现。以下是一些建议&#xff1a; 明确课堂规则和纪律&#xff1a; (1)在课程开始时&#xff0c;明确告知学生课堂规则和纪律&#xff0c;包括禁止玩游戏的规定。 (2)强调遵守…

[Qt] QtCreator编辑区关闭右侧不必要的警告提示

在代码编辑页面&#xff0c;右侧总会出现一些即时Waring&#xff0c;不想看见&#xff1f; 取消勾选插件管理中的ClangCodeModel 插件即可

Linux 内核权限提升漏洞CVE-2024-1086三种修复方法

作者介绍&#xff1a;老苏&#xff0c;10余年DBA工作运维经验&#xff0c;擅长Oracle、MySQL、PG数据库运维&#xff08;如安装迁移&#xff0c;性能优化、故障应急处理等&#xff09; 公众号&#xff1a;老苏畅谈运维 欢迎关注本人公众号&#xff0c;更多精彩与您分享。一、漏…

NLP大语言模型的缩放定律

一、简述 ​论文《神经语言模型的缩放定律》包含对交叉熵损失的语言模型性能的经验缩放定律的研究&#xff0c;重点关注Transformer架构。 https://arxiv.org/pdf/2001.08361.pdfhttps://arxiv.org/pdf/2001.08361.pdf 实验表明&#xff0c;测试损失与模型大小、数据集…

已解决VirtualMachineError: 虚拟机错误的正确解决方法,亲测有效!!!

已解决VirtualMachineError: 虚拟机错误的正确解决方法&#xff0c;亲测有效&#xff01;&#xff01;&#xff01; 目录 问题分析 报错原因 解决思路 解决方法 分析错误日志 优化代码 内存泄漏排查 优化递归调用 调整JVM参数 使用监控工具 增加物理内存或升级硬件…

优选免单模式:电商销售的新篇章

随着电商市场的日益繁荣&#xff0c;各种创新销售模式层出不穷。其中&#xff0c;优选免单模式以其独特的运作方式和激励机制&#xff0c;吸引了大量消费者的目光。该模式的核心在于通过降低商品售价、引入社交元素以及设计阶梯式奖励&#xff0c;激发消费者的购买热情&#xf…

【C++知识点】类和对象:友元,运算符重载,多态

今天来继续了解类和对象&#xff01; PS.本博客参考b站up黑马程序员的相关课程&#xff0c;老师讲得非常非常好&#xff01; 封装 深拷贝与浅拷贝 浅拷贝&#xff1a;简单的赋值拷贝操作 深拷贝&#xff1a;在堆区重新申请空间&#xff0c;进行拷贝操作 首先&#xff0c…

「动态规划」如何求最长湍流子数组的长度?

78. 最长湍流子数组https://leetcode.cn/problems/longest-turbulent-subarray/description/ 给定一个整数数组arr&#xff0c;返回arr的最长湍流子数组的长度。如果比较符号在子数组中的每个相邻元素对之间翻转&#xff0c;则该子数组是湍流子数组。更正式地来说&#xff0c;…

VBA技术资料MF164:列出文件夹中的所有文件和创建日期

我给VBA的定义&#xff1a;VBA是个人小型自动化处理的有效工具。利用好了&#xff0c;可以大大提高自己的工作效率&#xff0c;而且可以提高数据的准确度。“VBA语言専攻”提供的教程一共九套&#xff0c;分为初级、中级、高级三大部分&#xff0c;教程是对VBA的系统讲解&#…

JAVA大型医院绩效考核系统源码:​医院绩效考核实施的难点痛点

JAVA大型医院绩效考核系统源码&#xff1a;​医院绩效考核实施的难点痛点 绩效考核数字化综合管理系统是一个基于数字化技术的管理平台&#xff0c;用于帮助企业、机构等组织进行绩效考评的各个环节的管理和处理。它将绩效考评的各个环节集成到一个系统中&#xff0c;包括目标…

Appium Android 自动化测试 -- 元素定位

自动化测试元素定位是难点之一&#xff0c;编写脚本时会经常卡在元素定位这里&#xff0c;有时一个元素能捣鼓一天&#xff0c;到最后还是定位不到。 Appium 定位方式和 selenium 一脉相承&#xff0c;selenium 中的定位方式Appium 中都支持&#xff0c;而 Appium 还增加了自己…

ciscn_2019_n_1

前戏--------checksec,运行查看 进入就可以发现这段代码 很浅显易懂 我们要得到的后面是 这里 我们要利用的漏洞是 get函数 0x30大小 加上8 exp: from pwn import * ghust remote("node5.buuoj.cn",28777) addr 0x4006BE payload bA * 0x30 bB*0x8 p64(addr…

细说MCU输出两路PWM波形及改变占空比的实现方法

目录 一、硬件及工程 二、建立工程 三、代码修改 四、下载运行 五、改变PWM波形占空比 1、定义两个全局变量 2、启动定时器 3、重写TIM3中断回调函数 六、下载并运行 一、硬件及工程 文章依赖的硬件及工程配置参考本文作者的其他文章&#xff1a;细说ARM MCU的串口接…

3D开发工具HOOPS为BIM应用提供支持:复杂大模型实现Web端轻量化!

在数字化转型的浪潮中&#xff0c;Tech Soft 3D以其HOOPS SDK工具包&#xff0c;为软件开发人员提供了强大的支持。这一工具包不仅支持Windows、Linux、OSX和移动平台等多样化的操作系统&#xff0c;还使得开发人员能够构建出庞大而复杂的建筑和BIM应用程序。HOOPS SDK的多格式…

26.2 Django简介

1. Python三大主流框架 根据当前的信息和流行度, Python的三大框架可以归纳为Django, Flask和FastAPI, 以下是对它们的清晰分点表示和归纳:* 1. Django: 一个高级的Python Web框架, 以快速开发和实用简洁的设计出名.它遵循MVC设计模式(但更倾向于MTV模式), 并提供了许多内置的…