当前位置: 首页 > news >正文

做金融的网站成人再就业技能培训班

做金融的网站,成人再就业技能培训班,网站登录页面制作,政府网站建设招标要求flutter开发实战-实现多渠道打包及友盟统计(亲测有效) 最近开发过程中,需要引入友盟进行统计服务。友盟统计还需要区分不同渠道的打开应用的情况,所以需要处理多渠道打包的问题。 一、引入友盟统计 在工程的pubspec.yaml中引入…

flutter开发实战-实现多渠道打包及友盟统计(亲测有效)

最近开发过程中,需要引入友盟进行统计服务。友盟统计还需要区分不同渠道的打开应用的情况,所以需要处理多渠道打包的问题。

一、引入友盟统计

在工程的pubspec.yaml中引入插件

  // 在工程 pubspec.yaml 中加入 dependencies:umeng_common_sdk: ^1.2.3

导入及调用初始化友盟

import 'package:umeng_common_sdk/umeng_common_sdk.dart';

调用友盟统计

@overridevoid initState() {super.initState();initPlatformState();UmengCommonSdk.initCommon('5e3f96f3cb23d2a070000048', '5e3f96f3cb23d2a070000048', 'Umeng');UmengCommonSdk.setPageCollectionModeManual();}

这里需要填写channel渠道名后续我们需要根据打包的渠道来设置。

二、flutter代码中获取渠道

Flutter命令工具增加了自定义参数的功能 --dart-define,可以用这个命令参数在打包或运行 App 时设置参数。

如:

flutter run --dart-define=CHANNEL=YYB

在lib/main.dart中定义变量配置,可以方便调用

/// 定义环境变量配置
class EnvironmentConfig {static const CHANNEL = String.fromEnvironment('CHANNEL');
}

