使用Kotlin進行Android開發


 Kotlin是一門基於JVM的編程語言,它正成長為Android開發中用於替代Java語言的繼承者。Java是世界上使用最多的編程語言之一,當其他編程語言為更加便於開發者使用而不斷進化時,Java並沒有像預期那樣及時跟進。
    Kotlin是由JetBrains創建的基於JVM的編程語言,IntelliJ正是JetBrains的傑作,而Android Studio是基於IntelliJ修改而來的。Kotlin是一門包含很多函數式編程思想的面向對象編程語言。
  Kotlin生來就是為了彌補Java缺失的現代語言的特性,並極大的簡化了代碼,使得開發者可以編寫盡量少的樣板代碼。
據說是Android下的swift語言,而且是有jetBrains出品,有這么強大的IDE支持,一定錯不了。
 
AndroidStudio安裝Kotlin開發插件:
點擊“Install JetBrains plugin”
輸入kotlin搜索,安裝下面那個Kotlin Extension For Android插件,安裝后重啟AS。
 
創建KotlinActivity:
新建Android工程,這一步和以前創建安卓工程的步驟類似,這個時候工程里面也沒有跟kotlin有半毛錢的關系。
只不過在工程創建完成后,再新建Activity的時候選擇KotlinActivity:
 
不帶分號結束的看起來就是舒服,習慣了Lua和Python。
自動創建的界面布局文件和之前的沒什么區別,依然是xml格式的。同時manifest里也會自動添加該Activity的聲明。
 
配置gradle:
如果IDE提示需要配置Kotlin的時候,就點擊配置就好了,會自動在project和module的build.gradle里配置好。如果是手動配置的話,請在project的build.gradle里配置:
buildscript {
ext.kotlin_version = '1.0.2'
repositories {
jcenter()
}
dependencies {
classpath 'com.android.tools.build:gradle:2.1.0'
classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"

// NOTE: Do not place your application dependencies here; they belong
// in the individual module build.gradle files
}
}
在module的build.gradle里配置:
apply plugin: 'com.android.application'
apply plugin: 'kotlin-android'

android {
compileSdkVersion 23
buildToolsVersion "23.0.2"

defaultConfig {
applicationId "com.example.demo_yunbu"
minSdkVersion 15
targetSdkVersion 23
versionCode 1
versionName "1.0"
}
buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
}
}
sourceSets {
main.java.srcDirs += 'src/main/kotlin'
}
}

dependencies {
compile fileTree(dir: 'libs', include: ['*.jar'])
compile 'com.android.support:appcompat-v7:23.1.1'
compile "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version"
}
repositories {
mavenCentral()
}
最后IDE提示Sync Now,用用這些修改就好了。
 
最后我們在布局文件中添加一個TextView來演示控件的操作:
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/tvMessage"/>
然后在Activity代碼里就可以直接使用變量tvMessage了,如果有如下提示:
只需要按Alt+Enter導入布局文件的引用即可,自動導入:
import kotlinx.android.synthetic.main.activity_main.*
然后可以直接使用變量tvMessage進行操作了,非常方便,再也不用每個控件用findViewById查找一遍了。
以下是完整的代碼:
package com.example.hellokotlin

import android.content.Intent
import android.support.v7.app.AppCompatActivity
import android.os.Bundle
import kotlinx.android.synthetic.main.activity_main.*

class MainActivity : AppCompatActivity() {

override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
tvMessage.text = "hello kotlin!";
btnOpenActivity2.text = "OpenActivity2"
btnOpenActivity2.setOnClickListener({ startActivity(Intent(MainActivity@this, SecondActivity::class.java)) })
}
}
把之前的java代碼轉換為Kotlin:
前面新建android工程的時候因為MainActivity並不是KotlinActivity,因此需要轉換一下,
選擇菜單Code->Convert Java File to Kotlin File
除了文件內容改變之外,文件的擴展名也從.java變為了.kt。
 
 
編譯,出現錯誤:
Error:(6, 8) Unresolved reference: kotlinx
Error:(13, 9) Unresolved reference: tvMessage
Error:Execution failed for task ':app:compileDebugKotlin'.
> Compilation error. See log for more details
 
提示缺少kotlin,需要手動配置一下,在module的build.gradle里添加:
buildscript {
repositories {
jcenter()
}
dependencies {
classpath "org.jetbrains.kotlin:kotlin-android-extensions:$kotlin_version"
}
}
修改完成后Sync Now一次,編譯通過,運行效果:
點擊按鈕后打開一個空白的頁面,這里就不截圖了。
 
使用anko創建界面:
前面的界面全部繼續使用了XML來創建的,這里演示下使用anko創建界面。
首先配置gradle,在project的gradle里buildscript添加:
ext.anko_version = '0.8.2'
再在module的gradle里dependencies添加:
// Anko
compile "org.jetbrains.anko:anko-common:$anko_version"
compile 'org.jetbrains.anko:anko-sdk15:0.8.2' // sdk19, sdk21, sdk23 are also available
compile 'org.jetbrains.anko:anko-support-v4:0.8.2' // In case you need support-v4 bindings
compile 'org.jetbrains.anko:anko-appcompat-v7:0.8.2' // For appcompat-v7 bindings
最后Sync Now,成功后編輯SecondActivity的代碼:
package com.example.hellokotlin

import android.support.v7.app.AppCompatActivity
import android.os.Bundle
import org.jetbrains.anko.*

class SecondActivity : AppCompatActivity() {

override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
// setContentView(R.layout.activity_second)

verticalLayout {
padding = dip(30)
editText {
hint = "Name"
textSize = 24f
}
editText {
hint = "Password"
textSize = 24f
}
button("Login") {
textSize = 26f
onClick { toast(button@this.text) }
}
}
}
}
這里注釋掉了原來由setContentView來設置的xml布局,而使用了代碼直接創建,使用起來簡單直接了,但是缺點也很明顯,不能做到界面設計階段的實時預覽效果,很難做到所見即所得,好在xml還能繼續支持。
運行看下效果,點擊主界面的按鈕打開第二個頁面:
點擊Login按鈕彈出一個土司,文本就是該按鈕的文本。
 
 
參考:


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM