小程序十:媒体组件

audio


属性名 类型 默认值 说明
action Object   控制音频的播放、暂停,播放速率、播放进度的对象,有method和data两个参数
src String   要播放音频的资源地址
loop Boolean false 是否循环播放
controls Boolean true 是否显示默认控件
poster String   默认控件上的音频封面的图片资源地址,如果controls属性值为false则设置poster无效
name String 未知音频 默认控件上的音频名字,如果controls属性值为false则设置name无效
author String 未知作者 默认控件上的作者名字,如果controls属性值为false则设置author无效
binderror EventHandle   当发生错误时触发error事件,detail = {errMsg: MediaError.code}
bindplay EventHandle   当开始/继续播放时触发play事件
bindpause EventHandle   当暂停播放时触发pause事件
bindratechange EventHandle   当播放速率改变时触发ratechange事件
bindtimeupdate EventHandle   当播放进度改变时触发timeupdate事件,detail = {currentTime, duration}
bindended EventHandle   当播放到末尾时触发ended事件

MediaError.code

返回错误码 描述
MEDIA_ERR_ABORTED 获取资源被用户禁止
MEDIA_ERR_NETWORD 网络错误
MEDIA_ERR_DECODE 解码错误
MEDIA_ERR_SRC_NOT_SUPPOERTED 不合适资源

Action

method 描述 data
play 播放  
pause 暂停  
setPlaybackRate 调整速度 倍速
setCurrentTime 设置当前时间 播放时间

示例代码:

action的method属性只能是play、pause、setPlaybackRate、setCurrentTime,用法如下:

index.wxml:

<audio poster="{{poster}}" name="{{name}}" author="{{author}}" src="http://qqma.tingge123.com:823/mp3/2015-06-13/1434188181.mp3" action="{{action}}" controls loop></audio>  

<button type="primary" bindtap="audioPlay">播放</button>
<button type="primary" bindtap="audioPause">暂停</button>
<button type="primary" bindtap="audioPlaybackRateSpeedUp">调为2倍速</button>
<button type="primary" bindtap="audioPlaybackRateNormal">调为1倍速</button>
<button type="primary" bindtap="audioPlaybackRateSlowDown">调为0.5倍速</button>
<button type="primary" bindtap="audio14">设置当前播放时间为14秒</button>
<button type="primary" bindtap="audioStart">回到开头</button>  

index.js:

Page({
  data: {
    poster: ‘http://pic.pimg.tw/pam86591/1408719752-3322564110_n.jpg‘,
    name: ‘Sugar‘
    author: ‘Maroon 5‘
  },
  audioPlay: function () {
    this.setData({
      action: {
        method: ‘play‘
      }
    });
  },
  audioPause: function () {
    this.setData({
      action: {
        method: ‘pause‘
      }
    });
  },
  audioPlaybackRateSpeedUp: function () {
    this.setData({
      action: {
        method: ‘setPlaybackRate‘,
        data: 2
      }
    });
  },
  audioPlaybackRateNormal: function () {
    this.setData({
      action: {
        method: ‘setPlaybackRate‘,
        data: 1
      }
    });
  },
  audioPlaybackRateSlowDown: function () {
    this.setData({
      action: {
        method: ‘setPlaybackRate‘,
        data: 0.5
      }
    });
  },
  audio14: function () {
    this.setData({
      action: {
        method: ‘setCurrentTime‘,
        data: 14
      }
    });
  },
  audioStart: function () {
    this.setData({
      action: {
        method: ‘setCurrentTime‘,
        data: 0
      }
    });
  }
})  

image



图片资源

属性名 类型 默认值 说明
src String   图片资源地址
mode String ‘scaleToFill‘ 图片裁剪、缩放的模式
binderror HandleEvent   当错误发生时,发布到AppService的事件名,事件对象event.detail = { errMsg: ‘something wrong‘ }
bindload HandleEvent   当图片载入完毕时,发布到AppService的事件名,事件对象event.detail = {}

注:image标签认宽度300px、高度225px

mode有12种模式,其中3中是缩放模式,9种是裁剪模式。

缩放模式:

模式 说明
scaleToFill 不保持纵横比缩放图片,使图片的宽高完全拉伸至填满image元素
aspectFit 保持纵横比缩放图片,使图片的长边能完全显示出来。也就是说,可以完整地将图片显示出来。
aspectFill 保持纵横比缩放图片,只保证图片的短边能完全显示出来。也就是说,图片通常只在水平或垂直方向是完整的,另一个方向将会发生截取。

裁剪模式:

