public class MainActivity extends AppCompatActivity { private TextView tv;//定义组件 @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); tv = findViewById(R.id.tv);//获取组件 tv.setText("恭喜发财");//使用组件 } }
定义组件后使用 findViewById 进行组件获取后再使用定义的组件进行使用,几乎每个页面都要写这种获取组件的 findViewById,项目长久写下来还是需要一番流水线般的工作,为了减少这种代码的编写,后面GT库出了类似于 小刀(Butter Knife) 一样获取组件的方法。详情实现请点击下面链接。点击这里https://blog.csdn.net/qq_39799899/article/details/100150702https://blog.csdn.net/qq_39799899/article/details/100150702
第二版:使用GT_View 获取组件public class MainActivity extends AppCompatActivity { @GT.Annotations.GT_View(R.id.tv)//获取组件 private TextView tv;//定义组件 @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); GT.build(this);//绑定Activity tv.setText("恭喜发财");//使用组件 } }
这种就类似于小刀一样的获取组件,在定义组件、获取组件、使用组件上,多了一个 绑定Activity *** 作,将所有的获取组件方式都可以定义在 方法之外,且绑定的对象有:Activity、Fragment、DialogFragment、FloatingWindow(GT库独有-悬浮窗页面)、Adapter,等等,只要是页面为Activity或View 均可使用该绑定进行同意获取组件。
第二版:优化版@GT.Annotations.GT_AnnotationActivity(R.layout.activity_main)//加载布局 public class MainActivity extends GT.GT_Activity.AnnotationActivity { @GT.Annotations.GT_View(R.id.tv)//获取组件 private TextView tv;//定义组件 @Override protected void initView(Bundle savedInstanceState) { super.initView(savedInstanceState); tv.setText("恭喜发财");//使用组件 } }
如果是继承了GT 库里的 AnnotationActivity、AnnotationFragment、AnnotationDialogFragment、AnnotationFloatingWindow、AnnotationAdapter、那就均可以省去编写 绑定的方法,使用起来颇为方便。接下来博主就要介绍这新出的GT-DataBinding 获取组件的方法了。
第三版:使用GT-DataBinding 获取组件//指定布局并绑定数据类型为Activity @DataBinding(setLayout = "activity_main",setBindingType = DataBinding.Activity) public class MainActivity extends AppCompatActivity { private MainActivityBinding dataBinding;//定义绑定 dataBinding @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); dataBinding = GT.DataBindingUtil.setContentView(this);//组件数据绑定 //dataBinding = GT.DataBindingUtil.setContentView(this, view);//除Activity外其他的组件绑定 //使用组件 dataBinding.tv1.setText("你好1"); dataBinding.tv2.setText("你好2"); dataBinding.tv3.setText("你好3"); dataBinding.tv4.setText("你好4"); } }
绑定好组件数据后,直接使用绑定对象进行使用组件即可,在第三代获取组件之前如果页面组件有10—20个需要获取的组件,那么在页面代码上,一排长长的获取组件代码将会是一个非常不雅观的场面,在第三代获取组件上就只需要一次绑定组件,该页面所有写有ID的组件均会被初始化好,供你使用,省去了一大批流水线代码。接下来我们来看看第四版获取组件。
第四版:使用 ****(自定义类名)Binding 获取组件//指定绑定的布局,并设置绑定数据的类型 @DataBinding(setLayout = "activity_main", setBindingType = DataBinding.Activity) @GT.Annotations.GT_AnnotationActivity(R.layout.activity_main)//加载布局 public class MainActivity extends MainActivityBinding { @Override protected void initView(Bundle savedInstanceState) { super.initView(savedInstanceState); //直接使用组件 tv1.setText("恭喜发财1"); tv2.setText("恭喜发财2"); tv3.setText("恭喜发财3"); tv4.setText("恭喜发财4"); } }
看了这一番组件使用,没有接触过 Kotlin语言 的小伙伴是不是很疑惑,定义组件与获取组件都没看见就直接使用了,这样就彻底解放组件获取的代码了,不管你是5个组价获取还是100个组件获取都不用看到一排排头皮发麻的组件获取了。使用步骤也是非常简单:
第一步:指定绑定的布局,并设置绑定数据的类型
@DataBinding(setLayout = "当前布局文件名", setBindingType = 绑定数据的类型)
第二步:继承类名+Binding 的类,并注解加载布局
(注意:很多小伙伴在这里会发现类名+Binding的时候会爆红,那是因为你还没有编译,在编译的时候,继承类名+Binding 的类就会自动生成的)
@GT.Annotations.GT_AnnotationActivity(R.layout.activity_main)//加载布局 public class MainActivity extends MainActivityBinding {
后面就就可以直接使用你布局里所有写有 ID 号的组件了
接下来就来介绍如何使用第四版的组件获取: 第1步:依赖GT库使用前需要依赖库:
allprojects { repositories { ... maven { url 'https://jitpack.io' } } }
(注意:当前演示的版本号是1.3.5.1版本,今后会有新的版本发布,欢迎使用最新版)
dependencies { ... implementation 'com.github.1079374315:GSLS_Tool:v1.3.5.2' }
依赖详细教程:依赖GT库
第2步:下载gt-DataBinding.jar包并进行注册在GT官网上进行
第1下载网址:下载最新jar 包https://github.com/1079374315/GThttps://github.com/1079374315/GT
第2下载网址:
下载最新 jar 包http://gsls.3vfree.cn/GT/gt-DataBinding.jarhttp://gsls.3vfree.cn/GT/gt-DataBinding.jar
点击下载 jar 包
下载下来后进行复制粘贴到AndroidStudio项目中并进行注册(记住是注册,不是依赖)
然后再在 build.gradle(:app) 这里进行注册,如下:
可供复制粘贴:
annotationProcessor files('libs/gt-DataBinding.jar')//注册 gt-DataBinding
注意:当前演示的版本是v1.3.5.2,依赖GT库的版本请使用最新版。GT官网最新版https://github.com/1079374315/GThttps://github.com/1079374315/GT
然后再进行同步 Sync Now
就可以向之前获取组件第四版的教程进行使用了。
点个关注点个赞呗(〃'▽'〃),关注博主最新发布库:GitHub - 1079374315/GT
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)