当前位置: 首页 > 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.pierceye.com/news/10687/

相关文章:

  • 图书馆网站建设情况汇报杭州网站定制开发哪家好
  • 深圳网站建设官网各大网站投稿方式
  • 钓鱼网站生成器床品图案设计网站
  • 美食网站开发计划网站集约化建设会议请示
  • 朝阳网站建设怎么样安徽工程建设信息网新网站
  • 太原做彩票网站公司中石油第六建设公司网站
  • 长沙建站找有为太极就治就网站能给企业带来什么
  • 西部数码成品网站在线看国内永久免费crm
  • 网站建设从哪几个情况去判品牌网站建设策划方案
  • 外贸行销网站做正规网站
  • 求网站网页设计图片叠加
  • 鲅鱼圈做网站wordpress菜单显示用户
  • 网站建站网站91955在线流程图网站怎么做
  • 建设部网站官网证书编号软文文案
  • 站酷网官方入口网页版设计网站公司咨询亿企邦
  • 网站开发项目运营经理岗位职责知名网站有哪些?
  • 电商网站建设行业现状凡科做网站在百度能看见吗
  • wordpress链接数据库文件夹百度seo优化排名
  • 成都新都建设银行网站个人网站的设计与实现参考文献
  • 做平面设计用什么网站素材多海外sns网站
  • 服装网站建设配色网站源码区别
  • 文化馆网站建设方案腾讯企业邮箱手机登录入口
  • 滕州网站建设公司图案logo设计
  • 做seo为什么要了解网站俐侎族网站建设背景
  • 响应式网站哪里做优惠网站怎么做
  • 关岭县建设局网站百度售后服务电话人工
  • html网站首页图片切换中山网红粥
  • 好用的网站开发软件公司网站没做301怎么做301
  • 新手做外贸怎么入门随州网站seo诊断
  • 微信小程序网站开发教程整站优化提升排名