static/tiles2.js
author Tero Marttila <terom@fixme.fi>
Sat, 09 Jan 2010 13:47:47 +0200
changeset 46 82d7b4d64cc6
parent 45 0ce4064c428e
child 48 7577a3b68ccc
permissions -rw-r--r--
fixes for IE8
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
     1
// A source of tile images of a specific width/height, zoom level range, and some other attributes
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
     2
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
     3
/**
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
     4
 * A source of image tiles.
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
     5
 *
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
     6
 * The image source is expected to serve fixed-size tiles (tile_width × tile_height) of image data based on the 
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
     7
 * x, y, zl URL query parameters. 
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
     8
 *
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
     9
 *  x, y        - the pixel coordinates of the top-left corner
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
    10
 *                XXX: these are scaled from the image coordinates by the zoom level
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
    11
 *
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
    12
 *  zl          - the zoom level used, out < zl < in.
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
    13
 *                The image pixels are scaled by powers-of-two, so a 256x256 tile at zl=-1 shows a 512x512 area of the
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
    14
 *                1:1 image.
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
    15
 */
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    16
var Source = Class.create({
43
fcd818eb5a71 center initial view
Tero Marttila <terom@fixme.fi>
parents: 40
diff changeset
    17
    initialize: function (path, tile_width, tile_height, zoom_min, zoom_max, img_width, img_height) {
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    18
        this.path = path;
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    19
        this.tile_width = tile_width;
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    20
        this.tile_height = tile_height;
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    21
        this.zoom_min = zoom_min;
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    22
        this.zoom_max = zoom_max;
43
fcd818eb5a71 center initial view
Tero Marttila <terom@fixme.fi>
parents: 40
diff changeset
    23
        this.img_width = img_width;
fcd818eb5a71 center initial view
Tero Marttila <terom@fixme.fi>
parents: 40
diff changeset
    24
        this.img_height = img_height;
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    25
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    26
        this.refresh = false;
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    27
        this.opt_key = this.opt_value = null;
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    28
    },
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    29
    
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
    30
    /**
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
    31
     * Return an URL representing the tile at the given viewport (row, col) at the given zl.
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
    32
     *
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
    33
     * XXX: sw/sh = screen-width/height, used to choose an appropriate output size for dynamic image sources...
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
    34
     */
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
    35
    build_url: function (col, row, zl /*, sw, sh */) {
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
    36
        // XXX: distribute tile requests across tile*.foo.bar
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
    37
        if (0) {
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
    38
            // two-bit hash (0-4) based on the (col, row)
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
    39
            var hash = ( (col % 2) << 1 | (row % 2) ) + 1;
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
    40
            
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
    41
            // the subdomain to use
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
    42
            var subdomain = "";
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
    43
            
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    44
            subdomain = "tile" + hash + ".";
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
    45
        }
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    46
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    47
        // the (x, y) co-ordinates
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    48
        var x = col * this.tile_width;
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    49
        var y = row * this.tile_height;
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    50
40
5454d2e2f633 add link-to-image feature
Tero Marttila <terom@fixme.fi>
parents: 39
diff changeset
    51
        var url = this.path + "?x=" + x + "&y=" + y + "&zl=" + zl; // + "&sw=" + sw + "&sh=" + sh;
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
    52
        
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
    53
        // refresh the tile each time it is loaded?
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    54
        if (this.refresh)
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    55
            url += "&ts=" + new Date().getTime();
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
    56
        
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
    57
        // XXX: additional parameters, not used
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    58
        if (this.opt_key && this.opt_value)
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    59
            url += "&" + this.opt_key + "=" + this.opt_value;
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    60
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    61
        return url;
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    62
    },
40
5454d2e2f633 add link-to-image feature
Tero Marttila <terom@fixme.fi>
parents: 39
diff changeset
    63
5454d2e2f633 add link-to-image feature
Tero Marttila <terom@fixme.fi>
parents: 39
diff changeset
    64
    // build an URL for a full image
5454d2e2f633 add link-to-image feature
Tero Marttila <terom@fixme.fi>
parents: 39
diff changeset
    65
    build_image_url: function (cx, cy, w, h, zl) {
5454d2e2f633 add link-to-image feature
Tero Marttila <terom@fixme.fi>
parents: 39
diff changeset
    66
        return (this.path + "?cx=" + cx + "&cy=" + cy + "&w=" + w + "&h=" + h + "&zl=" + zl);
5454d2e2f633 add link-to-image feature
Tero Marttila <terom@fixme.fi>
parents: 39
diff changeset
    67
    }
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    68
});
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    69
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
    70