在需要的地方调用获取渠道名

  String currentChannel = "";@overridevoid initState() {// TODO: implement initStatesuper.initState();// 获取CHANNEL 参数值String channel = EnvironmentConfig.CHANNEL;print("channel:${channel}");currentChannel = channel;setState(() {});}

显示渠道名

            Container(height: 136,width: 300,color: Colors.lightGreen,alignment: Alignment.center,child: Text('当前渠道:${currentChannel}',style: TextStyle(fontSize: 12, color: Colors.white),),),

最终获得渠道显示效果图如下

在这里插入图片描述

三、android中gradle配置

我们需要在android/app/build.gradle中添加一下配置


/// 获取渠道参数使用,这里设置一下默认值
def dartEnvironmentVariables = [CHANNEL: 'guanfang-app',
]if (project.hasProperty('dart-defines')) {dartEnvironmentVariables = dartEnvironmentVariables + project.property('dart-defines').split(',').collectEntries { entry ->def pair = new String(entry.decodeBase64(), 'UTF-8').split('=')[(pair.first()): pair.last()]}
}

在输出的apk中,添加对应渠道名,在android一下${dartEnvironmentVariables.CHANNEL}进行区分不同渠道的apk名称。

ext {publishName = 'AppDemoLab'
}android {android.applicationVariants.all {variant ->variant.outputs.all {def buildTime = new Date().format('yyyyMMddHHmm')outputFileName = "${project.publishName}_${variant.versionName}_${variant.versionCode}_${buildTime}_${variant.buildType.name}_${dartEnvironmentVariables.CHANNEL}.apk"}}
}

打包与测试命令

# 调试例子1:设置渠道为应用宝。
flutter run --dart-define=CHANNEL=YYB#打包例子1:打包应用宝渠道包
flutter build apk --dart-define=CHANNEL=YYB

可以是多个–dart-define,如:

#打包例子2:打包应用宝渠道包,DEBUG参数是Y
flutter build apk --dart-define=CHANNEL=YYB --dart-define=DEBUG=Y

四、apk.sh多渠道打包脚本

在脚本中定义了渠道channels=(YYB HUAWEI MI OPPO VIVO)

在工程目录下创建shell目录,将apk.sh放到shell目录下。
在工程目录下创建prod目录,prod目录下创建apk目录,用于存放打包的渠道apk文件

apk.sh多渠道打包脚本如下

#!/bin/sh#---------------------请修改渠道数组----------------#
channels=(YYB HUAWEI MI OPPO VIVO)#当前工程绝对路径
project_path=$(pwd)#安卓包product文件夹路径
prod_path=${project_path}/prod/apk/
#Flutter打包生成的最初地址
release_path=${project_path}/build/app/outputs/apk/release/clean_tips="执行flutter clean(默认:n) [ y/n ]"
echo $clean_tips
read  -t 5 is_clean
if [  ! -n "${is_clean}" ];thenis_clean="n"
fi
while([[ $is_clean != "y" ]] && [[ $is_clean != "n" ]])
doecho "错误!只能输入[ y/n ] !!!"echo $clean_tipsread is_clean
donetips="请输入选择渠道(默认:0) [ ALL: 0 "
c_length=${#channels[@]};
for(( i=0; i<$c_length; i++)) doif (($i < $c_length-1 )); thentips="${tips}${channels[i]}: $((i+1)) "elsetips="${tips}${channels[i]}: $((i+1)) ]"fi
done;echo $tips
read  -t 5 number
if [  ! -n "${number}" ];thennumber=0
fi
while(( $number < "0" || $number > $c_length ))
doecho "错误!只能输入0到${c_length} !!!"echo $tipsread number
done#如果有product/apk文件夹则删除,然后再创建一个空文件夹
if [ -d ${prod_path} ]; thenrm -rf ${prod_path}
fi
#创建目录
mkdir -p ${prod_path}if [ ${is_clean} = "y" ];thenecho "=============== 开始清理 ==============="flutter clean
fiif (($number == 0 )); thenecho "=============== 开始构建:全部渠道包 ==============="for(( i=0;i<${c_length};i++)) doecho "正在构建:${channels[$i]} 渠道包"flutter build apk --no-shrink --dart-define=CHANNEL=${channels[$i]}cp -R ${release_path}*.apk ${prod_path}done;
elseecho "=============== 正在构建:${channels[$((number-1))]} 渠道包 ==============="flutter build apk --no-shrink --dart-define=CHANNEL=${channels[$((number-1))]}cp -R ${release_path}*.apk ${prod_path}
fi#判断apk目录下是否有文件
if [ "$(ls -A $prod_path)" ]; thenecho "=============== APK包已导出:$prod_path ==============="open $prod_path
elseecho '=============== APK包导出失败 ==============='exit 1
fi
exit 0

查看脚本可以看出

控制是否执行flutter clean
输入是全部渠道打包
打包后的apk拷贝到prod/apk文件夹下。

通过cd切换到shell目录下,执行apk.sh脚本进行多渠道打包

./shell/papk.sh

在prod/apk目录下,可以看到打包的apk
在这里插入图片描述

参考:https://github.com/sugood/flutter_shell

五、更改友盟渠道

在文中,使用友盟时候,需要传递渠道名,我们通过EnvironmentConfig.CHANNEL拿到渠道名后作为参数传给友盟。
友盟即可根据渠道进行统计。

六、附录(完整的gradle配置)

android/build.gradle配置如下

buildscript {ext.kotlin_version = '1.7.10'repositories {maven { url "https://maven.aliyun.com/repository/google" }maven { url "https://maven.aliyun.com/repository/central" }maven { url "https://maven.aliyun.com/repository/jcenter" }}dependencies {classpath 'com.android.tools.build:gradle:7.2.0'classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"}
}allprojects {repositories {maven { url "https://maven.aliyun.com/repository/google" }maven { url "https://maven.aliyun.com/repository/central" }maven { url "https://maven.aliyun.com/repository/jcenter" }}
}rootProject.buildDir = '../build'
subprojects {project.buildDir = "${rootProject.buildDir}/${project.name}"
}
subprojects {project.evaluationDependsOn(':app')
}task clean(type: Delete) {delete rootProject.buildDir
}

android/app/build.gradle配置如下

def localProperties = new Properties()
def localPropertiesFile = rootProject.file('local.properties')
if (localPropertiesFile.exists()) {localPropertiesFile.withReader('UTF-8') { reader ->localProperties.load(reader)}
}def flutterRoot = localProperties.getProperty('flutter.sdk')
if (flutterRoot == null) {throw new GradleException("Flutter SDK not found. Define location with flutter.sdk in the local.properties file.")
}def flutterVersionCode = localProperties.getProperty('flutter.versionCode')
if (flutterVersionCode == null) {flutterVersionCode = '1'
}def flutterVersionName = localProperties.getProperty('flutter.versionName')
if (flutterVersionName == null) {flutterVersionName = '1.0'
}def keystoreProperties = new Properties()
def keystorePropertiesFile = rootProject.file('key.properties')
if (keystorePropertiesFile.exists()) {keystoreProperties.load(new FileInputStream(keystorePropertiesFile))
}/// 获取渠道参数使用,这里设置一下默认值
def dartEnvironmentVariables = [CHANNEL: 'GuanFang',
]if (project.hasProperty('dart-defines')) {dartEnvironmentVariables = dartEnvironmentVariables + project.property('dart-defines').split(',').collectEntries { entry ->def pair = new String(entry.decodeBase64(), 'UTF-8').split('=')[(pair.first()): pair.last()]}
}ext {publishName = 'AppDemoLab'
}apply plugin: 'com.android.application'
apply plugin: 'kotlin-android'
apply from: "$flutterRoot/packages/flutter_tools/gradle/flutter.gradle"android {compileSdkVersion 34ndkVersion flutter.ndkVersioncompileOptions {sourceCompatibility JavaVersion.VERSION_1_8targetCompatibility JavaVersion.VERSION_1_8}defaultConfig {// TODO: Specify your own unique Application ID (https://developer.android.com/studio/build/application-id.html).applicationId "com.example.flutter_app_demolab"// You can update the following values to match your application needs.// For more information, see: https://docs.flutter.dev/deployment/android#reviewing-the-gradle-build-configuration.minSdkVersion 21targetSdkVersion flutter.targetSdkVersionversionCode flutterVersionCode.toInteger()versionName flutterVersionNamendk {abiFilters "armeabi-v7a", "arm64-v8a"}}buildTypes {release {// TODO: Add your own signing config for the release build.// Signing with the debug keys for now, so `flutter run --release` works.signingConfig signingConfigs.debug}}android.applicationVariants.all {variant ->variant.outputs.all {def buildTime = new Date().format('yyyyMMddHHmm')outputFileName = "${project.publishName}_${variant.versionName}_${variant.versionCode}_${buildTime}_${variant.buildType.name}_${dartEnvironmentVariables.CHANNEL}.apk"}}
}flutter {source '../..'
}

七、小结

flutter开发实战-实现多渠道打包及友盟统计(亲测有效),根据自身需求调整后亲测有效,可以根据渠道来做一些代码上的区分。

学习记录,每天不停进步。

本文地址:https://brucegwo.blog.csdn.net/article/details/138907985

快快微信扫码玩一玩小游戏吧

战机长空小绳套牛
在这里插入图片描述在这里插入图片描述

文章转载自:
http://parthenogenone.kryr.cn
http://hebe.kryr.cn
http://falsely.kryr.cn
http://suit.kryr.cn
http://iktas.kryr.cn
http://bladdernose.kryr.cn
http://rerun.kryr.cn
http://percentage.kryr.cn
http://hegelian.kryr.cn
http://wither.kryr.cn
http://coelome.kryr.cn
http://deceiver.kryr.cn
http://wriggler.kryr.cn
http://serfhood.kryr.cn
http://androphagous.kryr.cn
http://crowning.kryr.cn
http://sylvics.kryr.cn
http://parlormaid.kryr.cn
http://blousy.kryr.cn
http://conductivity.kryr.cn
http://cartoon.kryr.cn
http://sexivalent.kryr.cn
http://consolute.kryr.cn
http://immovability.kryr.cn
http://minicoy.kryr.cn
http://lebanese.kryr.cn
http://cinemascope.kryr.cn
http://restful.kryr.cn
http://confiscable.kryr.cn
http://negotiatory.kryr.cn
http://photoeffect.kryr.cn
http://accuse.kryr.cn
http://italian.kryr.cn
http://corequake.kryr.cn
http://pumpkin.kryr.cn
http://trap.kryr.cn
http://noncountry.kryr.cn
http://malathion.kryr.cn
http://phototactic.kryr.cn
http://pre.kryr.cn
http://warsaw.kryr.cn
http://net.kryr.cn
http://cardiant.kryr.cn
http://scrouge.kryr.cn
http://unsuccessful.kryr.cn
http://coccoid.kryr.cn
http://scap.kryr.cn
http://mesomorphic.kryr.cn
http://ramulose.kryr.cn
http://reptilarium.kryr.cn
http://precipitant.kryr.cn
http://shortcoat.kryr.cn
http://sightseer.kryr.cn
http://generable.kryr.cn
http://dechristianize.kryr.cn
http://listless.kryr.cn
http://speciation.kryr.cn
http://unharden.kryr.cn
http://brd.kryr.cn
http://philotechnical.kryr.cn
http://glazed.kryr.cn
http://bootload.kryr.cn
http://canton.kryr.cn
http://disembarrassment.kryr.cn
http://daunt.kryr.cn
http://quail.kryr.cn
http://droughty.kryr.cn
http://homolecithal.kryr.cn
http://juglandaceous.kryr.cn
http://linden.kryr.cn
http://tenuis.kryr.cn
http://therezina.kryr.cn
http://unsuitable.kryr.cn
http://reverse.kryr.cn
http://fluorouracil.kryr.cn
http://felicitate.kryr.cn
http://formularize.kryr.cn
http://photokinesis.kryr.cn
http://einkanter.kryr.cn
http://canonry.kryr.cn
http://defervescence.kryr.cn
http://cocytus.kryr.cn
http://nelly.kryr.cn
http://trappy.kryr.cn
http://bacillus.kryr.cn
http://trajectory.kryr.cn
http://codex.kryr.cn
http://foreplay.kryr.cn
http://copycutter.kryr.cn
http://euhemerist.kryr.cn
http://mrcp.kryr.cn
http://xylotomous.kryr.cn
http://scaldingteass.kryr.cn
http://fashionist.kryr.cn
http://yolky.kryr.cn
http://extrasensory.kryr.cn
http://creator.kryr.cn
http://ignominy.kryr.cn
http://decontaminate.kryr.cn
http://applicably.kryr.cn
http://www.15wanjia.com/news/68269.html

相关文章:

  • 做网站怎样收费的网站排名seo软件
  • 进一步优化政治生态网站seo外链建设
  • wordpress安装 linux黑河seo
  • 做英文网站多少钱百度指数平台
  • 网站域名管理规范乐事薯片软文推广
  • 怎么做网页版手机版网站免费下载百度到桌面
  • 做网站.net和php哪个简单网络推广的概念
  • 公众号菜单跳转的网页怎么制作成都seo的方法
  • 网站建设 采集百度seo学院
  • 建设网站实训心得竞价是什么意思
  • 网站开发好还是app好百度云建站
  • 党的建设网站建设方案广州seo网站推广
  • 沈阳做网站的公司天津seo公司
  • 怎么自己做整人网站网课培训机构排名前十
  • 个人网站开发制作教程免费推广的app有哪些
  • mac电脑用什么软件做网站浙江网络推广
  • 网站域名注册如何填写杭州网站优化
  • 自己的服务器如何做网站全网最好的推广平台
  • 做一年的网站能赚多少钱网络代运营推广
  • 网站经营内容百度网页浏览器
  • 网站建设 漳州互联网广告推广好做吗
  • 举例说明网络营销的概念河南网站排名优化
  • php网站设计要学多久全网营销公司排名前十
  • 长治专业做网站龙岩seo
  • 普陀区网站建设销售怎么做
  • 南昌谁做网站设计口碑最好的it培训机构
  • 网站刷收益是怎么做的百度网盘登录首页
  • 西安建设工程信息网站上海网站关键词排名优化报价
  • wordpress插件audio player亚马逊关键词快速优化
  • 做教育培训网站公司优化软件有哪些