*/
var FilmSlider;
-
(function(){
var keyLeft = 37, keyRight = 39;
FilmSlider.prototype._checkSizeStability = function(evt) {
var self = this;
var i;
+ var checkAgain = function(evt){self._checkSizeStability();};
for (i=0 ; i<this._barSizes.length - 1 ; i++) {
if (this._barSizes[i] !== this._barSizes[i+1]) {
this._barSizes = [];
- setTimeout(function(evt){self._checkSizeStability();}, 250);
+ setTimeout(checkAgain, 250);
return;
}
}
FilmSlider.prototype._fitToScreen = function(evt) {
var wh = getWindowHeight();
+ var rb;
if (!browser.isMobile) {
- var rb = getObjectTop(this.rail) + getObjectHeight(this.rail); // rail bottom
+ rb = getObjectTop(this.rail) + getObjectHeight(this.rail); // rail bottom
}
else {
- var rb = getObjectTop(this.filmBar) + getObjectHeight(this.filmBar); // film bottom
+ rb = getObjectTop(this.filmBar) + getObjectHeight(this.filmBar); // film bottom
}
var delta = wh - rb;
var sh = getObjectHeight(this.stretchable);
var src = this.image.src.replace(imgRequestedSize, 'size=' + bestFitSize);
this.pendingImage.src = src;
}
+ this.adjustImage(this.image);
};
FilmSlider.prototype.getBestFitSize = function(ratio) {
return DEFAULT_IMAGE_SIZES[i];
};
+FilmSlider.prototype.adjustImage = function(img) {
+ var dispWidth = parseInt(this.stretchable.style.width);
+ var imgWidth = img.naturalWidth;
+ var dispHeight = parseInt(this.stretchable.style.height);
+ var imgHeight = img.naturalHeight;
+ var ratio;
+
+ if (imgHeight > dispHeight) {
+ ratio = dispHeight / imgHeight;
+ imgWidth = imgWidth * ratio;
+ imgHeight = dispHeight;
+ }
+ if (imgWidth > dispWidth) {
+ ratio = dispWidth / imgWidth;
+ imgHeight = imgHeight * ratio;
+ imgWidth = dispWidth;
+ }
+ img.width = imgWidth;
+ img.height = imgHeight;
+};
+
if (!browser.isMobile) {
FilmSlider.prototype.centerSlide = function(slideIndex) {
if (this.sliderRatio > 1) { return; }
var delta = this.touchStartX - evt.changedTouches[0].screenX;
var posX = this.filmStartX - delta;
this.setFilmPosition(posX);
- this.lastMoveTime = (new Date()).getTime();
+ this.lastMoveTime = (new Date()).getTime();
};
FilmSlider.prototype.touchEndHandler = function(evt) {
- var x = evt.changedTouches[0].screenX;
+ var x = evt.changedTouches[0].screenX;
var delta = x - this.touchStartX;
if (delta) {
disableDefault(evt);
- var now = (new Date()).getTime();
- if (now - this.lastMoveTime < 100) {
- // au delà de 100 ms de maintient, on annule l'inertie
- var speed = delta / (now - this.touchStartTime)
- var x0 = parseInt(this.film.style.left, 10);
- var t0 = (new Date()).getTime();
- var d = 500; // milisecondes
- var delta = 0;
- var dt = 25
- var self = this;
+ var now = (new Date()).getTime();
+ if (now - this.lastMoveTime < 100) {
+ // au delà de 100 ms de maintient, on annule l'inertie
+ var speed = delta / (now - this.touchStartTime);
+ var x0 = parseInt(this.film.style.left, 10);
+ var t0 = (new Date()).getTime();
+ var d = 500; // milisecondes
+ delta = 0;
+ var dt = 25;
+ var self = this;
- function animate() {
- // inertie
- var t = (new Date()).getTime() - t0;
- if (t < d) {
- setTimeout(animate, dt);
- delta = delta + (1-t/d) * speed * dt; // décelleration linéaire
- self.setFilmPosition(x0 + delta);
- }
- }
- animate();
- }
+ var animate = function() {
+ // inertie
+ var t = (new Date()).getTime() - t0;
+ if (t < d) {
+ setTimeout(animate, dt);
+ delta = delta + (1-t/d) * speed * dt; // décelleration linéaire
+ self.setFilmPosition(x0 + delta);
+ }
+ };
+ animate();
+ }
}
this.touchStartX = undefined;
};
};
FilmSlider.prototype.refreshImage = function() {
+ this.adjustImage(this.pendingImage);
this.image.style.visibility = 'hidden';
this.image.src = this.pendingImage.src;
this.image.width = this.pendingImage.width;
}
if (leftSize > rightSize) {
for (i = this.center - rightSize - 1 ; i >= 0 ; i--) {
- console.log(i);
this.thumbnailsLoadingOrder.push(thumbnails[i]);
}
}
else if (leftSize < rightSize) {
- for (i = this.center + leftSize ; i < thumbnails.length ; i++) {
+ for (i = this.center + leftSize + 1 ; i < thumbnails.length ; i++) {
this.thumbnailsLoadingOrder.push(thumbnails[i]);
}
}