用 Kotlin 开启我们的 Activity

这篇博客介绍了如何使用Kotlin语言编写Android的Activity。首先讲解了Kotlin中的类定义、继承、函数以及构造方法和参数。接着,通过一个实际的MainActivity示例,展示了如何加载布局和初始化RecyclerView。博客强调了Kotlin与Java在语法上的差异,如默认构造器、函数定义、参数默认值以及对象实例化的简洁性。

Kotlin中的类遵循一个简单的结构。尽管与Java有一点细微的差别。你可以使用try.kotlinlang.org在不需要一个真正的项目和不需要部署到机器的前提下来测试一些简单的代码范例。

一、开启Activity前的知识预备

1、怎么定义一个类

如果你想定义一个类,你只需要使用class关键字:

class MainActivity{

}

它有一个默认唯一的构造器,我们会在以后的篇幅当中学习在特殊的情况下创建其它额外的构造器,但是请记住大部分情况下我们只需要这个默认的构造器。我们只需要在类名后面写上它的参数,如果这个类没有任何内容可以省略大括号:

class Person(name: String, surname: String)

那么构造函数的函数体在哪呢?我们可以写在init块中:

class Person(name: String, surname: String) {
    init{
        ...
    }
}

2、类继承的实现

默认任何类都是基础继承自 Any(与java中的Object类似)的,但是我们也可以继承其它类。所有的类默认都是不可继承的(final),所以我们只能继承那些明确声明 open 或者 abstract 的类:

open class Animal(name: String)
class Person(name: String, surname: String) : Animal(name)

当我们只有单个构造器时,我们需要在从父类继承下来的构造器中指定需要的参数,这是用来替换 Java 中的 super 调用的。

3、如何定义一个函数

函数(我们Java中的方法)可以使用fun关键字就可以定义:

fun onCreate(savedInstanceState: Bundle?) {
}

如果我们没有指定它的返回值,它就会返回Unit,与Java中的void类似,但是Unit是一个真正的对象。我们当然也可以指定任何其它的返回类型:

fun add(x: Int, y: Int) : Int {
    return x + y
}

注意:分号不是必须的
就像你在上面的例子中看到的那样,我在每句的最后没有使用分号。当然你也可以使用分号,分号不是必须的,而且不使用分号是一个不错的方式,因为这会节约我们很多时间。

然而如果返回的结果可以使用一个表达式计算出来,你可以不使用括号而是使用等号:

fun add(x: Int,y: Int) : Int = x + y

4、构造方法和函数参数

Kotlin 中的参数与Java中有些不同。如你所见,我们先写参数的名字再写它的类型:

fun add(x: Int, y: Int) : Int {
    return x + y
}

我们可以给参数指定一个默认值使得它们变得可选,这是非常有帮助的。这里有一个例子,在Activity中创建了一个函数用来toast一段信息:

fun toast(message: String, length: Int = Toast.LENGTH_SHORT) {
    Toast.makeText(this, message, length).show()
}

正如我们看见的,第二个参数(length)指定了一个默认值。这意味着我们调用的时候可以传入第二个值或者不传,这样可以避免我们需要的重载函数:

toast("Hello")
toast("Hello", Toast.LENGTH_LONG)

这个与下面的Java代码是一样的:

void toast(String message){
}

void toast(String message, int length){
    Toast.makeText(this, message, length).show();
}

再看看这个例子:

fun niceToast(message: String,
                tag: String = javaClass<MainActivity>().getSimpleName(),
                length: Int = Toast.LENGTH_SHORT) {
    Toast.makeText(this, "[$className] $message", length).show()
}

我增加了第三个默认值是类名的tag参数,如果在Java中总数开销会以几何增长,现在可以通过以下方式调用:

toast("Hello")
toast("Hello", "MyTag")
toast("Hello", "MyTag", Toast.LENGTH_SHORT)

而且甚至还有其它选择,因为我们可以使用参数名字来调用,这表示我们可以通过在值前写明参数名来传入我们希望的参数:

toast(message = "Hello", length = Toast.LENGTH_SHORT)

