Android 传统view嵌入compose

上一个demo使用compose调用view, 再试下传统view嵌套compose, 还是修改之前的demo。

MainActivity 增加一个按钮,用于跳转到该demo的activity:

Kotlin 复制代码
package com.example.testnavigation

import android.content.Intent
import android.net.Uri
import android.os.Bundle
import android.widget.Button
import android.widget.ImageView
import androidx.fragment.app.FragmentActivity
import dagger.hilt.android.AndroidEntryPoint


@AndroidEntryPoint  // 注入点,可以被注入对象
class MainActivity : FragmentActivity() {

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main2)
        val ivBaibing = findViewById<ImageView>(R.id.iv_baibing)
        val uri = Uri.parse("android.resource://com.example.testnavigation/${R.drawable.baibing}")
        ivBaibing?.setImageURI(uri)
        ivBaibing?.let{
            it.setOnClickListener {
                // 预览
                val intent = Intent(this@MainActivity, PicZoomActivity::class.java).let {
                    it.putExtra(PicZoomActivity.BUNDLE_KEY_PIC_URI, uri)
                }
                startActivity(intent)
            }
        }

        // Compose 预览按钮(启动纯 Compose Activity)
        val btnComposePreview = findViewById<Button>(R.id.btn_compose_preview)
        btnComposePreview.setOnClickListener {
            val intent = Intent(this, ComposePreviewActivity::class.java).apply {
                putExtra(PicZoomActivity.BUNDLE_KEY_PIC_URI, uri)
            }
            startActivity(intent)
        }

        val btn_test_view_invoke_compose = findViewById<Button>(R.id.btn_test_view_invoke_compose)
        btn_test_view_invoke_compose?.setOnClickListener {
            startActivity(Intent(this@MainActivity, ActivityViewContainsCompose::class.java))
        }
    }
}
复制代码
ActivityViewContainsCompose 代码如下:
Kotlin 复制代码
package com.example.testnavigation

import android.app.Activity
import android.os.Bundle
import androidx.appcompat.app.AppCompatActivity
import androidx.compose.foundation.layout.Column
import androidx.compose.material3.Text
import androidx.compose.runtime.Composable
import androidx.compose.ui.platform.ComposeView
import androidx.compose.ui.unit.sp

public class ActivityViewContainsCompose : AppCompatActivity() { // 用到compose必须继承AppCompatActivity
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_view_contains_compose)
        val composeView = findViewById<ComposeView>(R.id.compose_host)

        composeView.setContent {
            // 纯 Compose 代码
            ComposeContent()
        }
    }
}

@Composable
fun ComposeContent() {
    Column {
        Text(
            text = "汝比颜良文丑如何?",
            fontSize = 18.sp
        )
        Text(
            text = "今天下英雄,惟使君与操耳!",
            fontSize = 16.sp
        )
    }
}

其布局:

XML 复制代码
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    android:padding="16dp">
    <!-- 传统 TextView -->
    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="此间乐,不思蜀也。"
        android:textSize="18sp"/>

    <!-- 用来放 Compose 的容器 -->
    <androidx.compose.ui.platform.ComposeView
        android:id="@+id/compose_host"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginTop="16dp"/>
</LinearLayout>

测试:

点击最下面按钮:

ok. 显示正确。

相关推荐
搜狐技术产品小编20232 小时前
破局与重构:纯端侧 Android 自动化引擎的尝试与未来推演
android·运维·重构·自动化
码云骑士3 小时前
Android SystemServer启动过程
android·systemserver
weiggle4 小时前
第三篇:可组合函数(Composable)——Compose 的基石
android·前端
独隅4 小时前
Android Studio 接入多种不同 AI 大模型进行开发的全面详细指南(Android Studio+AI)
android·人工智能·android studio
夜微凉45 小时前
三、MySQL
android·数据库·mysql
我命由我123455 小时前
Android 开发问题:项目同时引入了两个包含相同类文件的库(AndroidX 库、旧版本支持库),导致了重复类错误
android·java·java-ee·android studio·android-studio·androidx·android runtime
anthonyzhu5 小时前
安卓Android studio panda run无法应用更新的问题
android·ide·android studio
jingling5556 小时前
Flutter | Dio网络请求实战
android·开发语言·前端·flutter
帅次7 小时前
讯飞与腾讯云:Android 实时语音识别服务对比选择
android·ios·微信小程序·小程序·android studio·android runtime
jiayong237 小时前
MySQL 排序规则冲突问题与 utf8mb4_general_ci 统一方案
android·mysql·ci/cd