真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

微信小程序中怎么制作圖片拖拽功能

這篇文章主要介紹微信小程序中怎么制作圖片拖拽功能,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!

站在用戶的角度思考問題,與客戶深入溝通,找到新區(qū)網(wǎng)站設(shè)計(jì)與新區(qū)網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗(yàn),讓設(shè)計(jì)與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個(gè)性化、用戶體驗(yàn)好的作品,建站類型包括:成都網(wǎng)站建設(shè)、網(wǎng)站設(shè)計(jì)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣、國(guó)際域名空間、網(wǎng)站空間、企業(yè)郵箱。業(yè)務(wù)覆蓋新區(qū)地區(qū)。

1.編寫頁(yè)面結(jié)構(gòu):moveimg.wxml


	
		
		
	

2.編寫頁(yè)面樣式:moveimg.wxss

.container {
    box-sizing:border-box;
    padding:1rem;
} 
.cnt{
    width:100%;
    height:70%;
    border: 1px solid #ccc;
    position:relative;
    overflow: hidden;
    z-index:9999;
}
.image-style{
	-webkit-transform:translate(-38px,0px);  
}

3.設(shè)置數(shù)據(jù):moveimg.js

var app = getApp()
Page({
	data: {
    	imgwidth:0,
    	imgheight:0,
    	animationData: {},
    	movex:0,
    	movey:0,
    	x:0,
    	y:0,
	},
	onLoad: function() {
		 // 頁(yè)面初始化 options為頁(yè)面跳轉(zhuǎn)所帶來(lái)的參數(shù)
		var _this = this;
		wx.getSystemInfo({
			success: function(res) {
				_this.setData({
					screenHeight: res.windowHeight,
					screenWidth: res.windowWidth,
				});
			}
		});
	},
	onReady:function(){
	    // 頁(yè)面渲染完成
	    //實(shí)例化一個(gè)動(dòng)畫
	    this.animation = wx.createAnimation({
	    	duration: 1000, 
	    	timingFunction: 'linear',//均勻
	    	transformOrigin: "left top 0px",
	    })
	},
	imageLoad: function(e) {  
        var _this=this; 
        //1.框的寬高
        var cnt_offetw=_this.data.screenWidth-38,
        	cnt_offeth=(_this.data.screenHeight-38)*0.7;
        //2.獲取圖片真實(shí)寬度
        var $width=e.detail.width,    //獲取圖片真實(shí)寬度  
            $height=e.detail.height,  
            ratio=$width/$height;   //圖片的真實(shí)寬高比例
       	//3.進(jìn)行判斷:當(dāng)圖片小于框時(shí)候,圖片大小等于框大小,當(dāng)大于框的時(shí)候,則成比例呈現(xiàn)
       	var viewWidth=_this.data.screenWidth;           //設(shè)置圖片固定寬度值,  
        var	viewHeight=parseInt(viewWidth/ratio);    //計(jì)算的高度值
     	if (viewHeight< cnt_offeth) {
            viewHeight=cnt_offeth;
        }
        _this.setData({ 
            imgwidth:viewWidth,  
            imgheight:viewHeight,
            cnt_boxw:cnt_offetw,
            cnt_boxh:cnt_offeth,
        })
    },
    startEvent:function(e){
    	//1.獲取鼠標(biāo)點(diǎn)擊下去的
    	this.setData({
	     	startx: e.touches[0].pageX,
	      	starty: e.touches[0].pageY
	    })
    },
    moveEvent: function(e) { 
		var _this=this;
		//2.鼠標(biāo)移動(dòng)的位置
		var pageX = e.touches[0].pageX;
		var pageY = e.touches[0].pageY;	
		var x,y;
		//3.記住初始化圖片x,y
		var endx=_this.data.x,endy=_this.data.y;
		//4.判斷
		var w_x=_this.data.imgwidth-_this.data.cnt_boxw;//x拖拽值:圖片寬-框的寬
		var h_y=parseInt(_this.data.imgheight-_this.data.cnt_boxh);//y拖拽值:圖片高-框高
		var DistanceX = pageX - _this.data.startx;//x:當(dāng)鼠標(biāo)點(diǎn)擊到移動(dòng)的點(diǎn)之間的距離
		var DistanceY =pageY - _this.data.starty;//y:當(dāng)鼠標(biāo)點(diǎn)擊到移動(dòng)的點(diǎn)之間的距離
		if (DistanceX>0){
			//往右移動(dòng) 如果當(dāng)前的值大于等于0時(shí)則不移動(dòng),否則當(dāng)前值加上鼠標(biāo)拖拽的距離
			if (endx >= 0) {
		        x = 0;
		    } else {
		        x = endx + DistanceX;
		    }
	    }else{
	    	//往左移動(dòng):x拖拽值大于等于當(dāng)前的值,說明已經(jīng)到邊上了,就等于拖拽值,否則當(dāng)前的值加上鼠標(biāo)拖拽的距離
			if (w_x >= endx) {
		        x = -w_x;
		    } else {
		        x = endx + DistanceX;
		    }
	    }
	    if (DistanceY>0){
	    	//往下移動(dòng):如果當(dāng)前的值大于等于0時(shí)則不移動(dòng),否則當(dāng)前值加上鼠標(biāo)拖拽的距離
			if(endy>=0){
				y =0;
		    }else{
		        y = endy + DistanceY;
		    }
	    }else{
	    	//往上移動(dòng):y拖拽值大于等于當(dāng)前的值,說明已經(jīng)到邊上了,就等于拖拽值,否則當(dāng)前的值加上鼠標(biāo)拖拽的距離
	    	if(-endy==h_y||-endy>h_y){
	    		y=-h_y;
	    		console.log("da0")
	    	}else{
	    		y=endy+DistanceY;
	    		console.log("da 1")
	    	}
	 	}
   		setTimeout(function() {
	      	_this.animation.translate(x, y).step();
			_this.setData({
	       		animationData: this.animation.export()
	   		})
	    }.bind(this), 0)

	    _this.setData({
	    	x:x,
	    	y:y,
	    }) 
	    endx=x;endy=y;//記住這次的圖片移動(dòng)的范圍
	    _this.data.startx=pageX;_this.data.starty=pageY;// 每移動(dòng)一次把上一次的點(diǎn)作為原點(diǎn)
    },
    endEvent:function(){
 		clearTimeout(function(){
    		this.animation.translate(this.data.x,this.data.y).step();
			this.setData({
	       		animationData: this.animation.export()
	   		})
     	});
    }
})

由于上次做的這個(gè)有問題,并沒有記錄上一次移動(dòng)的效果。所以這次我使用了洪荒之力,修改下代碼。

以上是“微信小程序中怎么制作圖片拖拽功能”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!


網(wǎng)站標(biāo)題:微信小程序中怎么制作圖片拖拽功能
本文來(lái)源:http://weahome.cn/article/goghgj.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部