Wonky zoom scroll

This commit is contained in:
Max Lynch
2015-09-01 14:06:48 -05:00
parent afc18755e8
commit 481fd7f651
2 changed files with 76 additions and 22 deletions

View File

@ -47,6 +47,13 @@ export class Scroll extends Ion {
} }
} }
resetZoom() {
console.log('RESET ZOOM');
if(this.scale > 1) {
this.zoomElement && this.zoomElement.style[CSS.transform] = 'scale(1)';
}
}
initZoomScrolling() { initZoomScrolling() {
this.zoomElement = this.scrollElement.children[0].children[0]; this.zoomElement = this.scrollElement.children[0].children[0];
@ -59,7 +66,9 @@ export class Scroll extends Ion {
this.zoomGesture = new Gesture(this.scrollElement); this.zoomGesture = new Gesture(this.scrollElement);
this.zoomGesture.listen(); this.zoomGesture.listen();
let scale = 1, last_scale, deltaX, deltaY, this.scale = 1;
let last_scale, deltaX, deltaY,
startX, startY, posX = 0, posY = 0, lastPosX = 0, lastPosY = 0, startX, startY, posX = 0, posY = 0, lastPosX = 0, lastPosY = 0,
zoomRect, viewportWidth, viewportHeight; zoomRect, viewportWidth, viewportHeight;
@ -76,7 +85,7 @@ export class Scroll extends Ion {
//lastPosX = 0; //lastPosX = 0;
//lastPosY = 0; //lastPosY = 0;
if(scale > 1) { if(this.scale > 1) {
//e.preventDefault(); //e.preventDefault();
//e.stopPropagation(); //e.stopPropagation();
} }
@ -86,7 +95,7 @@ export class Scroll extends Ion {
deltaX = e.touches[0].clientX - startX; deltaX = e.touches[0].clientX - startX;
deltaY = e.touches[0].clientY - startY; deltaY = e.touches[0].clientY - startY;
if(scale > 1) { if(this.scale > 1) {
// Move image // Move image
posX = deltaX + lastPosX; posX = deltaX + lastPosX;
@ -121,50 +130,78 @@ export class Scroll extends Ion {
}); });
this.zoomGesture.on('pinchstart', (e) => { this.zoomGesture.on('pinchstart', (e) => {
last_scale = scale; last_scale = this.scale;
console.log('Last scale', e.scale); console.log('Last scale', e.scale);
}); });
this.zoomGesture.on('pinch', (e) => { this.zoomGesture.on('pinch', (e) => {
scale = Math.max(1, Math.min(last_scale * e.scale, 10)); this.scale = Math.max(1, Math.min(last_scale * e.scale, 10));
console.log('Scaling', scale); console.log('Scaling', this.scale);
this.zoomElement.style[CSS.transform] = 'scale(' + scale + ')' this.zoomElement.style[CSS.transform] = 'scale(' + this.scale + ')'
zoomRect = this.zoomElement.getBoundingClientRect(); zoomRect = this.zoomElement.getBoundingClientRect();
}); });
this.zoomGesture.on('pinchend', (e) => { this.zoomGesture.on('pinchend', (e) => {
//last_scale = Math.max(1, Math.min(last_scale * e.scale, 10)); //last_scale = Math.max(1, Math.min(last_scale * e.scale, 10));
if(scale > this.maxScale) { if(this.scale > this.maxScale) {
let za = new Animation(this.zoomElement) let za = new Animation(this.zoomElement)
.duration(this.zoomDuration) .duration(this.zoomDuration)
.easing('linear') .easing('linear')
.from('scale', scale) .from('scale', this.scale)
.to('scale', this.maxScale); .to('scale', this.maxScale);
za.play(); za.play();
scale = this.maxScale; this.scale = this.maxScale;
} }
}); });
this.zoomGesture.on('doubletap', (e) => { this.zoomGesture.on('doubletap', (e) => {
console.log("Double tap");
let za = new Animation(this.zoomElement) let x = e.pointers[0].clientX;
let y = e.pointers[0].clientY;
let tx = (viewportWidth / 2) - x;
let ty = (viewportHeight / 2) - y;
console.log("Double tap", e, x, y, tx, ty);
let zi = new Animation(this.zoomElement)
.duration(this.zoomDuration)
.easing('linear');
let zw = new Animation(this.zoomElement.parentElement)
.duration(this.zoomDuration) .duration(this.zoomDuration)
.easing('linear'); .easing('linear');
if(scale > 1) { let za = new Animation();
za.from('scale', scale); za.add(zi, zw);
za.to('scale', 1);
if(this.scale > 1) {
// Zoom out
zw.fromTo('translateX', posX + 'px', '0px');
zw.fromTo('translateY', posY + 'px', '0px');
zi.from('scale', this.scale);
zi.to('scale', 1);
za.play(); za.play();
scale = 1; posX = 0;
posy = 0;
this.scale = 1;
} else { } else {
za.from('scale', scale); // Zoom in
za.to('scale', this.maxScale);
zw.fromTo('translateX', posX + 'px', tx + 'px');
zw.fromTo('translateY', posY + 'px', ty + 'px');
zi.from('scale', this.scale);
zi.to('scale', this.maxScale);
za.play(); za.play();
scale = this.maxScale; posX = tx;
posY = ty;
this.scale = this.maxScale;
} }
//this.zoomElement.style[CSS.transform] = 'scale(3)'; //this.zoomElement.style[CSS.transform] = 'scale(3)';
}); });

View File

@ -1,4 +1,4 @@
import {Component, View, ElementRef, EventEmitter, onInit, import {Component, View, ViewQuery, Query, QueryList, ElementRef, EventEmitter, onInit,
Host, forwardRef, NgFor, NgIf, NgClass} from 'angular2/angular2'; Host, forwardRef, NgFor, NgIf, NgClass} from 'angular2/angular2';
import {Ion} from '../ion'; import {Ion} from '../ion';
@ -12,6 +12,7 @@ import {Platform} from 'ionic/platform/platform';
import * as util from 'ionic/util'; import * as util from 'ionic/util';
import {Swiper} from './swiper-widget'; import {Swiper} from './swiper-widget';
import {Scroll} from '../scroll/scroll';
/** /**
* Slides is a slide box implementation based on Swiper.js * Slides is a slide box implementation based on Swiper.js
@ -48,19 +49,35 @@ import {Swiper} from './swiper-widget';
directives: [NgIf, NgClass] directives: [NgIf, NgClass]
}) })
export class Slides extends Ion { export class Slides extends Ion {
scrollChildren: QueryList<Scroll>;
/** /**
* TODO * TODO
* @param {ElementRef} elementRef TODO * @param {ElementRef} elementRef TODO
*/ */
constructor(elementRef: ElementRef, config: IonicConfig) { constructor(elementRef: ElementRef, config: IonicConfig, @Query(Scroll, {descendants: true}) public scrollChildren: QueryList<Scroll>) {
super(elementRef, config); super(elementRef, config);
scrollChildren.onChange(() => {
console.log('SCROLL CHILDREN FOUND', scrollChildren.length);
})
} }
onInit() { onInit() {
console.log(this.bounce); console.log(this.scrollChildren);
var options = util.defaults({ var options = util.defaults({
pagination: '.swiper-pagination', pagination: '.swiper-pagination',
paginationClickable: true, paginationClickable: true,
lazyLoading: true, lazyLoading: true,
onSlideChangeStart: (swiper) => {
console.log('Slide change!', swiper);
this.scrollChildren.forEach((s) => {
s.resetZoom();
});
},
onSlideChangeEnd: (swiper) => {
console.log('Slide changED!');
}
//resistance: (this.bounce !== "false") //resistance: (this.bounce !== "false")
}, this.options); }, this.options);