1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55

/// `Zone` represents a Lambert projection zone.
#[derive(Copy, Clone)]
pub enum Zone {
    LambertI,
    LambertII,
    LambertIII,
    LambertIV,
    LambertIIe,
    Lambert93
}

pub fn n(zone:Zone) -> f32 {
    match zone {
        Zone::LambertI => 0.7604059656,
        Zone::LambertII => 0.7289686274,
        Zone::LambertIII => 0.6959127966,
        Zone::LambertIV => 0.6712679322,
        Zone::LambertIIe => 0.7289686274,
        Zone::Lambert93 =>  0.7256077650,
    }
}

pub fn c(zone:Zone) -> f32 {
    match zone {
        Zone::LambertI => 11603796.98,
        Zone::LambertII => 11745793.39,
        Zone::LambertIII => 11947992.52,
        Zone::LambertIV => 12136281.99,
        Zone::LambertIIe => 11745793.39,
        Zone::Lambert93 =>  11754255.426,
    }
}

pub fn xs(zone:Zone) -> f32 {
    match zone {
        Zone::LambertI => 600000.0,
        Zone::LambertII => 600000.0,
        Zone::LambertIII => 600000.0,
        Zone::LambertIV => 234.358,
        Zone::LambertIIe => 600000.0,
        Zone::Lambert93 =>  700000.0,
    }
}

pub fn ys(zone:Zone) -> f32 {
    match zone {
        Zone::LambertI => 5657616.674,
        Zone::LambertII => 6199695.768,
        Zone::LambertIII => 6791905.085,
        Zone::LambertIV => 7239161.542,
        Zone::LambertIIe => 8199695.768,
        Zone::Lambert93 =>  12655612.050,
    }
}