以下內容為原創,歡迎轉載,轉載請注明
來自天天博客:http://www.cnblogs.com/tiantianbyconan/p/4800656.html
Kotlin是由JetBrains開發並且開源的靜態類型JVM語言。比Java語言語法簡潔,支持很多Java中不支持的語法特性,如高階函數、內聯函數、null安全、靈活擴展、操作符重載等等。而且它還完全兼容Java,與Scala類似,但是Scala的宗旨是“盡可能自己實現,不得已才使用Java”,而Kotlin卻相反:“盡可能復用Java的實現,不得已才自己實現”。所以相比之下Kotlin更簡潔輕量,非常適合移動端的開發。另外JetBrains針對Android開發提供了一個由Kotlin實現的“anko”開源庫,可以讓你使用DSL的方式直接用代碼編寫UI,讓你從繁瑣的xml中解脫出來,而且避免了xml解析過程所帶來的性能問題。
這篇先講怎么去使用idea(Android Studio用戶也一樣)搭建Kotlin的Android開發環境。
一、下載以下相關idea插件:
1. Kotlin
2. Kotlin Extensions For Android
3. Anko DSL Preview
其中Anko DSL Preview插件用於預覽使用DSL編寫的UI代碼,就像以前使用xml編寫UI文件時可以動態在“Preview”窗口預覽效果一樣。
二、新建Android項目
在src/main目錄下,新建kotlin目錄(用於放置kotlin代碼),配置Gradle如下:
1 buildscript { 2 ext.kotlin_version = '0.12.1230' 3 repositories { 4 mavenCentral() 5 } 6 dependencies { 7 classpath 'com.android.tools.build:gradle:1.1.1' 8 classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version" 9 classpath "org.jetbrains.kotlin:kotlin-android-extensions:$kotlin_version" 10 } 11 } 12 apply plugin: 'com.android.application' 13 apply plugin: 'kotlin-android' 14 15 repositories { 16 mavenCentral() 17 } 18 19 android { 20 compileSdkVersion 22 21 buildToolsVersion "22.0.1" 22 23 defaultConfig { 24 applicationId "com.wangjie.androidwithkotlin" 25 minSdkVersion 9 26 targetSdkVersion 22 27 versionCode 1 28 versionName "1.0" 29 } 30 31 sourceSets { 32 main.java.srcDirs += 'src/main/kotlin' 33 } 34 35 buildTypes { 36 release { 37 minifyEnabled false 38 proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' 39 } 40 } 41 } 42 43 dependencies { 44 compile fileTree(dir: 'libs', include: ['*.jar']) 45 compile 'com.android.support:appcompat-v7:22.2.0' 46 compile "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version" 47 compile "org.jetbrains.kotlin:kotlin-reflect:$kotlin_version" 48 compile 'org.jetbrains.anko:anko:0.6.3-15' 49 }
然后sync & build。
三、配置Kotlin
調用“Configuring Kotlin in the project”這個Action


四、把Java代碼一鍵轉成kotlin代碼
打開要轉換的Java文件,調用“Convert Java File to Kotlin File”這個Action即可。

轉換之前的Java代碼:
public class MainActivity extends ActionBarActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); } @Override public boolean onCreateOptionsMenu(Menu menu) { // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(R.menu.menu_main, menu); return true; } @Override public boolean onOptionsItemSelected(MenuItem item) { // Handle action bar item clicks here. The action bar will // automatically handle clicks on the Home/Up button, so long // as you specify a parent activity in AndroidManifest.xml. int id = item.getItemId(); //noinspection SimplifiableIfStatement if (id == R.id.action_settings) { return true; } return super.onOptionsItemSelected(item); } }
轉換之后的Kotlin代碼:
public class MainActivity : ActionBarActivity() { override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_main) } override fun onCreateOptionsMenu(menu: Menu?): Boolean { // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(R.menu.menu_main, menu) return true } override fun onOptionsItemSelected(item: MenuItem?): Boolean { // Handle action bar item clicks here. The action bar will // automatically handle clicks on the Home/Up button, so long // as you specify a parent activity in AndroidManifest.xml. val id = item!!.getItemId() //noinspection SimplifiableIfStatement if (id == R.id.action_settings) { return true } return super.onOptionsItemSelected(item) } }
