flutter 更新apk

Dart 复制代码
import 'package:path_provider/path_provider.dart';   //app_installer: ^1.0.0
import 'package:app_installer/app_installer.dart';    //path_provider

 //查询是否更新
  Future<void> ifUpdate(BuildContext buildContext) async {
    String jsonFlag = await LocalStorage.get("apkJson");
    var s = jsonFlag;
    var dio = Dio();
    final response = await dio.get(s);
    print(response.data);
    if(response.data != null){
      setState(() {

      });
      apkJson = response.data;   //json格式{"version":"3.0.1","outputFile":"http://192.168.200.201/test/news.apk","versionName":"ydhl"}
    }
    PackageInfo packageInfo = await PackageInfo.fromPlatform();
    //如果你设置的版本号 于你本机上的App的版本号 不一致 弹出下载框
    if (apkJson["version"] != "packageInfo.version") {
      print(packageInfo.version);
      Msg.dlg(context: context,title: "版本不是最新版,请确定是否更新").then((value)=>{
        if(value == ""){
          _installApk(apkJson["outputFile"])
          // download2()
        }
      });
    }else{
      toast("已是最新版");
    }
  }
Dart 复制代码
/// 下载安卓更新包
  Future downloadAndroid(String url) async {
    /// 创建存储文件
    Directory storageDir = await getExternalStorageDirectory();
    String storagePath = storageDir.path;
    final directory = await getTemporaryDirectory();
    File file = new File("${storageDir.path}/ydhl.apk");

    if (!file.existsSync()) {
      file.createSync();
    }
    try {
      /// 发起下载请求

      Response response = await Dio().download(url,file.path,
          options: Options(
            followRedirects: false,
          ),onProgress: (int count, int total){
            if (total != -1) {
              //更新界面进度
              _value = count / total;
              print("------"+_value.toString());
              setState(() {
                _value =_value;
              });
            }
          });
      // file.writeAsBytesSync(response.data);
      return file;
    } catch (e) {
      showError("下载失败");
      debugPrint(e.toString());
      setState(() {

      });
    }
  }
Dart 复制代码
/// 安装apk
  Future _installApk(String url) async {
    File _apkFile = await downloadAndroid(url);
    String _apkFilePath = _apkFile.path;

    if (_apkFilePath.isEmpty) {
      print("make sure the apk file is set");
      return;
    }
    AppInstaller.installApk(_apkFilePath)
        .then((ell){
      toast("下载成功");
    }).catchError((e){
      showError("install apk error: $e");
    });
  }

更新界面

与界面都在stack中

Dart 复制代码
Visibility(
          visible: (_value*100).toInt() != 0 && (_value*100).toInt() != 100,
          child: Stack(
            children: [
              Container(
                height: double.infinity,
                width: double.infinity,
                color: Colors.black12,
              ),
              Center(
                child: Column(
                  mainAxisAlignment: MainAxisAlignment.center,
                  crossAxisAlignment: CrossAxisAlignment.center,
                  children: [
                    Container(
                      child: Text("下载中...",style: TextStyle(
                        color: Colors.blue,
                          decoration: TextDecoration.none
                      ),),
                    ),
                    SizedBox(height: 10,),
                    SizedBox(
                      height: 20,
                      width: 300,
                      child: ClipRRect(
                        borderRadius: const BorderRadius.all(Radius.circular(100)),
                        child: LinearProgressIndicator(
                          value: _value,
                          backgroundColor: const Color(0xFF7E7F88).withOpacity(0.15),
                          valueColor: const AlwaysStoppedAnimation<Color>(Colors.green),
                        ),
                      ),
                    ),
                  ],
                ),
              ),
            ],
          ),
        ),
相关推荐
百锦再1 小时前
五种常用的web加密算法
前端·算法·前端框架·web·加密·机密
@大迁世界1 小时前
彻底改变我 React 开发方式的组件模式
前端·javascript·react.js·前端框架·ecmascript
William Dawson2 小时前
【Vue 3 + Element Plus 实现产品标签的动态添加、删除与回显】
前端·javascript·vue.js
拉不动的猪2 小时前
项目基础搭建时的一些基本注意点
前端·javascript·面试
蕉君桑2 小时前
vue2使用vue-echarts
前端·vue.js·echarts
runnerdancer2 小时前
React+Vite+Typescript项目脚手架模版
前端
louisgeek2 小时前
Flutter StatelessWidget 和 StatefulWidget 的区别
flutter
Code额3 小时前
ECMAScript 6 新特性(二)
前端·javascript·ecmascript
JarvanMo3 小时前
Flutter插件中引用aar
flutter
群联云防护小杜3 小时前
基于AI的Web应用防火墙(AppWall)实战:漏洞拦截与威胁情报集成
前端·分布式·安全·ddos