安卓开发Intent详细介绍和使用

1. 什么是 Intent

在 Android 开发里,Intent 是一个极为关键的组件,它本质上是一种消息传递对象。其主要用途是在不同的组件之间进行通信,这些组件涵盖了 ActivityServiceBroadcastReceiver 等。借助 Intent,你能够启动新的 Activity、开启或停止 Service,还能发送广播消息。

2. Intent 的主要作用

  • 启动 Activity :从一个 Activity 跳转到另一个 Activity
  • 启动 Service:开启或停止一个后台服务。
  • 发送广播:向系统或者应用内的广播接收器发送消息。
  • 数据传递:在不同组件之间传递数据。

3. Intent 的类型

显式 Intent

显式 Intent 明确指定了要启动的组件的名称,通常用于应用内部组件之间的交互。

kotlin

kotlin 复制代码
import android.content.Intent
import androidx.appcompat.app.AppCompatActivity
import android.os.Bundle
import android.widget.Button

class MainActivity : AppCompatActivity() {
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)

        val button = findViewById<Button>(R.id.start_button)
        button.setOnClickListener {
            // 创建显式 Intent,指定要启动的 Activity 类
            val intent = Intent(this, SecondActivity::class.java)
            startActivity(intent)
        }
    }
}

隐式 Intent

隐式 Intent 不指定具体的组件,而是通过 ActionCategoryData 等信息来描述要执行的操作,系统会根据这些信息寻找合适的组件来处理。

kotlin

kotlin 复制代码
import android.content.Intent
import android.net.Uri
import androidx.appcompat.app.AppCompatActivity
import android.os.Bundle
import android.widget.Button

class MainActivity : AppCompatActivity() {
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)

        val button = findViewById<Button>(R.id.open_browser_button)
        button.setOnClickListener {
            // 创建隐式 Intent,打开网页
            val uri = Uri.parse("https://www.example.com")
            val intent = Intent(Intent.ACTION_VIEW, uri)
            startActivity(intent)
        }
    }
}

4. Intent 的主要属性

  • Action :是一个字符串,用于指定要执行的通用操作,如 ACTION_VIEWACTION_EDIT 等。
  • Data :一个 Uri 对象,用于指定操作所涉及的数据,例如文件的 Uri、网页的 Uri 等。
  • Category :是一个字符串集合,用于进一步描述 Intent 的附加信息,例如 CATEGORY_DEFAULT 表示默认的操作。
  • Type :指定数据的 MIME 类型,如 text/plainimage/jpeg 等。
  • Extras :是一个 Bundle 对象,用于在 Intent 中携带额外的数据,例如传递字符串、整数等。

5. 在 Intent 中传递数据

kotlin

kotlin 复制代码
import android.content.Intent
import androidx.appcompat.app.AppCompatActivity
import android.os.Bundle
import android.widget.Button
import android.widget.TextView

class MainActivity : AppCompatActivity() {
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)

        val button = findViewById<Button>(R.id.send_data_button)
        button.setOnClickListener {
            val intent = Intent(this, SecondActivity::class.java)
            intent.putExtra("message", "这是传递的数据")
            startActivity(intent)
        }
    }
}

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

        val textView = findViewById<TextView>(R.id.received_text)
        val message = intent.getStringExtra("message")
        textView.text = message
    }
}

6. 启动 Activity 并获取返回结果

kotlin

kotlin 复制代码
import android.content.Intent
import androidx.appcompat.app.AppCompatActivity
import android.os.Bundle
import android.widget.Button
import android.widget.TextView

class MainActivity : AppCompatActivity() {
    private val REQUEST_CODE = 1

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

        val button = findViewById<Button>(R.id.start_for_result_button)
        button.setOnClickListener {
            val intent = Intent(this, SecondActivity::class.java)
            startActivityForResult(intent, REQUEST_CODE)
        }
    }

    override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) {
        super.onActivityResult(requestCode, resultCode, data)
        if (requestCode == REQUEST_CODE && resultCode == RESULT_OK) {
            val result = data?.getStringExtra("result")
            val textView = findViewById<TextView>(R.id.result_text)
            textView.text = result
        }
    }
}

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

        val button = findViewById<Button>(R.id.return_result_button)
        button.setOnClickListener {
            val resultIntent = Intent()
            resultIntent.putExtra("result", "这是返回的结果")
            setResult(RESULT_OK, resultIntent)
            finish()
        }
    }
}