注意:关于String模版
我们可以在String中直接使用模版表达式。它可以帮助我们很简单地在静态值和变量的基础上编写复杂的String。在上面的例子中,我们使用了”[ className] message”。

任何时候我们使用一个 使"Yournameis {user.name}”。

二、编写我们的第一个类

我们之前已经定义了 MainActivity.kt 这个类,这个 Activity 会展示请求的数据,所以它的 layout 需要定义这些内容:

<FrameLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <android.support.v7.widget.RecyclerView
        android:id="@+id/testtList"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:clipToPadding="false"
        android:paddingTop="?attr/actionBarSize"/>

    <include layout="@layout/toolbar"/>

</FrameLayout>

列表我们使用 RecyclerView,所以我们需要在build.gradle中增加一个新的依赖:

dependencies {
    compile fileTree(dir: 'libs', include: ['*.jar'])
    compile "com.android.support:appcompat-v7:$support_version" 
    compile "com.android.support:recyclerview-v7:$support_version"
}

然后我们在 Mainactivity.kt 中使用老的 findViewByid() 的方式找到并加载布局:

val forecastList = findViewById(R.id.forecast_list) as RecyclerView
forecastList.layoutManager = LinearLayoutManager(this)

正如我们所看到的,我们通过 findViewById() 找到了 R.id.forecast_list 这个布局并转型为 RecyclerView。这里与 Java 有点不同,我们会在后面的文章中分析这些不同之处。LayoutManager 会通过属性的方式去设置,而不是通过 setter,现在这个 layout 已经足够显示一个列表了。

注意:Kotlin中的对象实例化
Kotlin中的对象实例化也是与Java中有些不同,我们去掉了new关键字,这时构造函数仍然会被调用,但是我们确可以省略四个字符,LinearLayoutManager(this) 创建了一个对象的实例。

