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

制作网站哪里好机器人网站建设规划书

制作网站哪里好,机器人网站建设规划书,wordpress怎么做背景,tp5企业网站开发flutter开发实战-video_player视频播放功能及视频缓存 最近开发过程中video_player播放视频#xff0c; 一、引入video_player 在pubspec.yaml引入video_player video_player: ^2.7.0在iOS上#xff0c;video_player使用的是AVPlayer进行播放。 在Android上#xff0c;…flutter开发实战-video_player视频播放功能及视频缓存 最近开发过程中video_player播放视频 一、引入video_player 在pubspec.yaml引入video_player video_player: ^2.7.0在iOS上video_player使用的是AVPlayer进行播放。 在Android上video_player使用的是ExoPlayer。 二、使用前设置 2.1 在iOS中的设置 在iOS工程中info.plist添加一下设置以便支持HttpsHTTP的视频地址 keyNSAppTransportSecurity/key dictkeyNSAllowsArbitraryLoads/keytrue/ /dict2.2 在Android中的设置 需要在/android/app/src/main/AndroidManifest.xml文件中添加网络权限 uses-permission android:nameandroid.permission.INTERNET/三、使用前设置video_player video_player 使用VideoPlayerController来控制播放与暂停 VideoPlayerController的初始化 _controller VideoPlayerController.networkUrl(Uri.parse(https://flutter.github.io/assets-for-api-docs/assets/videos/bee.mp4))..initialize().then((_) {// Ensure the first frame is shown after the video is initialized, even before the play button has been pressed.setState(() {});});显示视频Widget Center(child: _controller.value.isInitialized? AspectRatio(aspectRatio: _controller.value.aspectRatio,child: VideoPlayer(_controller),): Container(),),控制播放与暂停 // 播放 _controller.play();// 暂停 _controller.pause();完整实例代码 import package:flutter/material.dart; import package:video_player/video_player.dart;void main() runApp(const VideoApp());/// Stateful widget to fetch and then display video content. class VideoApp extends StatefulWidget {const VideoApp({super.key});override_VideoAppState createState() _VideoAppState(); }class _VideoAppState extends StateVideoApp {late VideoPlayerController _controller;overridevoid initState() {super.initState();_controller VideoPlayerController.networkUrl(Uri.parse(https://flutter.github.io/assets-for-api-docs/assets/videos/bee.mp4))..initialize().then((_) {// Ensure the first frame is shown after the video is initialized, even before the play button has been pressed.setState(() {});});}overrideWidget build(BuildContext context) {return MaterialApp(title: Video Demo,home: Scaffold(body: Center(child: _controller.value.isInitialized? AspectRatio(aspectRatio: _controller.value.aspectRatio,child: VideoPlayer(_controller),): Container(),),floatingActionButton: FloatingActionButton(onPressed: () {setState(() {_controller.value.isPlaying? _controller.pause(): _controller.play();});},child: Icon(_controller.value.isPlaying ? Icons.pause : Icons.play_arrow,),),),);}overridevoid dispose() {super.dispose();_controller.dispose();} }注意video_player暂时不支持缓存如果需要可以使用flutter_cache_manager 四 缓存flutter_cache_manager下载文件 使用flutter_cache_manager代码如下 import package:flutter_cache_manager/flutter_cache_manager.dart; import dart:async; import dart:typed_data; import package:file/file.dart; import package:flutter_suprisebox/utils/string_utils.dart;class CustomCacheManager {static const key customCacheKey;static CacheManager instance CacheManager(Config(key,stalePeriod: const Duration(days: 7),maxNrOfCacheObjects: 20,repo: JsonCacheInfoRepository(databaseName: key),fileService: HttpFileService(),),);FutureFile getSingleFile(String url, {String? key,MapString, String? headers,}) async {return await instance.getSingleFile(url, key: key, headers: headers);}FutureFileInfo? getFileFromCache(String url,{bool ignoreMemCache false}) async {String? key StringUtils.toMD5(url);if (key ! null key.isNotEmpty) {return await instance.getFileFromCache(key, ignoreMemCache: ignoreMemCache);}return null;}FutureFileInfo downloadFile(String url,{String? key,MapString, String? authHeaders,bool force false}) async {return await instance.downloadFile(url, key: key, authHeaders: authHeaders, force: force);}StreamFileResponse getFileStream(String url,{String? key, MapString, String? headers, bool withProgress false}) {return instance.getFileStream(url,key: key, headers: headers, withProgress: withProgress);}Futurevoid removeFile(String key) async {return instance.removeFile(key);}/// Removes all files from the cacheFuturevoid emptyCache() {return instance.emptyCache();} }添加flutter_cache_manager后flutter_cache_manager会先判断文件是否存在如果不存在则下载视频文件。 使用CustomCacheManager后的视频初始化代码如下 Futurevoid stuVideoPlay() async {_controller?.dispose();if (Platform.isIOS) {_controller VideoPlayerController.network(widget.videoUrl);} else {FileInfo? fileInfo await CustomCacheManager().getFileFromCache(widget.videoUrl);if (fileInfo null) {fileInfo await CustomCacheManager().downloadFile(widget.videoUrl);// if (fileInfo ! null) {_controller VideoPlayerController.file(fileInfo.file);// } else {// _controller VideoPlayerController.network(widget.videoUrl);// }} else {var file await CustomCacheManager().getSingleFile(widget.videoUrl);_controller VideoPlayerController.file(file);}}await _controller?.initialize().then((_) {// Ensure the first frame is shown after the video is initialized, even before the play button has been pressed.setState(() {});});await _controller!.setLooping(true);if (widget.autoPlay) {await _controller?.play();} else {await _controller?.pause();}}特别注意我使用的时候flutter_cache_manager好像暂时不支持iOS。这点可能还需要其他方案来做缓存处理。如果支持了请留言哦也可能我记错了。 四、小结 flutter开发实战-video_player视频播放功能及视频缓存。video_player播放视频flutter_cache_manager处理视频缓存。 学习记录每天不停进步。
http://www.pierceye.com/news/355535/

