-
Notifications
You must be signed in to change notification settings - Fork 34
/
Copy pathARTiledImageViewDataSource.h
88 lines (76 loc) · 2.22 KB
/
ARTiledImageViewDataSource.h
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
//
// ARTiledImageViewDataSource.h
// ARTiledImageView
//
// Created by Daniel Doubrovkine on 3/10/14.
// Copyright (c) 2014 Artsy. All rights reserved.
//
@class ARTiledImageView;
/**
* An ARTiledMapView data source.
*/
@protocol ARTiledImageViewDataSource
/**
* Return a UIImage for a tile, if available, for example from local storage.
*
* @param imageView Tiled image view.
* @param level Zoom level.
* @param x X coordinate of the tile.
* @param y Y coordinate of the tile.
*
* @return A UIImage of the tile, when available, otherwise nil.
*/
- (UIImage *)tiledImageView:(ARTiledImageView *)imageView imageTileForLevel:(NSInteger)level x:(NSInteger)x y:(NSInteger)y;
/**
* Tile size.
*
* @param imageView Tiled image view.
*
* @return CGSize of a single tile.
*/
- (CGSize)tileSizeForImageView:(ARTiledImageView *)imageView;
/**
* Size of the full, zoomed in, tiled image.
*
* @param imageView Tiled image view.
*
* @return CGSize of a full image.
*/
- (CGSize)imageSizeForImageView:(ARTiledImageView *)imageView;
/**
* Minimum zoom level.
*
* @param imageView Tiled image view.
*
* @return Minimum zoom level.
*/
- (NSInteger)minimumImageZoomLevelForImageView:(ARTiledImageView *)imageView;
/**
* Maximum zoom level.
*
* @param imageView Tiled image view.
*
* @return Maximum zoom level.
*/
- (NSInteger)maximumImageZoomLevelForImageView:(ARTiledImageView *)imageView;
@optional
/**
* Return an URL for an image tile.
*
* @param imageView Tiled image view.
* @param level Zoom level.
* @param x X coordinate of the tile.
* @param y Y coordinate of the tile.
*
* @return An NSURL where the tile can be downloaded from.
*/
- (NSURL *)tiledImageView:(ARTiledImageView *)imageView urlForImageTileAtLevel:(NSInteger)level x:(NSInteger)x y:(NSInteger)y;
/**
* Callback when an image tile has been downloaded. Use this method to cache tiles in local storage, for example.
*
* @param imageView Tiled image view.
* @param image UIImage of the tile.
* @param url URL from which the tile has been downloaded.
*/
- (void)tiledImageView:(ARTiledImageView *)imageView didDownloadTiledImage:(UIImage *)image atURL:(NSURL *)url;
@end