一侈贷、環(huán)境配置
1.Android Studio 3.0及以上版本等脂,新創(chuàng)建kotlin工程,或者新建kotlin文件時(shí)搏屑,gradle會(huì)自動(dòng)配置好
2.Android Studio 3.0以下版本,需要手動(dòng)添加相關(guān)依賴
(1)kotlin plugin
添加對應(yīng)的插件
(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 變?yōu)?strong>:
(2)實(shí)際上,實(shí)現(xiàn)接口也由implements變?yōu)?strong>:
(3)AppCompatActivity()雕凹,表示繼承時(shí)政冻,調(diào)用父類的構(gòu)造器。類似java的父類委托機(jī)制
(4)override fun明场,表示覆蓋父類的函數(shù),override 不再以注解的方式修飾逼泣,kotlin聲明函數(shù)用fun修飾
(5)savedInstanceState: Bundle? 在kotlin中舟舒,變量聲明都是(名稱:類型),秃励?表示該變量可以為null,這個(gè)是kotlin的null安全機(jī)制
(6)tv_title.text莺治,無需使用findViewById谣旁,直接使用id即可訪問對應(yīng)的TextView(btn_toast同理)。setText() 變?yōu)閠ext砌们,kotlin通過點(diǎn)語法訪問成員變量搁进,實(shí)際調(diào)用的就是對應(yīng)的setter和getter方法
(7)點(diǎn)擊事件,匿名內(nèi)部類實(shí)現(xiàn)方式饼问,用object修飾
(8)this@MainActivity,無法直接使用MaintActivity.this
(9)你沒注意到峻堰,行末尾的;(分號結(jié)束符)已經(jīng)不需要了嗎
三捐名、多種點(diǎn)擊事件寫法
1.匿名內(nèi)部類(如上述寫法)
2.onClick屬性綁定點(diǎn)擊函數(shù)
(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實(shí)現(xiàn)點(diǎn)擊接口
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.內(nèi)部類實(shí)現(xiàn)點(diǎn)擊接口
class MainActivity : AppCompatActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
btn_toast.setOnClickListener(ToastBtnListener())
}
// inner 修飾表示這是一個(gè)非靜態(tài)內(nèi)部類
// 沒有inner修飾镶蹋,表示這是一個(gè)靜態(tài)內(nèi)部類,kotlin稱之為嵌套類
inner class ToastBtnListener :View.OnClickListener{
override fun onClick(p0: View?) {
Toast.makeText(p0?.context,"我是toast"
,Toast.LENGTH_SHORT).show()
}
}
}
5.Lambda表達(dá)式
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()
}
}
}