Jet pack Compose集成unisdk

  • 这里只是记录,方便自己复制,记得先看官方文档,官方文档更简洁易懂

一、先在官网下载UniMPSDK

  • 官网文档 nativesupport.dcloud.net.cn/UniMPDocs/U...
  • 创建项目的时候Minimum SDK选API 21 ("Lollipop"; Android 5.0),其他我没试过
  • 把demo的app/libs文件夹复制到你项目的app/libs下面(记住,复制官方demo中的libs,一定不要全复制SDK文件夹里面的libs,因为有些文件会冲突
  • 把官方demo中的app/proguard.cfg中内容复制到app/proguard-rules.pro文件中
  • 项目根目录/gradle.properties最后一行加上android.enableJetifier=true
  • 将demo中app/src/main/assets完整复制到项目对应目录下

二、配置app/build.gradle.kts文件(有些省略了)

kotlin 复制代码
// todo 此处省略...

var mfph = mapOf(
    "apk.applicationId" to "com.example.unimpdemo",
)

android {
    namespace = "com.airqirke.uni_demo"
    compileSdk = 35 //创建的时候可能是其他的此处改成35
    buildToolsVersion = "35.0.0"

    defaultConfig {
        applicationId = "com.airqirke.uni_demo"
        minSdk = 21
        //noinspection OldTargetApi
        targetSdk = 34
        versionCode = 1
        versionName = "1.0"
        
        //下面这两行是新加的
        multiDexEnabled = true
        manifestPlaceholders.putAll(mfph)

        // todo 此处省略...
    }

    buildTypes {
        debug {
            isMinifyEnabled = false
            proguardFiles(
                getDefaultProguardFile("proguard-android-optimize.txt"),
                "proguard-rules.pro"
            )
        }
        release {
            isMinifyEnabled = true //改成true
            proguardFiles(
                getDefaultProguardFile("proguard-android-optimize.txt"),
                "proguard-rules.pro"
            )
        }
    }

    //此处配置必须添加 否则无法正确运行
    androidResources {
        additionalParameters += listOf("--auto-add-overlay")
        //noCompress 'foo', 'bar'
        ignoreAssetsPattern += listOf("!.svn","!.git",".*","!CVS","!thumbs.db","!picasa.ini","!*.scc","*~")
    }

    // todo 此处省略...
}

dependencies {

   // todo 此处省略...

    //导入SDK相关依赖jar、aar
    implementation(fileTree(mapOf("dir" to "libs", "include" to listOf("*.jar", "*.aar"))))

    //必须添加的依赖--下面的依赖虽然官方说不能变版本号,但是我都变了依然可以正常运行
    implementation ("com.android.support:recyclerview-v7:28.0.0")
    implementation ("com.android.support:support-v4:28.0.0")
    implementation ("com.android.support:appcompat-v7:28.0.0")
    implementation ("com.alibaba:fastjson:1.2.83")
    implementation ("com.facebook.fresco:fresco:2.5.0")
    implementation ("com.facebook.fresco:animated-gif:2.5.0")
    implementation ("com.github.bumptech.glide:glide:4.9.0")
    implementation ("androidx.webkit:webkit:1.6.1")
    implementation("com.tencent.mm.opensdk:wechat-sdk-android:6.8.0")//这个是因为aar有微信api
    implementation("androidx.multidex:multidex:2.0.0")//这个版本不要动
}

三、配置AndroidManifest.xml(不要完整复制,对应的地方改就行了)

xml 复制代码
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools">

    <!-- Barcode(二维码)  begin -->
    <uses-permission android:name="android.permission.CAMERA" />
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />

    <uses-feature android:name="android.hardware.camera" />
    <uses-feature android:name="android.hardware.camera.autofocus" />

    <uses-permission android:name="android.permission.VIBRATE" />
    <uses-permission android:name="android.permission.FLASHLIGHT" />
    <!-- Barcode(二维码)  end -->

    <uses-permission android:name="android.permission.USE_FINGERPRINT" />

    <!-- Maps(地图) begin -->
    <uses-permission android:name="android.permission.INTERNET" />
    <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
    <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
    <uses-permission android:name="android.permission.WRITE_SETTINGS"
        tools:ignore="ProtectedPermissions" />
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
    <uses-permission android:name="android.permission.CHANGE_WIFI_STATE" />
    <uses-permission android:name="android.permission.READ_PHONE_STATE" />
    <uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS"
        tools:ignore="ProtectedPermissions" />
    <uses-permission android:name="android.permission.READ_LOGS"
        tools:ignore="ProtectedPermissions" />
    <!-- Maps(地图) end -->


    <!-- Share(分享)  begin -->
    <!-- Share - 新浪微博分享 -->
    <uses-permission android:name="android.permission.CHANGE_WIFI_STATE" />
    <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
    <!-- Share - 微信分享 -->
    <uses-permission android:name="android.permission.MODIFY_AUDIO_SETTINGS" />


    <!-- Speech(语音识别)  begin -->
    <uses-permission android:name="android.permission.INTERNET" />
    <uses-permission android:name="android.permission.RECORD_AUDIO" />
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
    <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
    <uses-permission android:name="android.permission.CHANGE_NETWORK_STATE" />
    <uses-permission android:name="android.permission.READ_PHONE_STATE" />
    <!-- Speech(语音识别)  end -->


    <!-- Statistic(统计)  begin -->
    <!-- Statistic - 友盟统计 -->
    <uses-permission android:name="android.permission.READ_LOGS"
        tools:ignore="ProtectedPermissions" />
    <uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" />
    <uses-permission android:name="android.permission.RECEIVE_USER_PRESENT" />
    <!-- Statistic(统计)  end -->

    <!-- 蓝牙 ibeacon权限-->
    <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
    <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
    <uses-permission android:name="android.permission.BLUETOOTH_ADMIN" />
    <uses-permission android:name="android.permission.BLUETOOTH" />
    <uses-permission android:name="android.permission.ACCESS_BACKGROUND_LOCATION" />
    <uses-permission android:name="android.permission.BLUETOOTH_SCAN" />
    <uses-permission android:name="android.permission.BLUETOOTH_CONNECT" />

    <!-- 基座删除的部分权限 -->
    <uses-permission android:name="android.permission.GET_TASKS" />
    <uses-permission android:name="android.permission.CHANGE_NETWORK_STATE" />
    <uses-permission android:name="android.permission.READ_CONTACTS" />
    <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />

    <uses-feature android:name="android.hardware.camera.autofocus"
        tools:ignore="DuplicateUsesFeature" />

    <uses-permission android:name="android.permission.WRITE_CONTACTS" />
    <uses-permission android:name="android.permission.CAMERA" />
    <uses-permission android:name="android.permission.GET_ACCOUNTS" />
    <uses-permission android:name="android.permission.RECORD_AUDIO" />
    <uses-permission android:name="android.permission.SEND_SMS"
        tools:ignore="PermissionImpliesUnsupportedChromeOsHardware" />
    <uses-permission android:name="android.permission.READ_PHONE_STATE" />
    <uses-permission android:name="android.permission.FLASHLIGHT" />

    <uses-feature android:name="android.hardware.camera"
        tools:ignore="DuplicateUsesFeature" />

    <uses-permission android:name="android.permission.WRITE_OBB"
        tools:ignore="ProtectedPermissions" />
    <uses-permission android:name="android.permission.READ_SMS"
        tools:ignore="PermissionImpliesUnsupportedChromeOsHardware" />

    <uses-permission android:name="android.permission.FOREGROUND_SERVICE" />
    <uses-permission android:name="android.permission.FOREGROUND_SERVICE" />

    <application
        android:allowBackup="true"
        android:allowClearUserData="true"
        android:dataExtractionRules="@xml/data_extraction_rules"
        android:fullBackupContent="@xml/backup_rules"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:roundIcon="@mipmap/ic_launcher_round"
        android:supportsRtl="true"
        android:largeHeap="true"
        android:extractNativeLibs="true"
        android:theme="@style/Theme.Uni_demo"
        tools:targetApi="31"
        tools:replace="android:allowBackup,android:allowNativeHeapPointerTagging"
        android:allowNativeHeapPointerTagging="false"
        android:name=".App"
        tools:ignore="AppLinkUrlError">
        <activity
            android:name=".MainActivity"
            android:exported="true"
            android:label="@string/app_name"
            android:theme="@style/Theme.Uni_demo"
            android:hardwareAccelerated="true"
            android:windowSoftInputMode="adjustResize"
            android:configChanges="orientation|keyboardHidden|screenSize|mcc|mnc|fontScale"
            >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>

        <!-- Statistic(统计)-友盟统计 begin -->
        <!-- 官方网站:http://www.umeng.com/analytics -->
        <!-- meta-data节点android:name="UMENG_APPKEY"项中android:value值为友盟网站申请的APPKEY -->
        <!-- meta-data节点android:name="UMENG_CHANNEL"项中android:value值为发行渠道标识,可任意取值,用于各种发行渠道效果统计 -->
        <meta-data
            android:name="UMENG_APPKEY"
            android:value="xxxxxxx" />
        <meta-data
            android:name="UMENG_CHANNEL"
            android:value="googleplay" />
        <!-- 友盟统计  配置  end -->

        <provider
            android:name="io.dcloud.common.util.DCloud_FileProvider"
            android:authorities="${apk.applicationId}.dc.fileprovider"
            android:exported="false"
            android:grantUriPermissions="true">
            <meta-data
                android:name="android.support.FILE_PROVIDER_PATHS"
                android:resource="@xml/dcloud_file_provider" />
        </provider>

        <!-- Maps(地图) begin -->

        <meta-data
            android:name="com.amap.api.v2.apikey"
            android:value="346dc11885001c4fe444bdedc362cd4f" />
        <service android:name="com.amap.api.location.APSService"
            tools:ignore="MissingClass" />
        <!-- Maps(地图) end -->

        <!-- Oauth 授权登陆 start -->
        <!-- Oauth QQ start -->
        <!-- QQ 分享 配置和授权登陆相同 -->
        <meta-data
            android:name="QQ_APPID"
            android:value="xxxxx" />

        <!-- Share(分享) begin -->
        <!-- Share - 新浪微博分享 -->
        <!-- 官方网站:http://open.weibo.com/ -->
        <meta-data
            android:name="SINA_REDIRECT_URI"
            android:value="http://www.dcloud.io/" />
        <meta-data
            android:name="SINA_SECRET"
            android:value="xxxx" />
        <meta-data
            android:name="SINA_APPKEY"
            android:value="xxxxx" />
        <!-- 分享 -->

        <meta-data
            android:name="WX_SECRET"
            android:value="xxxxx" />

        <activity
            android:name=".wxapi.WXEntryActivity"
            android:exported="true"
            android:label="@string/app_name"
            android:launchMode="singleTop">
            <intent-filter>
                <action android:name="android.intent.action.VIEW" />

                <category android:name="android.intent.category.DEFAULT" />

                <data android:scheme="wx0411fa6a39d61297" />
            </intent-filter>
        </activity>
        <!-- 微信分享 配置 end -->

        <activity
            android:name=".wxapi.WXPayEntryActivity"
            android:exported="true"
            android:launchMode="singleTop" />

        <meta-data
            android:name="WX_APPID"
            android:value="xxxxx" />

        <!--百度语音识别 start-->
        <meta-data
            android:name="com.baidu.speech.APP_ID"
            android:value="xxxxx" />
        <meta-data
            android:name="com.baidu.speech.API_KEY"
            android:value="xxxxxxx" />
        <meta-data
            android:name="com.baidu.speech.SECRET_KEY"
            android:value="xxxxxx" />

        <service
            android:name="com.baidu.speech.VoiceRecognitionService"
            android:exported="false" />
        <!--百度语音识别 end-->

        <activity
            android:name="io.dcloud.PandoraEntryActivity"
            android:configChanges="orientation|keyboardHidden|screenSize|mcc|mnc|fontScale|keyboard"
            android:hardwareAccelerated="true"
            android:launchMode="singleTask"
            android:exported="false"
            android:permission="com.miui.securitycenter.permission.AppPermissionsEditor"
            android:screenOrientation="user"
            android:theme="@style/DCloudTheme"
            android:windowSoftInputMode="adjustResize"
            tools:ignore="Instantiatable">

            <intent-filter>

                <category android:name="android.intent.category.DEFAULT" />

                <category android:name="android.intent.category.BROWSABLE" />

                <action android:name="android.intent.action.VIEW" />

                <data android:scheme="h56131bcf" />
            </intent-filter>
        </activity>

    </application>

</manifest>

四、创建App.kt(记得在AndroidManifest.xml的application中引用android:name=".App"

kotlin 复制代码
package com.airqirke.uni_demo

import android.app.Application
import android.content.Context
import android.util.Log
import androidx.multidex.MultiDex
import io.dcloud.feature.sdk.DCSDKInitConfig
import io.dcloud.feature.sdk.DCUniMPSDK
import io.dcloud.feature.sdk.MenuActionSheetItem

class App : Application() {
    override fun onCreate() {
        super.onCreate()


        //初始化 uni小程序SDK ----start----------
        val item = MenuActionSheetItem("关于", "gy")

        val item1 = MenuActionSheetItem("获取当前页面url", "hqdqym")
        val item2 = MenuActionSheetItem("跳转到宿主原生测试页面", "gotoTestPage")
        val sheetItems: MutableList<MenuActionSheetItem> = ArrayList()
        sheetItems.add(item)
        sheetItems.add(item1)
        sheetItems.add(item2)
        Log.i("unimp", "onCreate----")
        val config: DCSDKInitConfig = DCSDKInitConfig.Builder()
            .setCapsule(false)
            .setMenuDefFontSize("16px")
            .setMenuDefFontColor("#ff00ff")
            .setMenuDefFontWeight("normal")
            .setMenuActionSheetItems(sheetItems)
            .setEnableBackground(true) //开启后台运行
//            .setUniMPFromRecents(true)
            .build()
        DCUniMPSDK.getInstance().initialize(this, config
        ) { b -> Log.d("unimpaa", "onInitFinished----$b") }


    }

    override fun attachBaseContext(base: Context?) {
        MultiDex.install(base)
        super.attachBaseContext(base)
    }
}

五、创建wxapi文件夹(WXEntryActivity.kt和WXPayEntryActivity.kt,如果没有引用可以忽略)

kotlin 复制代码
// 包名/wxapi/WXEntryActivity.kt
class WXEntryActivity: AbsWXCallbackActivity() {
}

// 包名/wxapi/WXPayEntryActivity.kt
class WXPayEntryActivity: AbsWXPayCallbackActivity() {
}

六、修改MainActivity.kt

kotlin 复制代码
package com.airqirke.uni_demo

import android.content.Context
import android.os.Build
import android.os.Bundle
import android.os.Handler
import android.os.Looper
import android.widget.Toast
import androidx.activity.ComponentActivity
import androidx.activity.compose.setContent
import androidx.activity.enableEdgeToEdge
import androidx.compose.foundation.layout.Arrangement
import androidx.compose.foundation.layout.Column
import androidx.compose.foundation.layout.fillMaxSize
import androidx.compose.foundation.layout.padding
import androidx.compose.material3.Button
import androidx.compose.material3.Scaffold
import androidx.compose.material3.Text
import androidx.compose.runtime.Composable
import androidx.compose.ui.Alignment
import androidx.compose.ui.Modifier
import androidx.core.view.WindowCompat
import com.airqirke.uni_demo.ui.theme.Uni_demoTheme
import io.dcloud.feature.sdk.DCUniMPSDK
import io.dcloud.feature.sdk.Interface.IUniMP


class MainActivity : ComponentActivity() {
    var mContext: Context? = null
    var mHandler: Handler? = null

    /** unimp小程序实例缓存 */
    var mUniMPCaches: HashMap<String, IUniMP> = HashMap()
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        mContext = this
        mHandler = Handler(Looper.getMainLooper())
        if (Build.VERSION.SDK_INT >= 35) {
            val windowInsetsController = window.decorView.windowInsetsController
            val decorView = window.decorView
            val controller = if (windowInsetsController != null
            )  WindowCompat.getInsetsController(window, decorView)else null

            if (controller != null) {
                controller.isAppearanceLightStatusBars = true
                controller.isAppearanceLightNavigationBars = true
            }
        }
        enableEdgeToEdge()


        //用来测试sdkDemo 胶囊×的点击事件,是否生效;lxl增加的
        DCUniMPSDK.getInstance().setCapsuleCloseButtonClickCallBack { appid ->
            Toast.makeText(mContext, "点击×号了", Toast.LENGTH_SHORT).show()
            if (mUniMPCaches.containsKey(appid)) {
                val mIUniMP = mUniMPCaches[appid]
                if (mIUniMP != null && mIUniMP.isRuning) {
                    mIUniMP.closeUniMP()
                    mUniMPCaches.remove(appid)
                }
            }
        }
        setContent {
            Uni_demoTheme {
                Scaffold(modifier = Modifier.fillMaxSize()) { innerPadding ->
                    Greeting(
                        name = "Android",
                        modifier = Modifier.padding(innerPadding).fillMaxSize(),
                        onClick = {
                            try {
                                val uniMP = DCUniMPSDK.getInstance().openUniMP(mContext, "__UNI__F743940")
                                mUniMPCaches[uniMP.appid] = uniMP
                            } catch (e: Exception) {
                                e.printStackTrace()
                            }
                        }
                    )
                }
            }
        }
    }
}

@Composable
fun Greeting(name: String, modifier: Modifier = Modifier,onClick:()->Unit) {
    Column (
        modifier = modifier,
        verticalArrangement = Arrangement.Center,
        horizontalAlignment = Alignment.CenterHorizontally
    ){
        Text(
            text = "Hello $name!",
        )

        Button(onClick = {onClick()}) {
            Text(text = "Click me")
        }
    }
}
相关推荐
_一条咸鱼_22 分钟前
Android Runtime即时编译触发条件与阈值深度解析(38)
android·面试·android jetpack
webbin6 小时前
Compose @Immutable注解
android·android jetpack
webbin7 小时前
Compose 副作用
android·android jetpack
Wgllss1 天前
大型异步下载器:基于kotlin+Compose+协程+Flow+Channel实现多文件异步同时分片断点续传下载
android·架构·android jetpack
_一条咸鱼_1 天前
Android Runtime JIT编译器核心技术原理分析(36)
android·面试·android jetpack
_一条咸鱼_1 天前
Android Runtime异常处理与跳转指令实现源码(35)
android·面试·android jetpack
我命由我123452 天前
Android Studio 问题:Android Studio 一直开在 Updating indexes
android·java·ide·java-ee·android studio·android jetpack·android-studio
webbin2 天前
Android Compose 重组规则
android jetpack
alexhilton3 天前
在Android应用中实战Repository模式
android·kotlin·android jetpack
ljt27249606614 天前
Compose笔记(二十六)--DatePicker
笔记·android jetpack