flutter與原生Android通信方式之MethodChannel

閑來無事,flutter好久沒看了,上次折騰flutter與Android通信沒折騰完,有些事情耽擱了,這次繼續

演示效果:

flutter與Android原生通信

flutter端

import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart';
import 'package:flutter/services.dart';
class LikePages extends StatefulWidget {const LikePages({super.key});@overrideState<LikePages> createState() => _LikePagesState();
}class _LikePagesState extends State<LikePages> {final MethodChannel _channel = MethodChannel('abc');
// Flutter 調用 Android 方法Future<void> callNativeMethod() async {try {final String result = await _channel.invokeMethod('getPlatformVersion');print('Result from Android: $result');} catch (e) {print('Error calling native method: $e');}}Future<void> callNativeOpenCameraMethod() async {try {final String result = await _channel.invokeMethod('openCamera');print('Result from Android: $result');} catch (e) {print('Error calling native method: $e');}}@overrideWidget build(BuildContext context) {return Scaffold(appBar: AppBar(title: Text('like'),),body: Column(children: [Center(child: GestureDetector(child: Text('like'),onTap: (){// 調用 Flutter 調用 Android 方法callNativeMethod();},),),Padding(padding: const EdgeInsets.all(80.0),child: Center(child: GestureDetector(child: Text('openCamare'),onTap: (){// 調用 Flutter 調用 Android 方法callNativeOpenCameraMethod();},),),),],),);}
}
Android端
package com.example.f4import android.content.Context
import android.content.ContextWrapper
import android.content.Intent
import android.graphics.Bitmap
import android.net.Uri
import android.os.Build.VERSION
import android.os.Bundle
import android.provider.MediaStore
import android.util.Log
import android.widget.Toast
import androidx.annotation.NonNull
import androidx.annotation.Nullable
import com.hjq.permissions.OnPermissionCallback
import com.hjq.permissions.Permission
import com.hjq.permissions.XXPermissions
import io.flutter.embedding.android.FlutterActivity
import io.flutter.embedding.engine.FlutterEngine
import io.flutter.plugin.common.MethodChannel
import java.io.File
import java.io.FileOutputStream
import java.io.IOException
import java.util.*class MainActivity: FlutterActivity() {private val CHANNEL = "abc"private val REQUEST_IMAGE_CAPTURE = 1private val PERMISSION_REQUEST_CODE = 200var resultOut:MethodChannel.Result?=nulloverride fun onCreate(savedInstanceState: Bundle?) {super.onCreate(savedInstanceState)XXPermissions.with(this) // 申請單個權限.permission(Permission.CAMERA) // 申請多個權限.permission(Permission.Group.CALENDAR) // 設置權限請求攔截器(局部設置)//.interceptor(new PermissionInterceptor())// 設置不觸發錯誤檢測機制(局部設置)//.unchecked().request(object : OnPermissionCallback {override fun onGranted(permissions: List<String>, allGranted: Boolean) {if (!allGranted) {
//                        Toast(this@MainActivity,"獲取部分權限成功,但部分權限未正常授予",Toast.LENGTH_SHORT).show()return}
//                    toast("獲取錄音和日歷權限成功")}override fun onDenied(permissions: List<String>, doNotAskAgain: Boolean) {if (doNotAskAgain) {
//                        toast("被永久拒絕授權,請手動授予錄音和日歷權限")// 如果是被永久拒絕就跳轉到應用權限系統設置頁面XXPermissions.startPermissionActivity(context, permissions)} else {
//                        toast("獲取錄音和日歷權限失敗")}}})}override fun configureFlutterEngine(@NonNull flutterEngine: FlutterEngine) {super.configureFlutterEngine(flutterEngine)// 創建 MethodChannelMethodChannel(flutterEngine.dartExecutor.binaryMessenger, CHANNEL).setMethodCallHandler { call, result ->// 處理 Flutter 調用 Android 方法if (call.method == "getPlatformVersion") {result.success("Android ${VERSION.RELEASE}")}else if (call.method=="openCamera"){Log.e("TAG","call.method:="+call.method);resultOut = resultdispatchTakePictureIntent()} else {result.notImplemented()}}}// 獲取真實路徑的函數private fun getRealPathFromUri(uri: Uri): String? {val projection = arrayOf(MediaStore.Images.Media.DATA)val cursor = contentResolver.query(uri, projection, null, null, null)return cursor?.use {val columnIndex = it.getColumnIndexOrThrow(MediaStore.Images.Media.DATA)it.moveToFirst()it.getString(columnIndex)}}fun saveBitmapToFile(context: Context, bitmap: Bitmap): String {val cw = ContextWrapper(context)val directory: File = cw.getDir("images", Context.MODE_PRIVATE)// 為文件生成唯一的名稱val imageName = "img_${UUID.randomUUID()}.jpg"// 創建文件對象val file = File(directory, imageName)var fos: FileOutputStream? = nulltry {fos = FileOutputStream(file)bitmap.compress(Bitmap.CompressFormat.JPEG, 100, fos) // 將 Bitmap 壓縮為 JPEG 格式} catch (e: IOException) {e.printStackTrace()} finally {try {fos?.close()} catch (e: IOException) {e.printStackTrace()}}// 返回文件的路徑return file.absolutePath}override fun onActivityResult(requestCode: Int, resultCode: Int,data: Intent) {super.onActivityResult(requestCode, resultCode, data)Log.e("TAG","==-->${data.extras}"+"  resultCode:=$resultCode "+" requestCode:$requestCode ")if (requestCode == REQUEST_IMAGE_CAPTURE && resultCode == RESULT_OK) {// 圖片從相機返回val extras = data.extrasif (extras != null) {// 獲取拍攝的照片val imageBitmap = extras.get("data") as Bitmap?// 保存 Bitmap 到文件并獲取文件路徑val imagePath = imageBitmap?.let { saveBitmapToFile(applicationContext, it) }// 在這里使用文件路徑resultOut?.success(imagePath)}} else {Toast.makeText(this, "Failed to capture image", Toast.LENGTH_SHORT).show()}}private fun dispatchTakePictureIntent() {val takePictureIntent = Intent(MediaStore.ACTION_IMAGE_CAPTURE)if (takePictureIntent.resolveActivity(packageManager) != null) {startActivityForResult(takePictureIntent, REQUEST_IMAGE_CAPTURE)}}
}

上述代碼演示了直接獲取Android版本號,以及調用Android原生拍照并發揮圖片路徑到Flutter的方式,至于為什么會想要搞搞這個,原因還是在與Flutter插件的穩定性問題,假如要實現一個功能,但是受限于Flutter插件自身的問題,就只能自己來實現了,這時候通過原生代碼返回需要的數據就不失為一種解決方案,

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/166970.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/166970.shtml
英文地址,請注明出處:http://en.pswp.cn/news/166970.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

ThreeJs實現簡單的動畫

上一節實現可用鼠標控制相機的方式實現動態效果&#xff0c;但很多時候是需要場景自己產恒動態效果&#xff0c;而不是通過鼠標拖動&#xff0c;此時引入一個requestAnimationFrame方法&#xff0c;它實際上是通過定時任務的方式&#xff0c;每隔一點時間改變場景中內容后重新渲…

筆記:如何搭建一套前端監控系統?(持續更新中)

數據敏感處理 數據加密&#xff0c;對涉及用戶隱私的數據做到加密防護 獨立部署&#xff0c;不和其它應用共享監控系統 不采集具體數據&#xff0c;只采集用戶操作數據 錯誤采集 Runtime Error: JS運行錯誤&#xff0c;可通過error監聽器捕獲 load Error: 資源加載錯誤&#x…

Ant Design Vue 樹形表格計算盈收金額

樹形表格計算 一、盈收金額計算1、根據需要輸入的子級位置&#xff0c;修改數據2、獲取兄弟節點數據&#xff0c;并計算兄弟節點的金額合計3、金額合計&#xff0c;遍歷給所有的父級 一、盈收金額計算 1、根據需要輸入的子級位置&#xff0c;修改數據 2、獲取兄弟節點數據&am…

銷售管理系統的實用性怎么樣?

銷售管理系統好用嗎&#xff1f;好用&#xff0c;銷售管理系統可以管理銷售流程、自動化大量重復性工作&#xff0c;讓銷售人員從瑣碎的任務中掙脫出來&#xff0c;投入到客戶跟進和維護客戶關系之中。那么&#xff0c;CRM系統的好用體現在哪些方面&#xff1f; 1.加速銷售流程…

react中的state

沒想到hooks中也有state這一說法 看下面的兩個案例 1、無state變化不會執行父子函數 2、有state更改執行父子函數

CDN加速在網站搭建中的必要性與優勢分析

隨著互聯網的快速發展&#xff0c;網站已經成為企業展示和用戶交互的主要平臺。在構建一個高性能、用戶體驗良好的網站時&#xff0c;CDN&#xff08;內容分發網絡&#xff09;的應用變得愈發重要。本文將從網站搭建的角度出發&#xff0c;深入分析CDN加速的必要性以及在提升網…

深度學習之六(自編碼器--Autoencoder)

概念 自編碼器(Autoencoder)是一種神經網絡架構,用于無監督學習和數據的降維表示。它由兩部分組成:編碼器(Encoder)和解碼器(Decoder)。 結構: 編碼器(Encoder): 接收輸入數據并將其壓縮為潛在表示(latent representation),通常比輸入數據的維度要低。編碼器的…

最詳細的軟件測試面試題整理與分析

前言 時光荏苒&#xff0c;一轉眼到了2023年末尾&#xff0c;2024年也快要來了&#xff0c;人員就業市場以往的寒冬也貌似有了轉暖的跡象&#xff0c;身邊大批的就業人員也開始了緊張的備戰之中。 近幾周也和多家合作公司的HR進行了溝通&#xff0c;發現雖然崗位就業情況較去年…

vue3中引入svg矢量圖

vue3中引入svg矢量圖 1、前言2、安裝SVG依賴插件3、在vite.config.ts 中配置插件4、main.ts入口文件導入5、使用svg5.1 在src/assets/icons文件夾下引入svg矢量圖5.2 在src/components目錄下創建一個SvgIcon組件5.3 封裝成全局組件&#xff0c;在src文件夾下創建plugin/index.t…

SQLserver 數據庫導入MySQL的方法

原文&#xff1a; https://blog.csdn.net/lht631935612/article/details/132086172#httpspanbaiducoms1TlLiRI9stxqTcwBJ5p6UAE993BEE68EA5EFBC9Ahttpspanbaiducoms1TlLiRI9stxqTcwBJ5p6UA2020E68F90E58F96E7A081EFBC9Av6d5_font_colordd0000v6d5font_8 下載鏈接&#xff1a;…

使用openfeign調用下載流的文件不完整的替代方案

OpenFeign是一種聲明式的Web服務客戶端&#xff0c;它使得編寫HTTP客戶端變得更加簡單和直觀。它使用了注解方式來描述HTTP API&#xff0c;使得開發者可以使用Java接口來調用遠程HTTP服務。 OpenFeign的核心特點包括&#xff1a; 聲明式API: 您可以使用注解聲明要調用的遠程AP…

一鍵創新 | 拓世法寶AI智能直播一體機激發房產自媒體創造力

在數字化時代&#xff0c;房產銷售已然不再是傳統的模式。隨著社交媒體和自媒體的興起&#xff0c;短視頻直播成為房產自媒體營銷的新風口。然而&#xff0c;行業也面臨著諸多挑戰&#xff0c;如何更好地利用新媒體拓展市場&#xff0c;提升自媒體效果成為擺在業內人士面前的難…

JMeter測試報錯422 Unprocessable Entity

添加HTTP信息頭&#xff1a; ? HTTP請求-》添加-〉配置元件-》HTTP信息頭管理器 ? 如果需要送json&#xff0c;需要添加Content-Type:application/json&#xff0c;否則會報【422 Unprocessable Entity】

好用的CRM系統到底有多重要?怎么選?

我們都知道&#xff0c;CRM軟件可以讓企業效率加倍。但如果選錯了CRM&#xff0c;企業損失點錢是小&#xff0c;客戶轉化率下降才是大。下面我們就來說說&#xff0c;市面上有哪些好用的CRM&#xff1f;以及好用的CRM軟件的重要性。 好用的CRM軟件的重要性&#xff1a; 客戶管…

Qt 軟件調試(一) Log日志調試

終于這段時間閑下來了&#xff0c;可以系統的編寫Qt軟件調試的整個系列。前面零零星星的也有部分輸出&#xff0c;但終究沒有形成體系。借此機會&#xff0c;做一下系統的總結。慎獨、精進~ 日志是有效幫助我們快速定位&#xff0c;找到程序異常點的實用方法。但是好的日志才能…

百度 文心一言 sdk 試用

JMaven Central: com.baidu.aip:java-sdk (sonatype.com) Java sdk地址如上&#xff1a; 文心一言開發者 文心一言 (baidu.com) ERNIE Bot SDK https://yiyan.baidu.com/developer/doc#Fllzznonw ERNIE Bot SDK提供便捷易用的接口&#xff0c;可以調用文心一言的能力&#…

口袋參謀:如何避免寶貝被降權?這招屢試屢爽!

?至少99.99999%的店鋪在今年都被降權過&#xff01;各家店鋪被降權的原因&#xff0c;無非就一個原因&#xff0c;那就是s單&#xff01; s單的風險也就兩種&#xff0c;一是操作問題&#xff0c;二是賬號問題。 操作問題被降權&#xff0c;這個大家都心知肚明&#xff0c;s…

5大原因,設備校準為什么是實驗室搬遷后的首要任務?

實驗室搬遷是一個復雜而緊張的過程。要考慮的事情太多&#xff0c;很容易忽視您最重要的任務之一——檢查設備在新環境中的性能。 校準對于確保設備安全運行和遵守監管標準至關重要。 1.保持合規性并遵守法律要求 生物技術和制藥等行業有特定的校準要求&#xff0c;實驗室必…

Java詳解之I/O[BIO、NIO、AIO使用方法和示范代碼]

前言&#xff1a; 小弟能力不足&#xff0c;認知有限&#xff0c;難免考慮不全面&#xff0c;希望大佬能給出更好的建議&#xff0c;指出存在的問題和不足&#xff0c;在此跪謝。 IO發展史 Java中對于I/O能力的支持主要分為三個比較關鍵的階段&#xff1a; BIO 第一個階段…

淺談安科瑞直流電表在印尼某基站的應用

摘要&#xff1a;本文介紹了安科瑞直流電表在印尼的應用。主要用于印尼某基站的電流電壓電能的計量&#xff0c;配合霍爾傳感器對基站進行計量。 Abstract: This article introduces the application of Acrel DC meters in base station in Indonesia.The device is measuri…