aboutsummaryrefslogtreecommitdiffstats
path: root/t/app/03podcoverage.t
Commit message (Collapse)AuthorAgeLines
* rename to tidy up test suiteEdmund von der Burg2011-02-22-0/+14
ef='#n20'>20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74
#!/usr/bin/perl
#
# FixMyStreet:Map::FMS
# Bing and OS StreetView maps on FixMyStreet, using OpenLayers.
#
# Copyright (c) 2011 UK Citizens Online Democracy. All rights reserved.
# Email: matthew@mysociety.org; WWW: http://www.mysociety.org/

package FixMyStreet::Map::FMS;
use base 'FixMyStreet::Map::OSM';

use strict;

# Is set by the JavaScript
sub map_type {
    return '""';
}

sub map_template {
    return 'fms';
}

sub copyright {
    return '';
}

sub get_quadkey {
    my ($x, $y, $z) = @_;
    my $key = '';
    for (my $i = $z; $i > 0; $i--) {
        my $digit = 0;
        my $mask = 1 << ($i - 1);
        $digit++ if ($x & $mask) != 0;
        $digit += 2 if ($y & $mask) != 0;
        $key .= $digit;
    }
    return $key;
}

sub map_tile_base {
    '.', "http://%stilma.mysociety.org/sv/%d/%d/%d.png";
}

sub map_tiles {
    my ( $self, %params ) = @_;
    my ( $x, $y, $z ) = ( $params{x_tile}, $params{y_tile}, $params{zoom_act} );
    my $ni = in_northern_ireland_box( $params{latitude}, $params{longitude} );
    if (!$ni && $z >= 16) {
        my ($tile_sep, $tile_base) = $self->map_tile_base;
        return [
            sprintf($tile_base, 'a' . $tile_sep, $z, $x-1, $y-1),
            sprintf($tile_base, 'b' . $tile_sep, $z, $x, $y-1),
            sprintf($tile_base, 'c' . $tile_sep, $z, $x-1, $y),
            sprintf($tile_base, '', $z, $x, $y),
        ];
    } else {
        my $url = "g=701";
        $url .= "&productSet=mmOS" if $z > 10 && !$ni;
        return [
            "//ecn.t0.tiles.virtualearth.net/tiles/r" . get_quadkey($x-1, $y-1, $z) . ".png?$url",
            "//ecn.t1.tiles.virtualearth.net/tiles/r" . get_quadkey($x,   $y-1, $z) . ".png?$url",
            "//ecn.t2.tiles.virtualearth.net/tiles/r" . get_quadkey($x-1, $y,   $z) . ".png?$url",
            "//ecn.t3.tiles.virtualearth.net/tiles/r" . get_quadkey($x,   $y,   $z) . ".png?$url",
        ];
    }
}

sub in_northern_ireland_box {
    my ($lat, $lon) = @_;
    return 1 if $lat >= 54.015 && $lat <= 55.315 && $lon >= -8.18 && $lon <= -5.415;
    return 0;
}

1;