android studio 中使用kotlin语言 直接操作布局id

android studio 中使用kotlin语言 直接操作布局id

需要在 build.gradle 文件 引入

java 复制代码
apply plugin: 'kotlin-android'
apply plugin: 'kotlin-android-extensions'

(会自动生成,可忽略)然后在 Activity 文件中 引入 对应的 layout 文件 如:activity_main.xml

import kotlinx.android.synthetic.main.activity_main.*

然而,运行是会提示kotlin-android-extensions废弃

java 复制代码
【Android Studio】The 'kotlin-android-extensions' Gradle plugin is deprecated.

所以我们采用viewbinding来直接操作布局id

一、ViewBinding开启

在app下build.grade中加入以下代码

AS 3.6.x

java 复制代码
android {
	...
     viewBinding{
        enabled = true
  	}
}

AS 4.0.x

java 复制代码
android {
	...
    buildFeatures{
        viewBinding= true
    }
}

开启之后,创建xml布局文件时,编译器会自动化生成对应的xxxBinding文件。例如:activity_main.xml 对应生成ActivityMainBinding,下面进行代码演示

一、Activity中使用ViewBinding

1、创建MainActivity、activity_main.xml文件

xml 复制代码
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout 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"
    android:orientation="vertical"
    tools:context=".MainActivity">

    <ImageView
        android:id="@+id/iv_test"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:background="@color/transparent" />


    <FrameLayout
        android:id="@+id/fl_contain"
        android:layout_width="match_parent"
        android:layout_height="match_parent" />

</RelativeLayout>

2、Java中把自动生成的ActivityMainBinding进行填充绑定后再 setContentView(rootView);

java 复制代码
        //关键代码:binding xml布局
        mBinding = ActivityMainBinding.inflate(getLayoutInflater());
        View rootView = mBinding.getRoot();
        setContentView(rootView);

3、绑定之后就可以直接通过mBinding.xxx(xxx==id)使用控件,完整代码如下:

java 复制代码
public class MainActivity extends AppCompatActivity {

    private ActivityMainBinding mBinding;

    @Override
    protected void onCreate(@Nullable Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        //关键代码:binding xml布局
        mBinding = ActivityMainBinding.inflate(getLayoutInflater());
        View rootView = mBinding.getRoot();
        setContentView(rootView);

        //使用介绍
        mBinding.ivTest.setBackground(ContextCompat.getDrawable(this, R.mipmap.ic_launcher));

        mBinding.flContain.setOnClickListener(v -> {
            FragmentManager fragmentManager = getSupportFragmentManager();
            FragmentTransaction transaction = fragmentManager.beginTransaction();
            transaction.add(R.id.fl_contain, new BindViewFragment());
            transaction.commit();
        });
    }
}

相关推荐
杉氧11 小时前
深入理解 Compose 重组机制:快照系统如何驱动 UI 精准刷新?
android·架构·android jetpack
召钱熏11 小时前
状态枚举正确≠渲染正确:一个语音按钮的状态机边界修复实录
android·前端
杉氧12 小时前
深度解析:Jetpack Compose 核心架构与底层原理 —— 十年安卓老兵的“破茧重生”
android·架构·android jetpack
通玄12 小时前
Jetpack Compose 入门系列(七):ViewModel 与界面状态管理
android
落魄Android在线炒饭12 小时前
Android Framework 开发技巧:android.jar 生成与系统快速编译验证
android
如此风景13 小时前
Kotlin Flow操作符学习
android·kotlin
plainGeekDev14 小时前
GreenDAO → Room
android·java·kotlin
weiggle14 小时前
第八篇:ViewModel + Compose——生产级状态管理实践
android
恋猫de小郭19 小时前
Amper 正式转正 Kotlin Toolchain ,Gradle 未来何去何从
android·前端·flutter
plainGeekDev20 小时前
ButterKnife → ViewBinding
android·java·kotlin