java项目添加`kotlin`支持

手动添加kotlin配置

在项目的bulid.gradle中添加以下代码

buildscript {
    ext.kotlin_version = '1.4.10'
     repositories {
        mavenCentral()
    ...
    }
    ...
    dependencies {
        ...
        //对kotlin支持
        classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
        ...
    }
}

在你需要支持kotlinmodule中添加kotlin的配置

apply plugin: 'kotlin-android'
apply plugin: 'kotlin-kapt'
apply plugin: 'kotlin-android-extensions'
...
dependencies {
//annotationProcessor替换kapt
    implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk7:$kotlin_version"

}

至此在这个项目里的这个module已经支持kotlin开发了

自动添加kotlin的配置

在android studio中也增加了javakotlin的工具,方便开发者转换

然后会出现两个选项

一个是使用gradle的java项目转kotlin
一个是使用gradle的android项目转kotlin
我们使用第二个

选择完毕之后我们会遇到第二个弹窗选择

第一个选项是所有module,也就是整个项目全部转kotlin项目
第二个就是在一个项目里多个module,指定某个module可以支持kotlin
大家可以根据需求使用

当我们使用自动转换之后项目代码如下

buildscript {
    ext.kotlin_version = '1.4.10'
     repositories {
        mavenCentral()
    ...
    }
    ...
    dependencies {
        ...
        //对kotlin支持
        classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
        ...
    }
}

在你需要支持kotlinmodule中添加kotlin的配置

apply plugin: 'kotlin-android'

...
dependencies {
    implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk7:$kotlin_version"
}

自动转换和手动转换的对比

只有一点就是手动代码添加多添加了两个插件

apply plugin: 'kotlin-kapt'
apply plugin: 'kotlin-android-extensions'

这两个插件不是必须的,编译kotlin项目只需要apply plugin: 'kotlin-android'一个就可以了,
但是在开发中kaptkotlin-android-extensions插件是必不可少的

关于kapt

kapt 即 Kotlin annotation processing tool(Kotlin 注解处理工具)缩写。

在java开发中我们导入依赖常用的都是

// 导入注解处理
    annotationProcessor 'com.jakewharton:butterknife-compiler:8.8.1'
//导入依赖
    implementation 'io.reactivex:rxandroid:1.2.1'

在kotlin项目中
我们使用kapt代替annotationProcessor,才能生效

// 导入注解处理
    kapt 'com.jakewharton:butterknife-compiler:8.8.1'
//导入依赖
    implementation 'io.reactivex:rxandroid:1.2.1'

官方文档的说明这样的

如果你以前使用 Android 支持作为注解处理器,那么以 kapt 取代 annotationProcessor 配置的使用。如果你的项目包含 Java 类,kapt 也会顾全到它们。

如果为 androidTest 或 test 源代码使用注解处理器,那么相应的 kapt 配置名为 kaptAndroidTest 和 kaptTest。请注意 kaptAndroidTest 和 kaptTest 扩展了 kapt,所以你可以只提供 kapt 依赖而它对生产和测试源代码都可用。

注解处理器参数

使用 arguments {} 块将参数传给注解处理器:

kapt {
    arguments {
        arg("key", "value")
    }
}

kotlin-android-extensions

Kotlin Android Extensions是Kotlin团队开发的一个插件,目的是让我们在开发过程中更少的编写一样的代码。例如:findViewById
布局文件

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout 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"
    tools:context=".MainActivity2">

    <Button
        android:id="@+id/button"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Button"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />
</androidx.constraintlayout.widget.ConstraintLayout>

Activity代码:

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

class MainActivity2 : AppCompatActivity() {
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)
        button.setOnClickListener {
            Toast.makeText(this, "被点击", Toast.LENGTH_LONG).show()
        }
    }
}

我们只需要使用控件的id就可以调用获取控件,当然也需要导入布局

  • 3
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值