相关文章:

  • 毕业设计网站建设选题依据设计公司网站应该包括的信息
  • wordpress 仪表板主题seo网站排名厂商定制
  • 网站建设成本报表wordpress缺点
  • 外贸建站选择哪个服务器好免费自动生成二维码
  • 建设部申请自己网站c 做网站设计
  • 软件制作网站网站维护合同模板
  • 那家财经网站做的好陕西网站建设公司哪有
  • 淄川网站建设中小型企业网站建设
  • phpcms 投资 网站源码wordpress主题网站
  • 聊城网站托管义乌外贸公司联系方式
  • 开发一个小程序对网站做综合搜索引擎优化分析
  • 网站开发自学网有哪些企业可以做招聘的网站有哪些
  • 网站怎么做百度推广网站开发者模式
  • 学校网站设计制作目的做网站推广方法
  • wordpress建站云平台小程序商城开发平台
  • pc网站转换成微网站网站建设开发哪家质量好
  • wordpress网站使用教程aspnet东莞网站建设多少钱
  • 网站地图提交给百度证券公司如何拉客户
  • 做外贸有哪些免费的网站win7优化大师好不好
  • 网站功能怎么写上海网站制作建设怎么样
  • 网站域名是网站架构吗成都网站搭建优化推广
  • 自己做的网站添加交费功能合肥有什么好的网站建设公司好
  • 做网站品牌龙岩新增病例行动轨迹
  • 任家房网站建设郑州百度网站推广
  • 深圳建设网站的公司简介WordPress多功能投稿
  • 简述织梦网站上传及安怎样在网站上做免费的推广
  • 关于信用体系建设的网站wordpress新闻类模板下载
  • 免费行情软件网站下载大全爱学校vi设计案例
  • 网站外包优化怎样做免费抽皮肤的网站
  • 东八区网站建设网站源码在哪里