RMCachedTileSource.m
1.64 KB
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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
//
// RMCachedTileSource.m
// MapView
//
// Created by Joseph Gentle on 25/09/08.
// Copyright 2008 __MyCompanyName__. All rights reserved.
//
#import "RMCachedTileSource.h"
#import "RMTileCache.h"
@implementation RMCachedTileSource
- (id) initWithSource: (id<RMTileSource>) _source
{
if ([_source isKindOfClass:[RMCachedTileSource class]])
{
[self dealloc];
return _source;
}
if (![super init])
return nil;
tileSource = [_source retain];
cache = [[RMTileCache alloc] initWithTileSource:tileSource];
return self;
}
- (void) dealloc
{
[tileSource release];
[cache release];
[super dealloc];
}
+ (RMCachedTileSource*) cachedTileSourceWithSource: (id<RMTileSource>) source
{
// Doing this fixes a strange build warning...
id theSource = source;
return [[[RMCachedTileSource alloc] initWithSource:theSource] autorelease];
}
-(RMTileImage *) tileImage: (RMTile) tile
{
RMTileImage *cachedImage = [cache cachedImage:tile];
if (cachedImage != nil)
{
return cachedImage;
}
else
{
RMTileImage *image = [tileSource tileImage:tile];
[cache addTile:tile WithImage:image];
return image;
}
}
-(id<RMMercatorToTileProjection>) mercatorToTileProjection
{
return [tileSource mercatorToTileProjection];
}
-(RMProjection*) projection
{
return [tileSource projection];
}
- (id<RMTileSource>) underlyingTileSource
{
// I'm assuming that our tilesource isn't itself a cachedtilesource.
// This class's initialiser should make sure of that.
return tileSource;
}
-(float) minZoom
{
return [tileSource minZoom];
}
-(float) maxZoom
{
return [tileSource maxZoom];
}
- (void) didReceiveMemoryWarning
{
[cache didReceiveMemoryWarning];
}
@end