/MapView/Map/RMTileCache.h

http://github.com/route-me/route-me · C Header · 77 lines · 25 code · 17 blank · 35 comment · 0 complexity · 651fba5d0f94c947beb44d573e0c22a5 MD5 · raw file

  1. //
  2. // RMTileCache.h
  3. //
  4. // Copyright (c) 2008-2009, Route-Me Contributors
  5. // All rights reserved.
  6. //
  7. // Redistribution and use in source and binary forms, with or without
  8. // modification, are permitted provided that the following conditions are met:
  9. //
  10. // * Redistributions of source code must retain the above copyright notice, this
  11. // list of conditions and the following disclaimer.
  12. // * Redistributions in binary form must reproduce the above copyright notice,
  13. // this list of conditions and the following disclaimer in the documentation
  14. // and/or other materials provided with the distribution.
  15. //
  16. // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
  17. // AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  18. // IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  19. // ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
  20. // LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
  21. // CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
  22. // SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
  23. // INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
  24. // CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
  25. // ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
  26. // POSSIBILITY OF SUCH DAMAGE.
  27. #import <Foundation/Foundation.h>
  28. #import "RMTile.h"
  29. #import "RMTileSource.h"
  30. @class RMTileImage;
  31. typedef enum {
  32. RMCachePurgeStrategyLRU,
  33. RMCachePurgeStrategyFIFO,
  34. } RMCachePurgeStrategy;
  35. @protocol RMTileCache<NSObject>
  36. /// Returns the cached image if it exists. nil otherwise.
  37. -(RMTileImage*) cachedImage:(RMTile)tile;
  38. -(void)didReceiveMemoryWarning;
  39. @optional
  40. -(void)addTile: (RMTile)tile WithImage: (RMTileImage*)image;
  41. /// removes all tile images from the memory and disk subcaches
  42. -(void)removeAllCachedImages;
  43. @end
  44. @interface RMTileCache : NSObject<RMTileCache>
  45. {
  46. NSMutableArray *caches;
  47. }
  48. -(id)initWithTileSource: (id<RMTileSource>) tileSource;
  49. +(NSNumber*) tileHash: (RMTile)tile;
  50. /// Add tile to cache
  51. /*!
  52. \bug Calls -makeSpaceInCache for every tile/image addition. -makeSpaceInCache does a linear scan of its contents at each call.
  53. \bug Since RMTileImage has an RMTile ivar, this API should be simplified to just -addImage:.
  54. */
  55. -(void)addTile: (RMTile)tile WithImage: (RMTileImage*)image;
  56. /// Add another cache to the chain
  57. -(void)addCache: (id<RMTileCache>)cache;
  58. -(void)didReceiveMemoryWarning;
  59. @end