AI-generated Key Takeaways
- 
          Photostores metadata for a single photo associated with a place, including attributions, author information, and maximum size.
- 
          It conforms to CustomStringConvertible,Equatable, andHashablefor describing, comparing, and uniquely identifying photos.
- 
          The attributionsproperty provides an attributed string detailing data provider credits, which should be displayed to users.
- 
          Photos can be instantiated for testing purposes using initializers that accept size, attributions, and author details. 
Photo
struct Photoextension Photo : Copyable, CustomStringConvertible, Equatable, Escapable, Hashable, SendableThe metadata corresponding to a single photo associated with a place.
- 
                  
                  Returns a Boolean value indicating whether two values are equal. Equality is the inverse of inequality. For any values aandb,a == bimplies thata != bisfalse.DeclarationSwift static func == (lhs: Photo, rhs: Photo) -> BoolParameterslhsA value to compare. rhsAnother value to compare. 
- 
                  
                  The data provider attribution string for this photo. These are provided as a NSAttributedString, which may contain hyperlinks to the website of each provider. In general, these must be shown to the user if data from this PlacePhotoMetadatais shown, as described in the Places SDK Terms of Service.DeclarationSwift var attributions: AttributedString? { get }
- 
                  
                  DeclarationSwift var authorAttributions: [AuthorAttribution] { get }
- 
                  
                  A textual representation of this instance. Calling this property directly is discouraged. Instead, convert an instance of any type to a string by using the String(describing:)initializer. This initializer works with any type, and uses the customdescriptionproperty for types that conform toCustomStringConvertible:struct Point: CustomStringConvertible { let x: Int, y: Int var description: String { return "(\(x), \(y))" } } let p = Point(x: 21, y: 30) let s = String(describing: p) print(s) // Prints "(21, 30)"The conversion of pto a string in the assignment tosuses thePointtype’sdescriptionproperty.DeclarationSwift var description: String { get }
- 
                  
                  Hashes the essential components of this value by feeding them into the given hasher. Implement this method to conform to the Hashableprotocol. The components used for hashing must be the same as the components compared in your type’s==operator implementation. Callhasher.combine(_:)with each of these components.Important In your implementation of hash(into:), don’t callfinalize()on thehasherinstance provided, or replace it with a different instance. Doing so may become a compile-time error in the future.DeclarationSwift func hash(into hasher: inout Hasher)
- 
                  
                  The hash value. Hash values are not guaranteed to be equal across different executions of your program. Do not save hash values to use during a future execution. Important hashValueis deprecated as aHashablerequirement. To conform toHashable, implement thehash(into:)requirement instead. The compiler provides an implementation forhashValuefor you.DeclarationSwift var hashValue: Int { get }
- 
                  
                  Instantiates a Photowith the specified information.Photos can be gotten from aPlaceobject. This initializer can be used for testing.DeclarationSwift init(maxSize: CGSize, attributions: AttributedString? = nil, authorAttributions: [AuthorAttribution] = [])ParametersmaxSizeThe maximum pixel size in which this photo is available. attributionsThe data provider attribution string for this photo. authorAttributionsThe optional author attributions for this photo. Return ValueA Photocontaining the specified information.
- 
                  
                  Instantiates a Photowith the specified information.Photos can be gotten from aPlaceobject. This initializer can be used for testing.DeclarationSwift init(maxSize: CGSize, attributions: NSAttributedString?, authorAttributions: [AuthorAttribution] = [])ParametersmaxSizeThe maximum pixel size in which this photo is available. attributionsThe data provider attribution string for this photo. authorAttributionsThe optional author attributions for this photo. Return ValueA Photocontaining the specified information.
- 
                  
                  The data provider attribution string for this photo. These are provided as a NSAttributedString, which may contain hyperlinks to the website of each provider. In general, these must be shown to the user if data from this PlacePhotoMetadatais shown, as described in the Places SDK Terms of Service.DeclarationSwift var legacyAttributions: NSAttributedString? { get }
- 
                  
                  The maximum pixel size in which this photo is available. DeclarationSwift var maxSize: CGSize { get }