一、环境配置
1.Android Studio 3.0及以上版本,新创建kotlin工程,或者新建kotlin文件时,gradle会自动配置好
2.Android Studio 3.0以下版本,需要手动添加相关依赖
(1)kotlin plugin
(2)工程gradle文件
buildscript {
ext.kotlin_version = '1.3.20'
repositories {
google()
jcenter()
}
dependencies {
classpath 'com.android.tools.build:gradle:3.3.0'
classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
}
}
(3)模块gradle文件
apply plugin: 'kotlin-android'
apply plugin: 'kotlin-android-extensions'
...
dependencies {
...
implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk7:$kotlin_version"
}
二、Hello World
1.布局文件
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity"
android:orientation="vertical">
<TextView
android:gravity="center"
android:id="@+id/tv_title"
android:layout_width="match_parent"
android:layout_height="wrap_content"/>
<Button
android:text="显示Toast"
android:layout_marginTop="20dp"
android:gravity="center"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:id="@+id/btn_toast"/>
</LinearLayout>
(1)简单的布局,记住TextView和Button的id
2.代码文件
class MainActivity : AppCompatActivity() { // 1,2,3
override fun onCreate(savedInstanceState: Bundle?) { // 4,5
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
tv_title.text = "Hello World!" // 6
btn_toast.setOnClickListener(object :View.OnClickListener{ // 7
override fun onClick(p0: View?) {
Toast.makeText(this@MainActivity,"我是toast" // 8
,Toast.LENGTH_SHORT).show()
}
})
}
}
(1)继承的写法,由extends 变为:
(2)实际上,实现接口也由implements变为:
(3)AppCompatActivity(),表示继承时,调用父类的构造器。类似java的父类委托机制
(4)override fun,表示覆盖父类的函数,override 不再以注解的方式修饰,kotlin声明函数用fun修饰
(5)savedInstanceState: Bundle? 在kotlin中,变量声明都是(名称:类型),?表示该变量可以为null,这个是kotlin的null安全机制
(6)tv_title.text,无需使用findViewById,直接使用id即可访问对应的TextView(btn_toast同理)。setText() 变为text,kotlin通过点语法访问成员变量,实际调用的就是对应的setter和getter方法
(7)点击事件,匿名内部类实现方式,用object修饰
(8)this@MainActivity,无法直接使用MaintActivity.this
(9)你没注意到,行末尾的;(分号结束符)已经不需要了吗
三、多种点击事件写法
1.匿名内部类(如上述写法)
2.onClick属性绑定点击函数
(1)布局文件
<Button
android:text="显示Toast"
android:layout_marginTop="20dp"
android:gravity="center"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:onClick="showToastMethod"/>
(2)代码文件
class MainActivity : AppCompatActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
}
fun showToastMethod(view:View){
Toast.makeText(view.context,"我是Toast",Toast.LENGTH_SHORT).show()
}
}
3.Activity实现点击接口
class MainActivity : AppCompatActivity(),View.OnClickListener {
override fun onClick(p0: View?) {
if(p0?.id == btn_toast.id)
{
Toast.makeText(this@MainActivity,"我是toast"
,Toast.LENGTH_SHORT).show()
}
}
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
btn_toast.setOnClickListener(this)
}
}
4.内部类实现点击接口
class MainActivity : AppCompatActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
btn_toast.setOnClickListener(ToastBtnListener())
}
// inner 修饰表示这是一个非静态内部类
// 没有inner修饰,表示这是一个静态内部类,kotlin称之为嵌套类
inner class ToastBtnListener :View.OnClickListener{
override fun onClick(p0: View?) {
Toast.makeText(p0?.context,"我是toast"
,Toast.LENGTH_SHORT).show()
}
}
}
5.Lambda表达式
class MainActivity : AppCompatActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
btn_toast.setOnClickListener{
Toast.makeText(this@MainActivity, "我是Toast"
, Toast.LENGTH_SHORT).show()
}
}
}