/**
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
    71
 * Viewport implements the tiles-UI. It consists of a draggable substrate, which in turn consists of several
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
    72
 * ZoomLayers, which then contain the actual tile images.
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
    73
 *
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
    74
 * Vars:
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
    75
 *      scroll_x/y      - the visible pixel offset of the top-left corner
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
    76
 */
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    77
var Viewport = Class.create({
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    78
    initialize: function (source, viewport_id) {
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    79
        this.source = source;
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
    80
        
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
    81
        // get a handle on the UI elements
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    82
        this.id = viewport_id;
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    83
        this.div = $(viewport_id);
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    84
        this.substrate = this.div.down("div.substrate");
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    85
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    86
        // make the substrate draggable
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    87
        this.draggable = new Draggable(this.substrate, {
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    88
            onStart: this.on_scroll_start.bind(this),
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    89
            onDrag: this.on_scroll_move.bind(this),
46
82d7b4d64cc6 fixes for IE8
Tero Marttila <terom@fixme.fi>
parents: 45
diff changeset
    90
            onEnd: this.on_scroll_end.bind(this)
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    91
        });
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    92
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
    93
        // register event handlers for other UI functions
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    94
        Event.observe(this.substrate, "dblclick", this.on_dblclick.bindAsEventListener(this));
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    95
        Event.observe(this.substrate, "mousewheel", this.on_mousewheel.bindAsEventListener(this));
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    96
        Event.observe(this.substrate, "DOMMouseScroll", this.on_mousewheel.bindAsEventListener(this));     // mozilla
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    97
        Event.observe(document, "resize", this.on_resize.bindAsEventListener(this));
39
eeedb6c2f7c0 zoom button UI
Tero Marttila <terom@fixme.fi>
parents: 38
diff changeset
    98
        
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
    99
        // init zoom UI buttons
39
eeedb6c2f7c0 zoom button UI
Tero Marttila <terom@fixme.fi>
parents: 38
diff changeset
   100
        this.btn_zoom_in = $("btn-zoom-in");
eeedb6c2f7c0 zoom button UI
Tero Marttila <terom@fixme.fi>
parents: 38
diff changeset
   101
        this.btn_zoom_out = $("btn-zoom-out");
eeedb6c2f7c0 zoom button UI
Tero Marttila <terom@fixme.fi>
parents: 38
diff changeset
   102
eeedb6c2f7c0 zoom button UI
Tero Marttila <terom@fixme.fi>
parents: 38
diff changeset
   103
        if (this.btn_zoom_in)
eeedb6c2f7c0 zoom button UI
Tero Marttila <terom@fixme.fi>
parents: 38
diff changeset
   104
            Event.observe(this.btn_zoom_in, "click", this.zoom_in.bindAsEventListener(this));
eeedb6c2f7c0 zoom button UI
Tero Marttila <terom@fixme.fi>
parents: 38
diff changeset
   105
        
eeedb6c2f7c0 zoom button UI
Tero Marttila <terom@fixme.fi>
parents: 38
diff changeset
   106
        if (this.btn_zoom_out)
eeedb6c2f7c0 zoom button UI
Tero Marttila <terom@fixme.fi>
parents: 38
diff changeset
   107
            Event.observe(this.btn_zoom_out, "click", this.zoom_out.bindAsEventListener(this));
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   108
           
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   109
        // initial view location (centered)
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   110
        var cx = 0, cy = 0, zl = 0;
32
aa168c7da551 implement x:y:z tuple in URL
Tero Marttila <terom@fixme.fi>
parents: 30
diff changeset
   111
        
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   112
        // from link?
32
aa168c7da551 implement x:y:z tuple in URL
Tero Marttila <terom@fixme.fi>
parents: 30
diff changeset
   113
        if (document.location.hash) {
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   114
            // parse x:y:z tuple
32
aa168c7da551 implement x:y:z tuple in URL
Tero Marttila <terom@fixme.fi>
parents: 30
diff changeset
   115
            var pt = document.location.hash.substr(1).split(":");
aa168c7da551 implement x:y:z tuple in URL
Tero Marttila <terom@fixme.fi>
parents: 30
diff changeset
   116
            
43
fcd818eb5a71 center initial view
Tero Marttila <terom@fixme.fi>
parents: 40
diff changeset
   117
            // unpack    
32
aa168c7da551 implement x:y:z tuple in URL
Tero Marttila <terom@fixme.fi>
parents: 30
diff changeset
   118
            if (pt.length) cx = parseInt(pt.shift());
aa168c7da551 implement x:y:z tuple in URL
Tero Marttila <terom@fixme.fi>
parents: 30
diff changeset
   119
            if (pt.length) cy = parseInt(pt.shift());
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   120
            if (pt.length) zl = parseInt(pt.shift());
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   121
43
fcd818eb5a71 center initial view
Tero Marttila <terom@fixme.fi>
parents: 40
diff changeset
   122
        } else {
fcd818eb5a71 center initial view
Tero Marttila <terom@fixme.fi>
parents: 40
diff changeset
   123
            // start in the center
fcd818eb5a71 center initial view
Tero Marttila <terom@fixme.fi>
parents: 40
diff changeset
   124
            cx = this.source.img_width / 2;
fcd818eb5a71 center initial view
Tero Marttila <terom@fixme.fi>
parents: 40
diff changeset
   125
            cy = this.source.img_height / 2;
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   126
            zl = 0; // XXX: need to scale x/y for this: (this.source.zoom_min + this.source.zoom_max) / 2;
43
fcd818eb5a71 center initial view
Tero Marttila <terom@fixme.fi>
parents: 40
diff changeset
   127
        }
32
aa168c7da551 implement x:y:z tuple in URL
Tero Marttila <terom@fixme.fi>
parents: 30
diff changeset
   128
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   129
        // initialize zoom state to given zl
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   130
        this._init_zoom(zl);
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   131
        
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   132
        // initialize viewport size
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   133
        this.update_size();
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   134
        
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   135
        // initialize scroll offset
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   136
        this._init_scroll(cx, cy);
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   137
        
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   138
        // this comes after update_size, so that the initial update_size doesn't try and update the image_link,
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   139
        // since this only works once we have the zoom layers set up...
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   140
        this.image_link = $("lnk-image");
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   141
        this.update_image_link();
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   142
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   143
        // display tiles!
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   144
        this.update_tiles();
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   145
    },
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   146
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   147
/*
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   148
 * Initializers - only run once
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   149
 */
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   150
                    
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   151
    /** Initialize the zoom state to show the given zoom level */
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   152
    _init_zoom: function (zl) {
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   153
        // the stack of zoom levels
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   154
        this.zoom_layers = [];
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   155
        
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   156
        // populate the zoom-layers stack based on the number of zoom levels defined for the source
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   157
        for (var zoom_level = this.source.zoom_min; zoom_level <= this.source.zoom_max; zoom_level++) {
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   158
            var zoom_layer = new ZoomLayer(this.source, zoom_level);
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   159
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   160
            this.substrate.appendChild(zoom_layer.div);
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   161
            this.zoom_layers[zoom_level] = zoom_layer;
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   162
        }
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   163
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   164
        // is the new zoom level valid?
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   165
        if (!this.zoom_layers[zl])
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   166
            // XXX: nasty, revert to something else?
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   167
            return false;
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   168
        
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   169
        // set the zoom layyer
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   170
        this.zoom_layer = this.zoom_layers[zl];
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   171
        
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   172
        // enable it with initial z-index
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   173
        this.zoom_layer.enable(11);
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   174
        
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   175
        // init the UI accordingly
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   176
        this.update_zoom_ui();
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   177
    },
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   178
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   179
    /** Initialize the scroll state to show the given (scaled) centered coordinates */
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   180
    _init_scroll: function (cx, cy) {
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   181
        // scroll center
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   182
        this.scroll_center_to(cx, cy);
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   183
    },
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   184
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   185
    
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   186
/*
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   187
 * Handle input events
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   188
 */    
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   189
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   190
    /** Viewport resized */
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   191
    on_resize: function (ev) {
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   192
        this.update_size();
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   193
        this.update_tiles();
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   194
    },
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   195
    
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   196
    /** Double-click to zoom and center */
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   197
    on_dblclick: function (ev) {
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   198
        var offset = this.event_offset(ev);
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   199
        
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   200
        // center view and zoom in
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   201
        this.center_and_zoom_in(
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   202
            this.scroll_x + offset.x,
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   203
            this.scroll_y + offset.y
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   204
        );
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   205
    },
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   206
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   207
    // mousewheel handler
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   208
    on_mousewheel: function (ev) {
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   209
        // this works in very weird ways, so it's based on code from http://adomas.org/javascript-mouse-wheel/
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   210
        // (it didn't include any license, so this is written out manually)
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   211
        var delta;
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   212
        
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   213
        // this is browser-dependant...
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   214
        if (ev.wheelDelta) {
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   215
            // IE + Opera
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   216
            delta = ev.wheelDelta;
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   217
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   218
            if (window.opera) {  
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   219
                // Opera, but apparently not newer versions?
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   220
                //delta = -delta;
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   221
            }
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   222
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   223
        } else if (ev.detail) {
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   224
            // Mozilla
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   225
            delta = -ev.detail;
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   226
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   227
        } else {
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   228
            // mousewheel not supported...
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   229
            return;
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   230
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   231
        }
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   232
        
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   233
        // don't scroll the page
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   234
        if (ev.preventDefault)
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   235
            ev.preventDefault();
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   236
        
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   237
        // delta > 0 : scroll up, zoom in
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   238
        // delta < 0 : scroll down, zoom out
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   239
        delta = delta < 0 ? -1 : 1;
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   240
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   241
        // Firefox's DOMMouseEvent's pageX/Y attributes are broken. layerN is for mozilla, offsetN for IE, seems to work
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   242
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   243
        // absolute location of the cursor
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   244
        var x = parseInt(ev.target.style.left) + (ev.layerX ? ev.layerX : ev.offsetX);
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   245
        var y = parseInt(ev.target.style.top) + (ev.layerY ? ev.layerY : ev.offsetY);
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   246
        
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   247
        // zoom \o/
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   248
        this.zoom_center_to(x, y, delta);
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   249
    },
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   250
    
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   251
    /** Substrate scroll was started */
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   252
    on_scroll_start: function (ev) {
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   253
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   254
    },
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   255
    
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   256
    /** Substrate was scrolled, update scroll_{x,y}, and then update tiles after 100ms */
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   257
    on_scroll_move: function (ev) {
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   258
        this.update_scroll();
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   259
        this.update_after_timeout();
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   260
    },
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   261
    
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   262
    /** Substrate scroll was ended, update tiles now */
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   263
    on_scroll_end: function (ev) {
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   264
        this.update_now();
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   265
    },
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   266
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   267
    /** Calculate the absolute (x, y) coords of the given event inside the viewport */
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   268
    event_offset: function (ev) {
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   269
        var offset = this.div.cumulativeOffset();
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   270
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   271
        return {
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   272
            x: ev.pointerX() - offset.left, 
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   273
            y: ev.pointerY() - offset.top
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   274
        };
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   275
    },
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   276
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   277
/*
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   278
 * Change view - scroll/zoom
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   279
 */                  
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   280
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   281
    /** Scroll the view to place the given absolute (x, y) co-ordinate at the top left */
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   282
    scroll_to: function (x, y) {
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   283
        // update it via the style
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   284
        this.substrate.style.top = "-" + y + "px";
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   285
        this.substrate.style.left = "-" + x + "px";
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   286
        
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   287
        // update these as well
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   288
        this.scroll_x = x;
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   289
        this.scroll_y = y;
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   290
    },
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   291
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   292
    /** Scroll the view to place the given absolute (x, y) co-ordinate at the center */
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   293
    scroll_center_to: function (x, y) {
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   294
        return this.scroll_to(
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   295
            x - this.center_offset_x,
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   296
            y - this.center_offset_y
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   297
        );
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   298
    },
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   299
 
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   300
    /** Zoom à la delta such that the given (zoomed) absolute (x, y) co-ordinates will be at the top left */
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   301
    zoom_scaled: function (x, y, delta) {
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   302
        if (!this.update_zoom(delta))
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   303
            // couldn't zoom, scaled coords are wrong
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   304
            return false;
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   305
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   306
        // scroll to the new position
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   307
        this.scroll_to(x, y);
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   308
        
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   309
        // update view after 100ms - in case we zoom again?
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   310
        this.update_after_timeout();
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   311
        
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   312
        return true;
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   313
    },
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   314
   
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   315
    /** Zoom à la delta such that the given (current) absolute (x, y) co-ordinates will be at the top left */
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   316
    zoom_to: function (x, y, delta) {
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   317
        return this.zoom_scaled(
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   318
            scaleByZoomDelta(x, delta),
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   319
            scaleByZoomDelta(y, delta),
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   320
            delta
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   321
        );
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   322
    },
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   323
    
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   324
    /** Zoom à la delta such that the given (current) absolute (x, y) co-ordinates will be at the center */
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   325
    zoom_center_to: function (x, y, delta) {
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   326
        return this.zoom_scaled(
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   327
            scaleByZoomDelta(x, delta) - this.center_offset_x,
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   328
            scaleByZoomDelta(y, delta) - this.center_offset_y,
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   329
            delta
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   330
        );
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   331
    },
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   332
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   333
    /** Zoom à la delta, keeping the view centered */
39
eeedb6c2f7c0 zoom button UI
Tero Marttila <terom@fixme.fi>
parents: 38
diff changeset
   334
    zoom_centered: function (delta) {
eeedb6c2f7c0 zoom button UI
Tero Marttila <terom@fixme.fi>
parents: 38
diff changeset
   335
        return this.zoom_center_to(
eeedb6c2f7c0 zoom button UI
Tero Marttila <terom@fixme.fi>
parents: 38
diff changeset
   336
            this.scroll_x + this.center_offset_x,
eeedb6c2f7c0 zoom button UI
Tero Marttila <terom@fixme.fi>
parents: 38
diff changeset
   337
            this.scroll_y + this.center_offset_y,
eeedb6c2f7c0 zoom button UI
Tero Marttila <terom@fixme.fi>
parents: 38
diff changeset
   338
            delta
eeedb6c2f7c0 zoom button UI
Tero Marttila <terom@fixme.fi>
parents: 38
diff changeset
   339
        );
eeedb6c2f7c0 zoom button UI
Tero Marttila <terom@fixme.fi>
parents: 38
diff changeset
   340
    },
eeedb6c2f7c0 zoom button UI
Tero Marttila <terom@fixme.fi>
parents: 38
diff changeset
   341
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   342
    /** Zoom in one level, keeping the view centered */
39
eeedb6c2f7c0 zoom button UI
Tero Marttila <terom@fixme.fi>
parents: 38
diff changeset
   343
    zoom_in: function () {
eeedb6c2f7c0 zoom button UI
Tero Marttila <terom@fixme.fi>
parents: 38
diff changeset
   344
        return this.zoom_centered(+1);
eeedb6c2f7c0 zoom button UI
Tero Marttila <terom@fixme.fi>
parents: 38
diff changeset
   345
    },
eeedb6c2f7c0 zoom button UI
Tero Marttila <terom@fixme.fi>
parents: 38
diff changeset
   346
    
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   347
    /** Zoom out one level, keeping the view centered */
39
eeedb6c2f7c0 zoom button UI
Tero Marttila <terom@fixme.fi>
parents: 38
diff changeset
   348
    zoom_out: function () {
eeedb6c2f7c0 zoom button UI
Tero Marttila <terom@fixme.fi>
parents: 38
diff changeset
   349
        return this.zoom_centered(-1);
eeedb6c2f7c0 zoom button UI
Tero Marttila <terom@fixme.fi>
parents: 38
diff changeset
   350
    },
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   351
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   352
    /** Center the view on the given coords, and zoom in, if possible */
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   353
    center_and_zoom_in: function (cx, cy) {
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   354
        // try and zoom in
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   355
        if (this.update_zoom(1)) {
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   356
            // scaled coords
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   357
            cx = scaleByZoomDelta(cx, 1);
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   358
            cy = scaleByZoomDelta(cy, 1);
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   359
        }
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   360
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   361
        // re-center
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   362
        this.scroll_center_to(cx, cy);
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   363
        
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   364
        // update view after 100ms - in case we zoom again?
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   365
        this.update_after_timeout();
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   366
    },
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   367
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   368
/*
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   369
 * Update view state
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   370
 */              
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   371
 
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   372
    /** Update the view_* / center_offset_* vars, and any dependent items */
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   373
    update_size: function () {
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   374
        this.view_width = this.div.getWidth();
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   375
        this.view_height = this.div.getHeight();
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   376
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   377
        this.center_offset_x = Math.floor(this.view_width / 2);
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   378
        this.center_offset_y = Math.floor(this.view_height / 2);
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   379
        
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   380
        // the link-to-image uses the current view size
40
5454d2e2f633 add link-to-image feature
Tero Marttila <terom@fixme.fi>
parents: 39
diff changeset
   381
        this.update_image_link();
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   382
    },
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   383
   
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   384
    /**
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   385
     * Update the scroll_x/y state
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   386
     */    
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   387
    update_scroll: function() {
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   388
        this.scroll_x = -parseInt(this.substrate.style.left);
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   389
        this.scroll_y = -parseInt(this.substrate.style.top);
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   390
    },
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   391
    
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   392
    /**
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   393
     * Switch zoom layers
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   394
     */
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   395
    update_zoom: function (delta) {
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   396
        // is the new zoom level valid?
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   397
        if (!this.zoom_layers[this.zoom_layer.level + delta])
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   398
            return false;
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   399
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   400
        var zoom_old = this.zoom_layer;
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   401
        var zoom_new = this.zoom_layers[this.zoom_layer.level + delta];
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   402
        
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   403
        // XXX: clear hide-zoom-after-timeout
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   404
        if (this.zoom_timer) {
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   405
            clearTimeout(this.zoom_timer);
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   406
            this.zoom_timer = null;
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   407
        }
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   408
        
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   409
        // get other zoom layers out of the way
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   410
        // XXX: u
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   411
        this.zoom_layers.each(function (zl) {
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   412
            zl.disable();
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   413
        });
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   414
        
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   415
        // update the current zoom layer
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   416
        this.zoom_layer = zoom_new;
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   417
        
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   418
        // layer them such that the old on remains visible underneath the new one
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   419
        zoom_new.enable(11);
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   420
        zoom_old.enable(10);
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   421
        
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   422
        // resize the tiles in the two zoom layers
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   423
        zoom_new.update_tiles(zoom_new.level);
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   424
        zoom_old.update_tiles(zoom_new.level);
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   425
        
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   426
        // disable the old zoom layer after 1000ms - after the new zoom layer has loaded - not an optimal solution
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   427
        this.zoom_timer = setTimeout(function () { zoom_old.disable()}, 1000);
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   428
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   429
        // update UI state
39
eeedb6c2f7c0 zoom button UI
Tero Marttila <terom@fixme.fi>
parents: 38
diff changeset
   430
        this.update_zoom_ui();
eeedb6c2f7c0 zoom button UI
Tero Marttila <terom@fixme.fi>
parents: 38
diff changeset
   431
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   432
        return true;
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   433
    },
39
eeedb6c2f7c0 zoom button UI
Tero Marttila <terom@fixme.fi>
parents: 38
diff changeset
   434
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   435
    /** Schedule an update_tiles() after a 100ms interval */
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   436
    update_after_timeout: function () {
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   437
        // have not called update_tiles() yet
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   438
        this._update_idle = false;
39
eeedb6c2f7c0 zoom button UI
Tero Marttila <terom@fixme.fi>
parents: 38
diff changeset
   439
        
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   440
        // cancel old timeout
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   441
        if (this._update_timeout)
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   442
            clearTimeout(this._update_timeout);
40
5454d2e2f633 add link-to-image feature
Tero Marttila <terom@fixme.fi>
parents: 39
diff changeset
   443
        
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   444
        // trigger in 100ms
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   445
        this._update_timeout = setTimeout(this._update_timeout_trigger.bind(this), 100);  
39
eeedb6c2f7c0 zoom button UI
Tero Marttila <terom@fixme.fi>
parents: 38
diff changeset
   446
    },
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   447
    
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   448
    _update_timeout_trigger: function () {
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   449
        // have called update_tiles()
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   450
        this._update_idle = true;
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   451
        
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   452
        this.update_tiles();
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   453
    },
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   454
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   455
    /** 
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   456
     * Unschedule the call to update_tiles() and call it now, unless it's already been triggered by the previous call to
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   457
     * update_after_timeout
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   458
     */
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   459
    update_now: function () {
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   460
        // abort trigger if active
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   461
        if (this._update_timeout)
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   462
            clearTimeout(this._update_timeout);
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   463
        
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   464
        // update now unless already done
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   465
        if (!this._update_idle)
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   466
            this.update_tiles();
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   467
    },
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   468
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   469
    /**
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   470
     * Determine the set of visible tiles, and ensure they are loaded
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   471
     */
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   472
    update_tiles: function () {
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   473
        // short names for some vars...
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   474
        var x = this.scroll_x;
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   475
        var y = this.scroll_y;
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   476
        var sw = this.view_width;
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   477
        var sh = this.view_height;
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   478
        var tw = this.source.tile_width;
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   479
        var th = this.source.tile_height;
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   480
        var zl = this.zoom_layer.level;
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   481
        
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   482
        // figure out which set of cols/rows are visible 
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   483
        var start_col = Math.max(0, Math.floor(x / tw));
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   484
        var start_row = Math.max(0, Math.floor(y / th));
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   485
        var end_col = Math.floor((x + sw) / tw);
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   486
        var end_row = Math.floor((y + sh) / th);
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   487
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   488
        // loop through all visible tiles
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   489
        for (var col = start_col; col <= end_col; col++) {
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   490
            for (var row = start_row; row <= end_row; row++) {
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   491
                // the tile's id
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   492
                var id = "tile_" + zl + "_" + col + "_" + row;
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   493
                
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   494
                // does the element exist already?
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   495
                // XXX: use basic document.getElementById for perf?
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   496
                var t = $(id);
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   497
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   498
                if (!t) {
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   499
                    // build a new tile
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   500
                    t = Builder.node("img", {
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   501
                            src:    this.source.build_url(col, row, zl /* , sw, sh */),
46
82d7b4d64cc6 fixes for IE8
Tero Marttila <terom@fixme.fi>
parents: 45
diff changeset
   502
                            id:     id //,
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   503
                            // title:  "(" + col + ", " + row + ")",
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   504
                            // style set later
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   505
                        }
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   506
                    );
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   507
                    
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   508
                    // position
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   509
                    t.style.top = th * row;
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   510
                    t.style.left = tw * col;
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   511
                    t.style.display = "none";
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   512
                    
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   513
                    // display once loaded
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   514
                    Event.observe(t, "load", _tile_loaded.bindAsEventListener(t));
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   515
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   516
                    // remember the col/row
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   517
                    t.__col = col;
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   518
                    t.__row = row;
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   519
                    
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   520
                    // add it to the zoom layer
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   521
                    this.zoom_layer.add_tile(t);
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   522
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   523
                } else if (this.source.reload) {
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   524
                    // force the tile to reload
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   525
                    touch_tile(t, col, row);
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   526
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   527
                }
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   528
            }
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   529
        }
40
5454d2e2f633 add link-to-image feature
Tero Marttila <terom@fixme.fi>
parents: 39
diff changeset
   530
        
5454d2e2f633 add link-to-image feature
Tero Marttila <terom@fixme.fi>
parents: 39
diff changeset
   531
        this.update_scroll_ui();
5454d2e2f633 add link-to-image feature
Tero Marttila <terom@fixme.fi>
parents: 39
diff changeset
   532
    }, 
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   533
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   534
/*
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   535
 * UI state
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   536
 */                  
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   537
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   538
    /**
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   539
     * Update any zl-dependant UI elements
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   540
     */
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   541
    update_zoom_ui: function () {
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   542
        // deactivate zoom-in button if zoomed in
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   543
        if (this.btn_zoom_in)
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   544
            (this.zoom_layer.level >= this.source.zoom_max) ? this.btn_zoom_in.disable() : this.btn_zoom_in.enable();
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   545
        
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   546
        // deactivate zoom-out button if zoomed out
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   547
        if (this.btn_zoom_out)
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   548
            (this.zoom_layer.level <= this.source.zoom_min) ? this.btn_zoom_out.disable() : this.btn_zoom_out.enable();
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   549
        
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   550
        // link-to-image
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   551
        this.update_image_link();
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   552
    },
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   553
 
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   554
    /**
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   555
     * Update any position-dependant UI elements
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   556
     */ 
40
5454d2e2f633 add link-to-image feature
Tero Marttila <terom@fixme.fi>
parents: 39
diff changeset
   557
    update_scroll_ui: function () {
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   558
        // update the link-to-this-page thing
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   559
        document.location.hash = "#" + (this.scroll_x + this.center_offset_x) + ":" + (this.scroll_y + this.center_offset_y) + ":" + this.zoom_layer.level;
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   560
        
40
5454d2e2f633 add link-to-image feature
Tero Marttila <terom@fixme.fi>
parents: 39
diff changeset
   561
        // update link-to-image
5454d2e2f633 add link-to-image feature
Tero Marttila <terom@fixme.fi>
parents: 39
diff changeset
   562
        this.update_image_link();
5454d2e2f633 add link-to-image feature
Tero Marttila <terom@fixme.fi>
parents: 39
diff changeset
   563
    },
5454d2e2f633 add link-to-image feature
Tero Marttila <terom@fixme.fi>
parents: 39
diff changeset
   564
    
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   565
    /**
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   566
     * Update the link-to-image-of-this-view link with dimensions, zoom, position
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   567
     */
40
5454d2e2f633 add link-to-image feature
Tero Marttila <terom@fixme.fi>
parents: 39
diff changeset
   568
    update_image_link: function () {
5454d2e2f633 add link-to-image feature
Tero Marttila <terom@fixme.fi>
parents: 39
diff changeset
   569
        if (!this.image_link)
5454d2e2f633 add link-to-image feature
Tero Marttila <terom@fixme.fi>
parents: 39
diff changeset
   570
            return;
5454d2e2f633 add link-to-image feature
Tero Marttila <terom@fixme.fi>
parents: 39
diff changeset
   571
5454d2e2f633 add link-to-image feature
Tero Marttila <terom@fixme.fi>
parents: 39
diff changeset
   572
        this.image_link.href = this.source.build_image_url(
5454d2e2f633 add link-to-image feature
Tero Marttila <terom@fixme.fi>
parents: 39
diff changeset
   573
            this.scroll_x + this.center_offset_x,
5454d2e2f633 add link-to-image feature
Tero Marttila <terom@fixme.fi>
parents: 39
diff changeset
   574
            this.scroll_y + this.center_offset_y,
5454d2e2f633 add link-to-image feature
Tero Marttila <terom@fixme.fi>
parents: 39
diff changeset
   575
            this.view_width, this.view_height,
5454d2e2f633 add link-to-image feature
Tero Marttila <terom@fixme.fi>
parents: 39
diff changeset
   576
            this.zoom_layer.level
5454d2e2f633 add link-to-image feature
Tero Marttila <terom@fixme.fi>
parents: 39
diff changeset
   577
        );
5454d2e2f633 add link-to-image feature
Tero Marttila <terom@fixme.fi>
parents: 39
diff changeset
   578
5454d2e2f633 add link-to-image feature
Tero Marttila <terom@fixme.fi>
parents: 39
diff changeset
   579
        this.image_link.innerHTML = this.view_width + "x" + this.view_height + "@" + this.zoom_layer.level;
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   580
    }
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   581
});
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   582
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   583
/** Used by Viewport.update_tiles to make a tile visible after it has loaded */
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   584
function _tile_loaded (ev) {
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   585
    this.style.display = "block";
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   586
}
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   587
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   588
/**
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   589
 * A zoom layer contains a (col, row) grid of tiles at a specific zoom level. 
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   590
 */
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   591
var ZoomLayer = Class.create({
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   592
    initialize: function (source, zoom_level) {
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   593
        this.source = source;
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   594
        this.level = zoom_level;
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   595
        this.div = Builder.node("div", { id: "zl_" + this.level, style: "position: relative; display: none;"});
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   596
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   597
        // our tiles
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   598
        this.tiles = [];
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   599
    },
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   600
    
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   601
    /** Add a tile to this zoom layer's grid */
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   602
    add_tile: function (tile) {
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   603
        this.div.appendChild(tile);
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   604
        this.tiles.push(tile);
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   605
    },
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   606
    
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   607
    /** Make this zoom layer visible with the given z-index */
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   608
    enable: function (z_index) {
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   609
        this.div.style.zIndex = z_index;
46
82d7b4d64cc6 fixes for IE8
Tero Marttila <terom@fixme.fi>
parents: 45
diff changeset
   610
82d7b4d64cc6 fixes for IE8
Tero Marttila <terom@fixme.fi>
parents: 45
diff changeset
   611
        // XXX: IE8 needs this for some reason
82d7b4d64cc6 fixes for IE8
Tero Marttila <terom@fixme.fi>
parents: 45
diff changeset
   612
        $(this.div).show();
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   613
    },
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   614
   
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   615
    /** Hide this zoom layer */
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   616
    disable: function () {
46
82d7b4d64cc6 fixes for IE8
Tero Marttila <terom@fixme.fi>
parents: 45
diff changeset
   617
        // XXX: IE8
82d7b4d64cc6 fixes for IE8
Tero Marttila <terom@fixme.fi>
parents: 45
diff changeset
   618
        $(this.div).hide();
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   619
    },
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   620
    
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   621
    /** 
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   622
     * Update the tile grid in this zoom layer such the tiles are in the correct position and of the correct size
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   623
     * when viewed with the given zoom level.
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   624
     *
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   625
     * For zoom levels different than this layer's level, this will resize the tiles!
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   626
     */
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   627
    update_tiles: function (zoom_level) {
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   628
        var zd = zoom_level - this.level;
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   629
        
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   630
        // desired tile size
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   631
        var tw = scaleByZoomDelta(this.source.tile_width, zd);
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   632
        var th = scaleByZoomDelta(this.source.tile_height, zd);
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   633
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   634
        var tiles = this.tiles;
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   635
        var tiles_len = tiles.length;
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   636
        var t, ts;
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   637
        
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   638
        // XXX: *all* tiles? :/
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   639
        for (var i = 0; i < tiles_len; i++) {
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   640
            t = tiles[i];
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   641
            ts = t.style;
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   642
            
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   643
            // reposition
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   644
            ts.width = tw;
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   645
            ts.height = th;
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   646
            ts.top = th * t.__row;
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   647
            ts.left = tw * t.__col;
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   648
        }
45
0ce4064c428e cleanup tiles2.js, fix scaling of old layer when zooming, and have double-click always center
Tero Marttila <terom@fixme.fi>
parents: 43
diff changeset
   649
    }
30
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   650
});
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   651
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   652
// scale the given co-ordinate by a zoom delta. If we zoom in (dz > 0), n will become larger, and if we zoom 
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   653
// out (dz < 0), n will become smaller.
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   654
function scaleByZoomDelta (n, dz) {
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   655
    if (dz > 0)
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   656
        return n << dz;
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   657
    else
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   658
        return n >> -dz;
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   659
}
53e99e552122 move the python/web code in
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   660