summaryrefslogtreecommitdiff
path: root/js/jcrop/jquery.Jcrop.go.js
blob: 5739f676d0eb46341e82d9c46c453ceaed0ea8c8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
/** Init for Jcrop library and page setup
 *
 * @package   StatusNet
 * @author Sarven Capadisli <csarven@status.net>
 * @copyright 2009 StatusNet, Inc.
 * @license   http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
 * @link      http://status.net/
 */

$(function(){
    var x = ($('#avatar_crop_x').val()) ? $('#avatar_crop_x').val() : 0;
    var y = ($('#avatar_crop_y').val()) ? $('#avatar_crop_y').val() : 0;
    var w = ($('#avatar_crop_w').val()) ? $('#avatar_crop_w').val() : $("#avatar_original img").attr("width");
    var h = ($('#avatar_crop_h').val()) ? $('#avatar_crop_h').val() : $("#avatar_original img").attr("height");

    jQuery("#avatar_original img").Jcrop({
        onChange: showPreview,
        setSelect: [ x, y, w, h ],
        onSelect: updateCoords,
        aspectRatio: 1,
        boxWidth: 480,
        boxHeight: 480,
        bgColor: '#000',
        bgOpacity: .4
    });
});

function showPreview(coords) {
    var rx = 96 / coords.w;
    var ry = 96 / coords.h;

    var img_width = $("#avatar_original img").attr("width");
    var img_height = $("#avatar_original img").attr("height");

    $('#avatar_preview img').css({
        width: Math.round(rx *img_width) + 'px',
        height: Math.round(ry * img_height) + 'px',
        marginLeft: '-' + Math.round(rx * coords.x) + 'px',
        marginTop: '-' + Math.round(ry * coords.y) + 'px'
    });
};

function updateCoords(c) {
    $('#avatar_crop_x').val(c.x);
    $('#avatar_crop_y').val(c.y);
    $('#avatar_crop_w').val(c.w);
    $('#avatar_crop_h').val(c.h);
};