image.js
170 lines
| 4.8 KiB
| application/javascript
|
JavascriptLexer
neko259
|
r332 | /* | ||
@licstart The following is the entire license notice for the | ||||
JavaScript code in this page. | ||||
Copyright (C) 2013 neko259 | ||||
The JavaScript code in this page is free software: you can | ||||
redistribute it and/or modify it under the terms of the GNU | ||||
General Public License (GNU GPL) as published by the Free Software | ||||
Foundation, either version 3 of the License, or (at your option) | ||||
any later version. The code is distributed WITHOUT ANY WARRANTY; | ||||
without even the implied warranty of MERCHANTABILITY or FITNESS | ||||
FOR A PARTICULAR PURPOSE. See the GNU GPL for more details. | ||||
As additional permission under GNU GPL version 3 section 7, you | ||||
may distribute non-source (e.g., minimized or compacted) forms of | ||||
that code without the copy of the GNU GPL normally required by | ||||
section 4, provided you include this license notice and a URL | ||||
through which recipients can access the Corresponding Source. | ||||
@licend The above is the entire license notice | ||||
for the JavaScript code in this page. | ||||
*/ | ||||
neko259
|
r1122 | |||
var IMAGE_VIEWERS = [ | ||||
['simple', new SimpleImageViewer()], | ||||
['popup', new PopupImageViewer()] | ||||
]; | ||||
neko259
|
r1128 | var FULL_IMG_CLASS = 'post-image-full'; | ||
neko259
|
r1122 | |||
function ImageViewer() {} | ||||
ImageViewer.prototype.view = function (post) {}; | ||||
function SimpleImageViewer() {} | ||||
SimpleImageViewer.prototype.view = function (post) { | ||||
neko259
|
r1128 | var images = post.find('img'); | ||
images.toggle(); | ||||
// When we first enlarge an image, a full image needs to be created | ||||
if (images.length == 1) { | ||||
neko259
|
r1283 | var thumb = images.first(); | ||
var width = thumb.attr('data-width'); | ||||
var height = thumb.attr('data-height'); | ||||
neko259
|
r1285 | if (width == null || height == null) { | ||
width = '100%'; | ||||
height = '100%'; | ||||
} | ||||
neko259
|
r1128 | var parent = images.first().parent(); | ||
var link = parent.attr('href'); | ||||
var fullImg = $('<img />') | ||||
.addClass(FULL_IMG_CLASS) | ||||
neko259
|
r1283 | .attr('src', link) | ||
.attr('width', width) | ||||
.attr('height', height); | ||||
neko259
|
r1128 | |||
parent.append(fullImg); | ||||
} | ||||
neko259
|
r1122 | }; | ||
function PopupImageViewer() {} | ||||
PopupImageViewer.prototype.view = function (post) { | ||||
var margin = 20; //..change | ||||
var el = post; | ||||
var thumb_id = 'full' + el.find('img').attr('alt'); | ||||
var existingPopups = $('#' + thumb_id); | ||||
neko259
|
r1352 | if (!existingPopups.length) { | ||
neko259
|
r1122 | var imgElement= el.find('img'); | ||
var img_w = imgElement.attr('data-width'); | ||||
var img_h = imgElement.attr('data-height'); | ||||
var win = $(window); | ||||
var win_w = win.width(); | ||||
var win_h = win.height(); | ||||
neko259
|
r1351 | |||
// New image size | ||||
var w_scale = 1; | ||||
var h_scale = 1; | ||||
neko259
|
r1122 | if (img_w > win_w) { | ||
neko259
|
r1351 | w_scale = img_w / (win_w - margin); | ||
neko259
|
r1122 | } | ||
if (img_h > win_h) { | ||||
neko259
|
r1351 | h_scale = img_h / (win_h - margin); | ||
neko259
|
r1122 | } | ||
neko259
|
r1351 | var scale = Math.max(w_scale, h_scale) | ||
img_w = img_w / scale; | ||||
img_h = img_h / scale; | ||||
neko259
|
r1352 | var postNode = $(el); | ||
neko259
|
r1122 | var img_pv = new Image(); | ||
var newImage = $(img_pv); | ||||
newImage.addClass('img-full') | ||||
.attr('id', thumb_id) | ||||
neko259
|
r1352 | .attr('src', postNode.attr('href')) | ||
.appendTo(postNode) | ||||
neko259
|
r1122 | .css({ | ||
'width': img_w, | ||||
'height': img_h, | ||||
'left': (win_w - img_w) / 2, | ||||
'top': ((win_h - img_h) / 2) | ||||
}) | ||||
//scaling preview | ||||
.mousewheel(function(event, delta) { | ||||
neko259
|
r1351 | var cx = event.originalEvent.clientX; | ||
var cy = event.originalEvent.clientY; | ||||
var i_w = parseFloat(newImage.width()); | ||||
var i_h = parseFloat(newImage.height()); | ||||
var newIW = i_w * (delta > 0 ? 1.25 : 0.8); | ||||
var newIH = i_h * (delta > 0 ? 1.25 : 0.8); | ||||
neko259
|
r1122 | |||
newImage.width(newIW); | ||||
newImage.height(newIH); | ||||
neko259
|
r1351 | // Set position | ||
var oldPosition = newImage.position(); | ||||
neko259
|
r1122 | newImage.css({ | ||
neko259
|
r1351 | left: parseInt(cx - (newIW/i_w) * (cx - parseInt(oldPosition.left, 10)), 10), | ||
top: parseInt(cy - (newIH/i_h) * (cy - parseInt(oldPosition.top, 10)), 10) | ||||
neko259
|
r1122 | }); | ||
return false; | ||||
} | ||||
) | ||||
.draggable({ | ||||
addClasses: false, | ||||
stack: '.img-full' | ||||
}); | ||||
} else { | ||||
existingPopups.remove(); | ||||
} | ||||
}; | ||||
rt@lightning
|
r238 | function addImgPreview() { | ||
neko259
|
r1122 | var viewerName = $('body').attr('data-image-viewer'); | ||
var viewer = ImageViewer(); | ||||
for (var i = 0; i < IMAGE_VIEWERS.length; i++) { | ||||
var item = IMAGE_VIEWERS[i]; | ||||
if (item[0] === viewerName) { | ||||
viewer = item[1]; | ||||
break; | ||||
} | ||||
} | ||||
rt@lightning
|
r263 | |||
rt@lightning
|
r238 | //keybind | ||
$(document).on('keyup.removepic', function(e) { | ||||
if(e.which === 27) { | ||||
$('.img-full').remove(); | ||||
} | ||||
}); | ||||
rt@lightning
|
r252 | $('body').on('click', '.thumb', function() { | ||
neko259
|
r1122 | viewer.view($(this)); | ||
rt@lightning
|
r238 | |||
rt@lightning
|
r252 | return false; | ||
rt@lightning
|
r238 | }); | ||
neko259
|
r1081 | } | ||