模式 说明
top 不缩放图片,只显示图片的顶部区域
bottom 不缩放图片,只显示图片的底部区域
center 不缩放图片,只显示图片的中间区域
left 不缩放图片,只显示图片的左边区域
right 不缩放图片,只显示图片的右边区域
top left 不缩放图片,只显示图片的左上边区域
top right 不缩放图片,只显示图片的右上边区域
bottom left 不缩放图片,只显示图片的左下边区域
bottom right 不缩放图片,只显示图片的右下边区域

示例:

index.wxml:

<view class="page">
  <view class="page__hd">
    <text class="page__title">image</text>
    <text class="page__desc">图片</text>
  </view>
  <view class="page__bd">
    <view class="section section_gap" wx:for-items="{{array}}" wx:for-item="item">
      <view class="section__title">{{item.text}}</view>
      <view class="section__ctn">
        <image style="width: 200px; height: 200px; background-color: #eeeeee;" mode="{{item.mode}}" src="{{src}}"></image>
      </view>
    </view>
  </view>
</view>  

index.js:

Page({
  data: {
    array: [{
      mode: ‘scaleToFill‘,
      text: ‘scaleToFill:不保持纵横比缩放图片,使图片完全适应‘
    }, {
      mode: ‘aspectFit‘,
      text: ‘aspectFit:保持纵横比缩放图片,使图片的长边能完全显示出来‘
    }, {
      mode: ‘aspectFill‘,
      text: ‘aspectFill:保持纵横比缩放图片,只保证图片的短边能完全显示出来‘
    }, {
      mode: ‘top‘,
      text: ‘top:不缩放图片,只显示图片的顶部区域‘
    }, {
      mode: ‘bottom‘,
      text: ‘bottom:不缩放图片,只显示图片的底部区域‘
    }, {
      mode: ‘center‘,
      text: ‘center:不缩放图片,只显示图片的中间区域‘
    }, {
      mode: ‘left‘,
      text: ‘left:不缩放图片,只显示图片的左边区域‘
    }, {
      mode: ‘right‘,
      text: ‘right:不缩放图片,只显示图片的右边边区域‘
    }, {
      mode: ‘top left‘,
      text: ‘top left:不缩放图片,只显示图片的左上边区域‘
    }, {
      mode: ‘top right‘,
      text: ‘top right:不缩放图片,只显示图片的右上边区域‘
    }, {
      mode: ‘bottom left‘,
      text: ‘bottom left:不缩放图片,只显示图片的左下边区域‘
    }, {
      mode: ‘bottom right‘,
      text: ‘bottom right:不缩放图片,只显示图片的右下边区域‘
    }],
    src: ‘../../resources/cat.jpg‘
  },
  imageError: function(e) {
    console.log(‘image3发生error事件,携带值为‘, e.detail.errMsg)
  }
})  

video



视频播放器

属性名 类型 默认值 说明
hidden Boolean false 设置视频的显示/隐藏,hidden值为true表示隐藏,值为false表示显示
src String   要播放视频的资源地址
binderror EventHandle   当发生错误时触发error事件,event.detail = { errMsg: ‘something wrong‘ }

video标签认宽度300px、高度225px,设置宽高需要通过wxss设置width和height。

示例代码:

index.wxml:

<view class="section tc">
    <video src="http://wxsnsdy.tc.qq.com/105/20210/snsdyvideodownload?filekey=30280201010421301f0201690402534804102ca905ce620b1241b726bc41dcff44e00204012882540400&bizid=1023&hy=SH&fileparam=302c020101042530230204136ffd93020457e3c4ff02024ef202031e8d7f02030f42400204045a320a0201000400" binderror="videoErrorCallback"></video>
</view>  

<view class="section tc">
    <video src="{{src}}"></video>
    <view class="btn-area">
        <button bindtap="bindButtonTap">获取视频</button>
    </view>
</view>  

index.js:

Page({
    data:{
        src:""
    },
    bindButtonTap:function(){
        var that = this;
        wx.chooseVideo({
            sourceType:[‘album‘,‘camera‘],
            maxDuration:60,
            camera:[‘front‘,‘back‘],
            success:function(res){
                that.setData({
                    src:res.tempFilePath
                })
            }
        })
    },
    videoErrorCallback: function (e) {
        console.log(‘视频错误信息:‘);
        console.log(e.detail.errMsg);
    }
})  
时间: 2024-10-09 08:39:54

小程序十:媒体组件的相关文章

小程序聊天会话组件

