随身笔记
随身笔记

小程序拖拽浮动按钮

小程序 浮动  拖拽 按钮

不借助movable-area自带的组件,实现拖拽效果

https://sdeno.com/wp-content/uploads/2019/05/20190321173621284.gif

 

wxml

<button catchtouchmove="buttonMove" catchtouchstart="buttonStart" catchtouchend="buttonEnd" style="top:{{buttonTop}}px;left:{{buttonLeft}}px;width: 50px;height:50px;border-radius:50px;position:fixed;background:#ff6700;line-height:50px;font-size:25pt;color:#fff;">+</button>

 

js:

var startPoint;
Page({
  data: {
  buttonTop: 0,
  buttonLeft: 0,
  windowHeight: '',
  windowWidth: ''
},
onLoad: function (options) {
  var that =this;
  wx.getSystemInfo({
    success: function (res) {
      console.log(res);
      // 屏幕宽度、高度
      console.log('height=' + res.windowHeight);
      console.log('width=' + res.windowWidth);
     // 高度,宽度 单位为px
     that.setData({
        windowHeight: res.windowHeight,
        windowWidth: res.windowWidth
      })
    }
  })
},

onShow: function () {

},

buttonStart: function (e) {
   startPoint = e.touches[0]
},
buttonMove: function (e) {
  var endPoint = e.touches[e.touches.length - 1]
  var translateX = endPoint.clientX - startPoint.clientX
  var translateY = endPoint.clientY - startPoint.clientY
  startPoint = endPoint
  var buttonTop = this.data.buttonTop + translateY
  var buttonLeft = this.data.buttonLeft + translateX
  //判断是移动否超出屏幕
  if (buttonLeft+50 >= this.data.windowWidth){
     buttonLeft = this.data.windowWidth-50;
  }
  if (buttonLeft<=0){
     buttonLeft=0;
  }
  if (buttonTop<=0){
     buttonTop=0
  }
  if (buttonTop + 50 >= this.data.windowHeight){
     buttonTop = this.data.windowHeight-50;
  }
  this.setData({
     buttonTop: buttonTop,
     buttonLeft: buttonLeft
  })
},

buttonEnd: function (e) {

}

})

 

https://blog.csdn.net/jiang18238032891/article/details/88721165

 

随身笔记

小程序拖拽浮动按钮
小程序 浮动  拖拽 按钮 不借助movable-area自带的组件,实现拖拽效果   wxml <button catchtouchmove="buttonMove" catchtouchstart="buttonStart" catchtouchend…
扫描二维码继续阅读
2019-05-22