欢迎光临,了解微信小程序开发,就上易用通!

微信小程序把玩《十三》:获取设备信息 API,navigation API,animation API ...

发布:2018-01-26 14:58浏览: 来源:网络 作者:cola

一:获取设备信息 API

微信小程序把玩《十三》:获取设备信息 API,navigation API,animation API ...(图1)

获取设备信息这里分为四种,

主要属性:

  • 网络信息wx.getNetWorkType, 

    微信小程序把玩《十三》:获取设备信息 API,navigation API,animation API ...(图2)

  • 系统信息wx.getSystemInfo,

微信小程序把玩《十三》:获取设备信息 API,navigation API,animation API ...(图3)

  • 重力感应数据wx.onAccelerometerChange,

微信小程序把玩《十三》:获取设备信息 API,navigation API,animation API ...(图4)

  • 罗盘数据wx.onCompassChange

微信小程序把玩《十三》:获取设备信息 API,navigation API,animation API ...(图5)

wxml

<button type="primary" bindtap="getNetWorkType">获取网络类型</button>
<button type="primary" bindtap="getSystemInfo">获取设备信息</button>
<button type="primary" bindtap="onAccelerometerChange">监听重力感应数据</button>
<button type="primary" bindtap="onCompassChange">监听罗盘数据</button>
  • 1
  • 2
  • 3
  • 4
  • 1
  • 2
  • 3
  • 4

js

Page({
  data:{
    text:"Page system"
  },
  onLoad:function(options){
    // 页面初始化 options为页面跳转所带来的参数
  },
  /**
   * 获取当前网络状态
   */
  getNetWorkType: function() {
    wx.getNetworkType({
      success: function(res) {
        console.log(res)
      }
    })
  },

  /**
   *  获取系统信息
   */
  getSystemInfo: function() {
    wx.getSystemInfo({
      success: function(res) {
        console.log(res)
      }
    })
  },
  /**
   *  监听重力感应数据     
   *      - 带on开头的都是监听接收一个callback
   */
  onAccelerometerChange: function() {
    wx.onAccelerometerChange(function(res) {
      console.log(res)
    })
  },
    /**
   *  监听罗盘数据
   */
  onCompassChange: function() {
    wx.onCompassChange(function(res) {
      console.log(res)
    })
  },
  onReady:function(){
    // 页面渲染完成
  },
  onShow:function(){
    // 页面显示
  },
  onHide:function(){
    // 页面隐藏
  },
  onUnload:function(){
    // 页面关闭
  }
})
二:navigation API

微信小程序把玩《十三》:获取设备信息 API,navigation API,animation API ...(图6)

 

主要属性:

导航条一些方法

wx.setNavigationBarTitle(object) 设置导航条的Title

导航标题可以通过三种方式设置,第一种是通过全局配置名字统一,第二种就是在page中新建个json文件配置它会覆盖全局配置的title,第三种就是通过API设置。

  • 微信小程序把玩《十三》:获取设备信息 API,navigation API,animation API ...(图7)

wx.showNavigationBarLoading()设置在导航条上显示Loading加载状态

wx.hideNavigationBarLoading() 隐藏Loading加载状态

导航视图的一些方法

wx.navigateTo() 保留当前页面进行跳转,传参时就像拼接GET参数一样即可,代码中会有体现

  • 微信小程序把玩《十三》:获取设备信息 API,navigation API,animation API ...(图8)

wx.redirectTo() 销毁当前页面进行跳转,

  • 微信小程序把玩《十三》:获取设备信息 API,navigation API,animation API ...(图9)

wx.navigateBack() 返回上一个页面

wxml

<button type="primary" bindtap="setNavigationBarTitle">设置navigationBarTitle</button>
<button type="primary" bindtap="showNavigationBarLoading">设置navigationBarLoading加载状态</button>
<button type="primary" bindtap="hiddenNavigationBarLoading">隐藏navigationBarLoading加载状态</button>
<button type="warn" bindtap="navigateTo"> 保留当前页跳转</button>
<button type="warn" bindtap="redirectTo"> 不保留当前页面跳转</button>
<button type="warn" bindtap="navigateBack">退回到上一个页面</button>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

json

{
    "navigationBarTitleText": "我是通过json配置的title"
}
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3

js

var file = '../audio/audio'
Page({
  data:{
    text:"Page navigation"
  },
  onLoad:function(options){
    // 页面初始化 options为页面跳转所带来的参数
  },
  /**
   * 设置NavigationTitle
   */
  setNavigationBarTitle: function() {
    wx.setNavigationBarTitle({
      title: '我是通过API设置的NavigationBarTitle'
    })
  },

  /**
   * 设置加载状态
   */
  showNavigationBarLoading: function() {
    wx.showNavigationBarLoading()
  },

  /**
   * 隐藏加载状态
   */
  hiddenNavigationBarLoading: function() {
    wx.hideNavigationBarLoading()
  },

  /**
   * 保留当前Page跳转
   */
  navigateTo: function() {
    wx.navigateTo({
      //传递参数方式向get请求拼接参数一样
      url: file + '?phone=18939571&password=1992',
      success: function(res) {
        console.log(res)
      },
      fail: function(err) {
        console.log(err)
      }

    })
  },
  /**
   * 关闭当前页面进行跳转当前页面会销毁
   */
  redirectTo: function() {
    wx.redirectTo({
       //传递参数方式向get请求拼接参数一样
      url: file + '?phone=189395719&password=1992'
    })
  },
  /**
   * 退回到上一个页面
   */
  navigateBack: function() {
    wx.navigateBack()
  },
  onReady:function(){
    // 页面渲染完成
  },
  onShow:function(){
    // 页面显示
  },
  onHide:function(){
    // 页面隐藏
  },
  onUnload:function(){
    // 页面关闭
  }
})
 