<think>好的,我现在需要帮助用户了解在Kotlin中如何使用startActivity方法,并且给出示例。首先,用户之前的问题是关于Android Power键锁屏流程,现在转向了Activity跳转,这可能是因为他在开发中遇到了需要页面跳转的需求,比如点击按钮后打开另一个界面。 用户提供的引用中,引用[1]、[2]、[5]都提到了Intent的使用和Activity之间的跳转,特别是引用[1]详细说明了Intent的构造函数startActivity方法。引用[5]提到了startActivityForResult,这可能是一个扩展点,用户可能也需要了解如何接收返回数据,但当前问题集中在基本的startActivity使用。 我需要先确定用户的需求层次。他可能刚开始学习Kotlin和Android开发,所以示例需要简单明了,覆盖基本用法,比如显式跳转和隐式跳转。同时,用户可能想知道如何传递数据,如基本类型、对象等,这在引用[2]中提到过。但用户的问题明确是使用startActivity方法,所以重点应放在启动Activity的不同方式上,数据传递可以作为扩展内容。 接下来,我需要确保代码示例符合Kotlin语法,比如使用apply函数来简化Intent的构建,如引用[1]中的Java示例转换成Kotlin。同时,注意Kotlin中的类引用使用::class.java,这点需要正确展示。还要提到需要在AndroidManifest.xml中注册Activity,避免用户漏掉这一步导致应用崩溃。 另外,用户可能需要知道如何隐式启动Activity,比如调用系统功能,这部分在引用中没有提到,但作为常见用法应该包括。需要注意隐式Intent需要声明intent-filter,这也是容易出错的地方。 最后,根据用户之前的回答,相关问题可能涉及数据传递、结果返回、生命周期影响等。需要确保这些扩展问题能够帮助用户进一步学习,但不要偏离当前问题太远。</think>### Kotlin 中 `startActivity` 使用详解及示例 #### **一、基础用法(显式启动)** 1. **简单跳转** 通过 `Intent` 指定目标 Activity 类,使用 `startActivity()` 启动: ```kotlin // 当前 Activity (MainActivity) val intent = Intent(this, SecondActivity::class.java) startActivity(intent) ``` - **代码解析** - `Intent(Context, Class)` 构造:`this` 为当前上下文,`SecondActivity::class.java` 获取目标类引用[^1][^5]。 - 必须在 `AndroidManifest.xml` 中声明目标 Activity: ```xml <activity android:name=".SecondActivity" /> ``` 2. **传递数据** 通过 `putExtra()` 附加参数(支持基础类型、Bundle、Parcelable 等): ```kotlin val intent = Intent(this, SecondActivity::class.java).apply { putExtra("username", "KotlinUser") putExtra("age", 25) putExtra("is_vip", true) } startActivity(intent) ``` - **目标 Activity 接收数据**: ```kotlin // SecondActivity 中 val username = intent.getStringExtra("username") val age = intent.getIntExtra("age", 0) val isVip = intent.getBooleanExtra("is_vip", false) ``` #### **二、隐式启动(跨应用调用)** 1. **调用系统功能** 通过 `Intent` 声明动作(Action)和数据类型: ```kotlin // 打开网页 val intent = Intent(Intent.ACTION_VIEW).apply { data = Uri.parse("https://www.example.com") } startActivity(intent) ``` - **自定义隐式 Intent** 若需启动其他应用的 Activity,需声明匹配的 `intent-filter`: ```xml <!-- 目标应用 Manifest 中 --> <activity android:name=".ShareActivity"> <intent-filter> <action android:name="android.intent.action.SEND" /> <category android:name="android.intent.category.DEFAULT" /> <data android:mimeType="text/plain" /> </intent-filter> </activity> ``` #### **三、高级场景** 1. **带返回结果的跳转** 使用 `startActivityForResult()`(已弃用,推荐 `Activity Result API`): ```kotlin // 启动并等待结果(传统方式) val intent = Intent(this, SecondActivity::class.java) startActivityForResult(intent, REQUEST_CODE) // 处理返回结果 override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) { if (requestCode == REQUEST_CODE && resultCode == RESULT_OK) { val result = data?.getStringExtra("result_key") } } ``` - **现代实现(Activity Result API)**: ```kotlin val launcher = registerForActivityResult(ActivityResultContracts.StartActivityForResult()) { result -> if (result.resultCode == RESULT_OK) { val data = result.data?.getStringExtra("result_key") } } launcher.launch(Intent(this, SecondActivity::class.java)) ``` 2. **传递复杂对象** 使用 `Parcelable` 或 `Serializable` 接口: ```kotlin // 定义数据类(实现 Parcelable) @Parcelize data class User(val name: String, val age: Int) : Parcelable // 传递对象 val user = User("Android", 13) intent.putExtra("user_data", user) ``` #### **四、常见问题** 1. **Activity 未注册异常** 若未在 `AndroidManifest.xml` 中声明目标 Activity,会抛出 `ActivityNotFoundException`[^1][^5]。 2. **生命周期影响** 跳转时原 Activity 会依次触发 `onPause()` → `onStop()`,返回时触发 `onRestart()` → `onResume()`[^3]。 --- ### 示例代码 **MainActivity.kt**(发起跳转): ```kotlin class MainActivity : AppCompatActivity() { override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_main) val button = findViewById<Button>(R.id.btn_jump) button.setOnClickListener { // 显式跳转 + 传参 Intent(this, SecondActivity::class.java).apply { putExtra("message", "Hello from MainActivity!") startActivity(this) } } } } ``` **SecondActivity.kt**(接收数据): ```kotlin class SecondActivity : AppCompatActivity() { override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_second) val message = intent.getStringExtra("message") Log.d("SecondActivity", "Received: $message") } } ``` --- ### 相关问题 1. **如何在 Kotlin 中传递 Bundle 对象?** 2. **使用 Parcelable 和 Serializable 有什么区别?** 3. **如何处理 Activity 返回结果的最佳实践?** 4. **隐式 Intent 的安全风险如何规避?** [^1]: Intent 构造函数与显式跳转逻辑 [^2]: 复杂数据类型的传递实现 [^3]: Activity 生命周期对跳转的影响 [^5]: 带结果返回的跳转机制
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值