效果图 场景 用于在线客服的聊天对话等 一.布局圈点 1.三角箭头 绘制一个26rpx*26rpx矩形,使它旋转45度,然后隐去对半,形成气泡上的直角三角形. <!-- 画三角箭头 --> <view class="triangle" style="{{item.myself == 1 ? 'right: 140rpx; background: #7ECB4B' : 'left: 140rpx;'}}"></view> /* 三角

小程序解决方案 Westore - 组件、纯组件、插件开发

数据流转 先上一张图看清 Westore 怎么解决小程序数据难以管理和维护的问题: 非纯组件的话,可以直接省去 triggerEvent 的过程,直接修改 store.data 并且 update,形成缩减版单向数据流. Github: https://github.com/dntzhang/westore 组件 这里说的组件便是自定义组件,使用原生小程序的开发格式如下: Component({ properties: { }, data: { }, methods: { } }) 使用 Wes

微信小程序_基础组件大全

微信小程序_基础组件 微信小程序为小程序开发者提供了一系列小程序基础组件,开发者可以通过组合这些小程序基础组件进行微信小程序的快速开发. 微信小程序组件是什么?微信小程序组件怎么用? 小程序组件是视图层的基本组成单元.小程序组件自带一些功能与微信风格的样式.一个小程序组件通常包括开始标签和结束标签,属性用来修饰这个组件,内容在两个标签之内. <tagname property="value"> Content goes here ... </tagename>

「小程序JAVA实战」小程序的基础组件(24)

转自:https://idig8.com/2018/08/12/xiaochengxu-chuji-24/ 来说下 ,小程序的基础组件.源码:https://github.com/limingios/wxProgram.git 中的No.11 基础组件 icon图标组件 rich-text 富文本组件 text 文本组件 progress 进度条组件 icon图标组件 官方介绍>https://developers.weixin.qq.com/miniprogram/dev/component/

微信小程序导入Vant-Weapp组件库及出错处理

微信小程序导入Vant-Weapp组件库及出错处理一.下载Node.js*链接:https://nodejs.org/en/推荐选择LST的8.0以上版本,下载安装即可,安装完成后可以进行验证cmd打开终端,输入vant-v出现对应版本即为安装成功,也可输入npm -v查看对应的npm版本 二.在微信开发工具做对应操作 链接:https://youzan.github.io/vant-weapp/#/intro 后续可根据开发指南进行操作 三.安装Vant组件库选中miniprogram文件,右

微信小程序wx.request组件的那些坑

最近在做一个教育的在线发布系统,打算用微信小程序做前端,后端用php的CI框架,这两天把CI框架的基本功能已经啃完,因为手册比较完善,所以按照逻辑走一边就通了. 反观微信小程序,帮助代码不多,对于一些没接触过前端和js开发的新手来说,很多流程和细节都会拿不准. 1.这两天遇到最大的困扰就是wx.request组件如何从php服务器端取回数据并显示在小程序界面上,这里涉及到一个通信, 因为小程序目前的机构和框架都是基于ajax异步交互的基础上的,所以要懂得小程序的数据读写功能,首先要了解ajax的

微信小程序简易table组件实现

前提:微信小程序自1.6.3基础库版本库开始支持简洁组件,之前的版本因不支持,故在引用组件处默认为空节点.关于微信小程序已有模板为何还需构建组件?一是因为组件可以更方便的自定义并绑定行为,二是在其他页面引用时,无需通过import,只需在该页面json文件下配置usingComponents属性即可.(原本想在app.json文件里配置这个属性,从此一劳永逸,但目前貌似还不支持,至少我尝试的时候还不行-.-) 思路:主要是将table的head和tbody部分的数据抽象出来,使之只需要传值就可直

小程序canvas截图组件

最近做一个小程序的过程中,需要用到截图功能,网上搜了一下,发现没有符合要求的,就自己搞了个组件,方便复用. 目前功能很简单,传入宽高和图片路径即可,宽高是为了计算截图的比例,只支持缩放和移动. 实现思路是: 1.模拟一个截取框:2.移动图片位置,缩放图片:3.获取图片在其中的位置(left,top,width,height):4.使用canvas绘制图片,然后截取就ok了. 其中第二步的缩放图片比较麻烦,缩放中心点以及平滑缩放 以下是我的实现方式 wxml: <!--component/picP

微信小程序覆盖自定义组件样式

小程序官方文档明确指出,引入的第三方自定义组件,是不可以对其进行CSS样式覆盖的,但是我们还想要修改怎么办呢?自定义组件时会之定义个外部类,通过这个外部类来修改样式. 修改https://weapp.iviewui.com/所提供的组件样式为例,它定义了一个外部类接口: 1. 通过第三方组件给出的externalClasses: ['i-class'],来指定自己的样式类 自己的wxml i-class="myrate" <i-rate i-class="myrate&

微信小程序——自定义图标组件

字体图标在网页中非常常见了.为了方便在小程序里面重复使用,自定义了一个图标组件,方便控制它的大小,颜色,自定义点击事件. 自定义图标组件的代码如下: 下面的代码是icon文件夹下面的4个文件 index.wxml: <view class="custom-class ss-font ss-icon-{{ name }}" style="{{ color ? 'color: ' + color : '' }}; {{ size ? 'font-size: ' + size