7. 启动 Service

kotlin

kotlin 复制代码
import android.content.Intent
import androidx.appcompat.app.AppCompatActivity
import android.os.Bundle
import android.widget.Button

class MainActivity : AppCompatActivity() {
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)

        val startServiceButton = findViewById<Button>(R.id.start_service_button)
        startServiceButton.setOnClickListener {
            val intent = Intent(this, MyService::class.java)
            startService(intent)
        }

        val stopServiceButton = findViewById<Button>(R.id.stop_service_button)
        stopServiceButton.setOnClickListener {
            val intent = Intent(this, MyService::class.java)
            stopService(intent)
        }
    }
}

import android.app.Service
import android.content.Intent
import android.os.IBinder

class MyService : Service() {
    override fun onBind(intent: Intent?): IBinder? {
        return null
    }

    override fun onStartCommand(intent: Intent?, flags: Int, startId: Int): Int {
        // 执行服务操作
        return START_STICKY
    }

    override fun onDestroy() {
        super.onDestroy()
        // 服务销毁时的操作
    }
}

8. 发送广播

kotlin

kotlin 复制代码
import android.content.BroadcastReceiver
import android.content.Context
import android.content.Intent
import android.content.IntentFilter
import androidx.appcompat.app.AppCompatActivity
import android.os.Bundle
import android.widget.Button

class MainActivity : AppCompatActivity() {
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)

        val sendBroadcastButton = findViewById<Button>(R.id.send_broadcast_button)
        sendBroadcastButton.setOnClickListener {
            val intent = Intent("com.example.MY_CUSTOM_BROADCAST")
            sendBroadcast(intent)
        }
    }

    override fun onResume() {
        super.onResume()
        val filter = IntentFilter("com.example.MY_CUSTOM_BROADCAST")
        registerReceiver(broadcastReceiver, filter)
    }

    override fun onPause() {
        super.onPause()
        unregisterReceiver(broadcastReceiver)
    }

    private val broadcastReceiver = object : BroadcastReceiver() {
        override fun onReceive(context: Context?, intent: Intent?) {
            if (intent?.action == "com.example.MY_CUSTOM_BROADCAST") {
                // 处理广播消息
            }
        }
    }
}

以上就是 Intent 的详细介绍和使用示例,通过这些示例你可以了解如何使用 Intent 进行组件间的通信和数据传递。

编辑

分享

相关推荐
Gracker1 小时前
Android Perfetto 系列 9 - CPU 信息解读
android
Gracker1 小时前
Android Perfetto 系列 8:深入理解 Vsync 机制与性能分析
android
Gracker2 小时前
Android Perfetto 系列 07 - MainThread 和 RenderThread 解读
android
Gracker2 小时前
Android Perfetto 系列 5:Android App 基于 Choreographer 的渲染流程
android
Gracker2 小时前
Android Perfetto 系列 6:为什么是 120Hz?高刷新率的优势与挑战
android
apigfly2 小时前
Flutter,Compose,Web 在Android平台上从布局到屏幕的机制探究
android·flutter·webview
摇滚侠2 小时前
Vue 项目实战《尚医通》,预约挂号的路由与静态搭建,笔记36
javascript·vue.js·笔记
三品吉他手会点灯3 小时前
STM32F103学习笔记-16-RCC(第4节)-使用 HSI 配置系统时钟并用 MCO 监控系统时钟
笔记·stm32·单片机·嵌入式硬件·学习
Lester_11013 小时前
嵌入式学习笔记 - 关于看门狗定时器的喂狗的操作放在中断还是放在主循环
笔记·单片机·学习
czhc11400756633 小时前
Java1112 基类 c#vscode使用 程序结构
android·java·数据库