60 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
			
		
		
	
	
			60 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
| const MIN_DISTANCE = 10
 | |
| 
 | |
| function getDirection(x, y) {
 | |
|     if (x > y && x > MIN_DISTANCE) {
 | |
|         return 'horizontal'
 | |
|     }
 | |
|     if (y > x && y > MIN_DISTANCE) {
 | |
|         return 'vertical'
 | |
|     }
 | |
|     return ''
 | |
| }
 | |
| 
 | |
| export default {
 | |
|     methods: {
 | |
|         getTouchPoint(e) {
 | |
|             if (!e) {
 | |
|                 return {
 | |
|                     x: 0,
 | |
|                     y: 0
 | |
|                 }
 | |
|             } if (e.touches && e.touches[0]) {
 | |
|                 return {
 | |
|                     x: e.touches[0].pageX,
 | |
|                     y: e.touches[0].pageY
 | |
|                 }
 | |
|             } if (e.changedTouches && e.changedTouches[0]) {
 | |
|                 return {
 | |
|                     x: e.changedTouches[0].pageX,
 | |
|                     y: e.changedTouches[0].pageY
 | |
|                 }
 | |
|             }
 | |
|             return {
 | |
|                 x: e.clientX || 0,
 | |
|                 y: e.clientY || 0
 | |
|             }
 | |
|         },
 | |
|         resetTouchStatus() {
 | |
|             this.direction = ''
 | |
|             this.deltaX = 0
 | |
|             this.deltaY = 0
 | |
|             this.offsetX = 0
 | |
|             this.offsetY = 0
 | |
|         },
 | |
|         touchStart(event) {
 | |
|             this.resetTouchStatus()
 | |
|             const touch = this.getTouchPoint(event)
 | |
|             this.startX = touch.x
 | |
|             this.startY = touch.y
 | |
|         },
 | |
|         touchMove(event) {
 | |
|             const touch = this.getTouchPoint(event)
 | |
|             this.deltaX = touch.x - this.startX
 | |
|             this.deltaY = touch.y - this.startY
 | |
|             this.offsetX = Math.abs(this.deltaX)
 | |
|             this.offsetY = Math.abs(this.deltaY)
 | |
|             this.direction =				this.direction || getDirection(this.offsetX, this.offsetY)
 | |
|         }
 | |
|     }
 | |
| }
 |