AI-generated Key Takeaways
- 
          GMSTileLayeris an abstract class for overlaying custom image tiles on aGMSMapView, requiring subclasses to implement therequestTileForX:y:zoom:receiver:method.
- 
          Tiles are organized by zoom levels, with zoom level 0 representing the whole world as a single tile and increasing zoom levels subdividing the map into more tiles. 
- 
          Developers can customize tile size, opacity, fade-in behavior, and z-index (draw order) for the tile layer. 
- 
          GMSTileLayerprovides methods to clear the tile cache and to associate the layer with a specificGMSMapViewfor display.
GMSTileLayer
@interface GMSTileLayer : NSObjectGMSTileLayer is an abstract class that allows overlaying of custom image tiles on a specified
 GMSMapView. It may not be initialized directly, and subclasses must implement the
 tileForX:y:zoom: method to return tiles.
At zoom level 0 the whole world is a square covered by a single tile, and the coordinates x and
 y are both 0 for that tile. At zoom level 1, the world is covered by 4 tiles with x and y
 being 0 or 1, and so on.
- 
                  
                  -requestTileForX:y:zoom:receiver:generates image tiles forGMSTileOverlay. It must be overridden by subclasses. The tile for the givenx,yandzoommust be later passed toreceiver.Specify kGMSTileLayerNoTileif no tile is available for this location; or nil if a transient error occurred and a tile may be available later.Calls to this method will be made on the main thread. See GMSSyncTileLayerfor a base class that implements a blocking tile layer that does not run on your application’s main thread.DeclarationSwift func requestTileFor(x: UInt, y: UInt, zoom: UInt, receiver: any GMSTileReceiver)Objective-C - (void)requestTileForX:(NSUInteger)x y:(NSUInteger)y zoom:(NSUInteger)zoom receiver:(nonnull id<GMSTileReceiver>)receiver;
- 
                  
                  Clears the cache so that all tiles will be requested again. DeclarationSwift func clearTileCache()Objective-C - (void)clearTileCache;
- 
                  
                  The map this GMSTileOverlayis displayed on. Setting this property will add the layer to the map. Setting it to nil removes this layer from the map. A layer may be active on at most one map at any given time.DeclarationSwift weak var map: GMSMapView? { get set }Objective-C @property (nonatomic, weak, nullable) GMSMapView *map;
- 
                  
                  Higher zIndexvalue tile layers will be drawn on top of lowerzIndexvalue tile layers and overlays. Equal values result in undefined draw ordering.DeclarationSwift var zIndex: Int32 { get set }Objective-C @property (nonatomic) int zIndex;
- 
                  
                  Specifies the number of pixels (not points) that the returned tile images will prefer to display as. For best results, this should be the edge length of your custom tiles. Defaults to 256, which is the traditional size of Google Maps tiles. Values less than the equivalent of 128 points (e.g. 256 pixels on retina devices) may not perform well and are not recommended. As an example, an application developer may wish to provide retina tiles (512 pixel edge length) on retina devices, to keep the same number of tiles per view as the default value of 256 would give on a non-retina device. DeclarationSwift var tileSize: Int { get set }Objective-C @property (nonatomic) NSInteger tileSize;
- 
                  
                  Specifies the opacity of the tile layer. This provides a multiplier for the alpha channel of tile images. DeclarationSwift var opacity: Float { get set }Objective-C @property (nonatomic) float opacity;
- 
                  
                  Specifies whether the tiles should fade in. Default YES. DeclarationSwift var fadeIn: Bool { get set }Objective-C @property (nonatomic) BOOL fadeIn;