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

网站排名哪家好做平面设计哪个网站下载素材好

网站排名哪家好,做平面设计哪个网站下载素材好,做美食网站的目的意义,尚海整装总店地址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.huolong8.cn/news/59440/

相关文章:

  • 怎样大力开发公司网站建设wordpress 4.5.2 编辑器插件
  • 网站建设的课程都需要什么网站建设数据库实训体会
  • 天河岗顶棠下上社网站建设备份核验单时网站域名
  • 静态html网址网站导航源码商城型网站建设
  • 网站 只收录首页wordpress模板排行榜
  • 企业品牌网站建设定制开发wordpress页脚插件
  • 梅州英文网站建设wordpress在线文件管理插件
  • 做医疗科普的网站网站添加背影音乐怎么做
  • 视频网站用户增长怎么做html怎么做游戏
  • 东莞网站建设优化手机访问网站下面电话怎么做
  • 亲 怎么给一个网站做备份网站地址栏图标怎么做
  • 商城网站要多少钱学广告设计好就业吗
  • 网站右侧分享插件网站建设 部署与发布题库
  • 网站系统开发企业网站建设 招标 评分表
  • 网站建设设计大作业可以做海报的网站
  • 网站开发人员是做什么的系统官网网站模板下载
  • 商品推广文案南通优化网站公司
  • 恐怖网站代码树莓派怎么打开 wordpress
  • 网站开发是用什么语言兰州格罗互联网技术服务有限公司
  • 怎样修改网站关键词网站内页做排名
  • 设计网页与创建网站吗漯河北京网站建设
  • 网站建立多少钱扬州网站建设icp备
  • 好看的个人网站设计网站logo怎么做最清楚
  • 小说网站开发猪八戒如何注册一个域名
  • 外贸网站的公司介绍视觉设计网站建设
  • 国外设计参考网站苏州网站建设上往建站
  • 网站网站建设专业营销团队建设与管理
  • 餐饮团购网站建设地产设计网站
  • 静态网站站内搜索宁波网站建设的过程
  • 模板网站建设流程图html企业网站模板下载