三:animation API

动画水还是比较深的,这里只是简单介绍下小程序中动画的一些属性和注意事项,做动画前一定要整理好思路将动画一步步分解,再进行组合!这里只做引入。

wx.createAnimation(object)

  • 看官方介绍

    • 1.创建一个动画实例animation。调用实例的方法来描述动画。最后通过动画实例的export方法导出动画数据传递给组件的animation属性。

    • 2.调用动画操作方法后要调用 step() 来表示一组动画完成,可以在一组动画中调用任意多个动画方法,一组动画中的所有动画会同时开始,一组动画完成后才会进行下一组动画。step 可以传入一个跟 wx.createAnimation() 一样的配置参数用于指定当前组动画的属性

这还是比较好理解的比如第一条对应代码animation: this.animation.export() 
第二条比如缩放动画,也就说是一组scale,scaleX, scaleY…为一缩放动画组的一个动画方法,缩放动画组和旋转动画组通过step()链接,按顺序执行。代码中体验吧!看效果反过来看会更容易理解

主要属性:

微信小程序把玩《十三》:获取设备信息 API,navigation API,animation API ...(图10)

这里主要树下timingFunction和transformOrigin

  • timingFunction 设置动画效果

    • linear 默认为linear 动画一直较为均匀
    • ease 开始时缓慢中间加速到快结束时减速
    • ease-in 开始的时候缓慢
    • ease-in-out 开始和结束时减速
    • ease-out 结束时减速
    • step-start 动画一开始就跳到 100% 直到动画持续时间结束 一闪而过
    • step-end 保持 0% 的样式直到动画持续时间结束 一闪而过
  • transformOrigin 设置动画的基点 默认%50 %50 0

    • left,center right是水平方向取值,对应的百分值为left=0%;center=50%;right=100%
    • top center bottom是垂直方向的取值,其中top=0%;center=50%;bottom=100%

动画组及动画方法

样式:

微信小程序把玩《十三》:获取设备信息 API,navigation API,animation API ...(图11)

旋转:

微信小程序把玩《十三》:获取设备信息 API,navigation API,animation API ...(图12)

缩放:

微信小程序把玩《十三》:获取设备信息 API,navigation API,animation API ...(图13)

偏移:

微信小程序把玩《十三》:获取设备信息 API,navigation API,animation API ...(图14)

倾斜:

微信小程序把玩《十三》:获取设备信息 API,navigation API,animation API ...(图15)

矩阵变形:

微信小程序把玩《十三》:获取设备信息 API,navigation API,animation API ...(图16)

演示单个动画组效果

微信小程序把玩《十三》:获取设备信息 API,navigation API,animation API ...(图17)

wxml

<view class="container">
  <view animation="{{animation}}" class="view">我在做动画</view>
</view>
<button type="primary" bindtap="rotate">旋转</button>
  •  

js

Page({
  data:{
    text:"Page animation",
    animation: ''
  },
  onLoad:function(options){
    // 页面初始化 options为页面跳转所带来的参数
  },
  onReady:function(){
    // 页面渲染完成
    //实例化一个动画
    this.animation = wx.createAnimation({
      // 动画持续时间,单位ms,默认值 400
      duration: 1000, 
      /**
       * https://cubic-bezier.com/#0,0,.58,1  
       *  linear  动画一直较为均匀
       *  ease    从匀速到加速在到匀速
       *  ease-in 缓慢到匀速
       *  ease-in-out 从缓慢到匀速再到缓慢
       * 
       *  https://www.tuicool.com/articles/neqMVr
       *  step-start 动画一开始就跳到 100% 直到动画持续时间结束 一闪而过
       *  step-end   保持 0% 的样式直到动画持续时间结束        一闪而过
       */
      timingFunction: 'linear',
      // 延迟多长时间开始
      delay: 100,
      /**
       * 以什么为基点做动画  效果自己演示
       * left,center right是水平方向取值,对应的百分值为left=0%;center=50%;right=100%
       * top center bottom是垂直方向的取值,其中top=0%;center=50%;bottom=100%
       */
      transformOrigin: 'left top 0',
      success: function(res) {
        console.log(res)
      }
    })
  },

  /**
   * 旋转
   */
  rotate: function() {
    //顺时针旋转10度
    //
    this.animation.rotate(150).step()
    this.setData({
      //输出动画
      animation: this.animation.export()
    })
  },

  onShow:function(){
    // 页面显示
  },
  onHide:function(){
    // 页面隐藏
  },
  onUnload:function(){
    // 页面关闭
  }
})
  •  

演示多个动画组效果

微信小程序把玩《十三》:获取设备信息 API,navigation API,animation API ...(图18)

这里我们只需要更改以下代码即可

  /**
   * 旋转
   */
  rotate: function() {
    //两个动画组 一定要以step()结尾
    /**
     * 动画顺序 顺时针旋转150度>x,y 放大二倍>x,y平移10px>x,y顺时针倾斜>改变样式和设置宽度宽度
     */
    this.animation.rotate(150).step().scale(2).step().translate(10).step().skew(10).step().opacity(0.5).width(10).step({ducation: 8000})
    this.setData({
      //输出动画
      animation: this.animation.export()
    })
  }





免责声明:本站所有文章和图片均来自用户分享和网络收集,文章和图片版权归原作者及原出处所有,仅供学习与参考,请勿用于商业用途,如果损害了您的权利,请联系网站客服处理。