• 0755-82538016
  • 0755-82560826
  • 深圳网站建设_APP小程序开发_博纳网络

    • 网站建设案例
      • ";

        营销网站建设

        全网营销网站

        高端网站建设

        商城网站建设

        外贸网站建设

        小程序开发

        区块链开发

        物联网项目开发

        定制app开发

        在线教育网站

        速成网站建设

        服装网站建设

        餐饮网站建设

        珠宝首饰网站

        机械制造网站

        文化旅游网站

        家装建材网站

        美容化妆品网站

        数码产品网站

        模板案例库

        联系电话:0755-82560826 82538016 82560635邮箱:qin@198bona.com地址:深圳市福田区皇岗路5007神采苑402栋610
    • 网站推广
      • ";

        网站优化基础

        建站优化

        网站优化

        营销推广

        整站优化

        推广帮助

        谷歌搜索

        推广方案

        推广套餐

        推广技巧

        百度排名

        巧用微博推广

        直播视频网站推广法

        微信推广网站方法

        网站外链推广

        公共微信号推广

        网站优化闲谈

        常见问题

        公司资讯

        联系电话:0755-82560826 82538016 82560635邮箱:qin@198bona.com地址:深圳市福田区皇岗路5007神采苑402栋610
    • 网站制作资讯
      • ";

        网站制作

        外贸网站建设

        网站设计

        网站代运营

        深圳网站建设专栏

        深圳小程序开发

        网站改版

        APP开发

        网站建设方案

        安全维护

        软件开发

        平台搭建

        建站行业资讯

        域名注册

        虚拟主机

        企业邮局

        国外主机

        VPS独享空间

        免备案香港服务器

        如何解析域名

        联系电话:0755-82560826 82538016 82560635邮箱:qin@198bona.com地址:深圳市福田区皇岗路5007神采苑402栋610
    • 网站报价
      • ";

        网站报价

        建站方案

        联系电话:0755-82560826 82538016 82560635邮箱:qin@198bona.com地址:深圳市福田区皇岗路5007神采苑402栋610
    • 公司动态
      • ";
        联系电话:0755-82560826 82538016 82560635邮箱:qin@198bona.com地址:深圳市福田区皇岗路5007神采苑402栋610
    • 关注博纳
      • ";

        网站制作精英团队

        网站建设公司愿景

        公司介绍

        主营业务

        博纳文化

        加入博纳

        联系电话:0755-82560826 82538016 82560635邮箱:qin@198bona.com地址:深圳市福田区皇岗路5007神采苑402栋610
    • 联系我们
      • ";

        网站建设公司联系方式

        网站建设、网站制作公司乘车路线

        联系电话:0755-82560826 82538016 82560635邮箱:qin@198bona.com地址:深圳市福田区皇岗路5007神采苑402栋610
      网站制作资讯

      当前位置:

        主页网站制作资讯APP开发视频类APP开发是怎样解决添加视频进度条的

      视频类APP开发是怎样解决添加视频进度条的

      发布时间:2019-07-04

      文章编辑:网站建设 文章来源:APP开发 浏览量:次

        视频类APP开发是怎样解决添加视频进度条的?深圳APP开发公司本例将完成给自定义播放器添加进度条的工作。一共会添加两种进度条,分别为下载进度条和播放进度条。使用Chrome浏览器打开网页文件,点击屏幕中央的三角播放按钮,播放器底部出现自定义工具条,同时进度条慢慢地向右伸长,运行效果如图3.7所示。
      图3.7中的蓝色进度条表示播放时间,灰色条表示视频下载进度。将鼠标悬浮于进度条之上,此时进度条上方会出现对应的时间提示框,效果如图3.8所示。
      本例的代码构建在“3-5.添加视频进度条.html”的功能基础之上。下面对增添的代码部分做一个分析。字符串模板CONTROLS_HTML增加进度条HTML结构,代码如下:
      '<div class=" control progress_ control">' + // 进度 条 外围 层 '<div class=" progress_ bar_ bg"></ div>' + // 进度 条 背景 层 '<div class=" progress_ bar_ buffered"></ div>' + //
      // 下载 进度 条 层 '<div class=" progress_ bar_ played"></ div>' + // 播放 进度 条 层 '<div class=" progress_ bar_ time">' + // 悬浮 提示 外围 层 '<div class=" progress_ bar_ time_ line"></ div>' + '<div class=" progress_ bar_ time_ txt"> 00: 00</ div>' + // 悬浮 时间 提示 '</div>' + '</div>' +
      APP开发公司提示HTML模板对应的CSS可以参考源码。视频工具类VideoControl的prototype原型上增加_progress和_bartime方法。其中_progress方法用于控制下载进度条的移动,代码如下:
      _progress: function () { // 控制 下载 进度 条 var self = this, video = self. video, // 实例 上 的video 属性 video_ ele = video. get( 0), // 视频 的 原生 元素 progress_ bar = self. wraper. find(' div. progress_ control'), // 进度 条 外围 元素 progress_ bar_ buffered = self. wraper. find(' div. progress_ bar_ buffered');// 下载 进度 条 元素 video. on({ 'progress': function (e) { // 监听 video 的 下载 进度 事件 if (this. buffered && this. buffered. length) { // 判断 是否 开始 接收 数据 var percent = video_ ele. buffered. end( 0) / video_ ele. duration; // 下载 数据 相对 总 时间 百分比 progress_ bar_ buffered. width( percent * progress_ bar. width()); // 设置 下载 进度 条 长度 }; } }); },
      video的buffered属性返回1个TimeRanges对象。TimeRanges对象表示音视频的已缓冲部分,对象具有1个length属性,表示音视频中已缓冲范围的数量,同时还具有两个方法,即start和end,语法如下:
      video. buffered. start( index); // 获得 某个 已 缓冲 范围 的 开始 位置 video. buffered. end (index); // 获得 某个 已 缓冲 范围 的 结束 位置
      _bartime方法用于实现鼠标悬浮进度条的时间提示,代码如下:
      _bartime: function () { // 鼠标 悬浮 进度 条 的 时间 提示 var wraper = this. wraper, progress_ control = wraper. find(' div. progress_ control'),// 进度 条 外围 元素 progress_ bar_ bg = wraper. find(' div. progress_ bar_ bg'), // 进度 条 背景 层 progress_ bar_ time = wraper. find(' div. progress_ bar_ time'), // 时间 悬浮 提示 层 外框 progress_ bar_ time_ txt = wraper. find(' div. progress_ bar_ time_ txt'), video_ ele = this. video. get( 0); // 悬浮 提示 时间 元素 progress_ bar_ bg. on({ // 绑 定 进度 条 背景
      'mousemove': function (e) { var offsetX = e. clientX - progress_ bar_ bg. offset(). left, // 相对于 进度 条 横轴 距离 percent = offsetX / progress_ bar_ bg. width(); progress_ bar_ time. css(' left', offsetX + 6); // 设置 时间 浮动 框 位置 progress_ bar_ time_ txt. html( timeFormat(( percent * video_ ele. duration)|| 0)); }, 'mouseenter': function (){ progress_ bar_ time. show(); },// 移入 显示 时间 提醒 'mouseleave': function (){ progress_ bar_ time. hide(); }// 移出 隐藏 时间 提醒 }); }
      最后,完成播放进度条的动态更新功能,修改原型方法_timeupdate,代码如下:
      this. video. on({ 'timeupdate': function () { // 视频 播放 位置 变动 时 触发 currentTime. html( timeFormat( video. currentTime)); // 当前
      播放 时间 动态 更新 var percent = video. currentTime / video. duration; // 播放 时间 占 总 时间 百分比 progress_ bar_ played. width( percent * progress_ bar. width()); // 设置 播放 进度 条 宽度 }, 'loadedmetadata': function () { // 视频 元 数据 加载 完毕 后 触发 duration. html( timeFormat( video. duration)); } });
      在上面的代码中,将之前监听video的play事件换为loadedmetadata事件,是为了保证视频的元数据下载完毕后再设置视频总耗时,避免在play事件触发时获取video的duration属性为空。提示视频的元素据包含时长、尺寸(仅视频)以及文本轨道等信息。好了,APP开发公司本文关于“视频类APP开发是怎样解决添加视频进度条的”的相关APP制作知识我们就分享到这里,谢谢关注,博纳网络编辑整理。
       

      当前文章链接:/construction/appkaifa/3070.html
      上一篇:APP开发Git工具的使用 下一篇:APP开发Git工具的常用命令及使用时的注意事项
      返回列表
      如果您觉得案例还不错请帮忙分享:

      [声明]本网转载网络媒体稿件是为了传播更多的信息,此类稿件不代表本网观点,本网不承担此类稿件侵权行为的连带责任。故此,如果您发现本网站的内容侵犯了您的版权,请您的相关内容发至此邮箱【qin@198bona.com 】,我们在确认后,会立即删除,保证您的版权。

      相关案例推荐

      • 蓓多康官网

        蓓多康官网

        企业网站

        蓓多康官网

      • 千岛湖秀水节

        千岛湖秀水节

        政府教育

        千岛湖秀水节

      • 爱吉尔电子集团网站建设

        爱吉尔电子集团网站建设

        集团网站

        爱吉尔电子集团网站建设

      资讯分类

      • 网站制作
      • 外贸网站建设
      • 网站设计
      • 网站代运营
      • 深圳网站建设专栏
      • 深圳小程序开发
      • 网站改版
      • APP开发
      • 网站建设方案
      • 安全维护
      • 软件开发
      • 平台搭建
      • 建站行业资讯
      • 域名注册
      • 虚拟主机
      • 企业邮局
      • 国外主机
      • VPS独享空间
      • 免备案香港服务器
      • 如何解析域名

      最新发布

      • 社区APP开发上线后影响用户使用的粘性有哪些?
      • 为什么说大健产业O2OAPP开发潜力无限
      • 网络公司对社区O2OAPP开发基本认识
      • 工业4.0时代怎样做好一个APP的开发工作?
      • APP开发公司分析APP应用开发下一个巨头在哪些领域?
      • APP电子商务平台开发前景如何?
      • 社交类型APP开发需要具备的五个必要条件
      • 社交类型APP平台开发使用小程序还是APP模式好?
      • 使用HTML语言开发APP商城可以吗?
      • 社区O2OAPP开发的方向选择

      相关资讯

      • APP网站制作流程以及栏目分布
      • 企业网站优化人员面对搜索引擎的困惑
      • 企业门户网站如何做好针对搜索引擎的优化工作
      • APP/PC购物商城网站如何做好产品图片的优化技巧
      • 网站软文内容以及网站外链存在的几种形式对网站有多大影响
      • 如何做好网站软文标题的描述更适合搜索引擎的需要?
      • 网站建设好后期出现被搜索引擎降权的几个主要因素
      • 小程序开发制作前途取决于市场,别被您的同行抢了先机
      • APP开发公司提醒您关注:电商平台要求商家“二选一”引多方不满 专家提建议
      • APP为什么会在我们的手机界面上变成僵尸图标?

      热门搜索

      • 商城网站建设
      • 公司网站制作
      • 网站开发
      • 网站制作
      • 小程序开发
      • APP开发
      • 模板网站建设
      • 设计
      • tP代运营
      • 网站建设公司

      Copyright © 2021 博纳网络 版权所有  粤ICP备17054727号

      • 🏠

        首页

      • 💬

        咨询

      • 📞

        通话

      • 📂

        案例

      • ⬆

        返回