Skip to content

Commit

Permalink
Expose extra MapboxMap APIs (#1993)
Browse files Browse the repository at this point in the history
* Expose extra APIs for MapboxMap

* Add changelog entry

* Update mapbox-maps-ios/CHANGELOG.md

Co-authored-by: Patrick Leonard <pjleonard37@users.noreply.github.com>

* Add negative side effects to the documentation of reduceMemoryUse()

---------

Co-authored-by: Patrick Leonard <pjleonard37@users.noreply.github.com>
  • Loading branch information
evil159 and pjleonard37 authored Jan 25, 2024
1 parent c1a2e9b commit d83148d
Show file tree
Hide file tree
Showing 4 changed files with 53 additions and 11 deletions.
4 changes: 4 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,10 @@ Mapbox welcomes participation and contributions from everyone.
* Fix glitch in chained camera animations.
* Build XCFramework with `SWIFT_SERIALIZE_DEBUGGING_OPTIONS=NO` flag to avoid serialized search paths in Swift modules.
* Fixed a crash that occurs when annotations have duplicate identifiers.
* Expose extra configuration methods for `MapboxMap`: `setNorthOrientation(_:)`, `setConstrainMode(_:)` and `setViewportMode(_:)`.
Use them to configure respective map options after creating a map view.
* Expose `MapboxMap.reduceMemoryUse()` which can be used in situations when it is important to keep the memory footprint minimal.
* Expose `MapboxMap.isAnimationInProgress` and `MapboxMap.isGestureInProgress` to query current status of both built-in and custom camera animations and gestures.

## 11.1.0 - 17 January, 2024

Expand Down
42 changes: 32 additions & 10 deletions Sources/MapboxMaps/Foundation/MapboxMap.swift
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ protocol MapboxMapProtocol: AnyObject {
var options: MapOptions { get }
func setCamera(to cameraOptions: CameraOptions)
func setCameraBounds(with options: CameraBoundsOptions) throws
func setNorthOrientation(northOrientation: NorthOrientation)
func setNorthOrientation(_ northOrientation: NorthOrientation)
func setConstrainMode(_ constrainMode: ConstrainMode)
func setViewportMode(_ viewportMode: ViewportMode)
func dragCameraOptions(from: CGPoint, to: CGPoint) -> CameraOptions
Expand Down Expand Up @@ -291,9 +291,13 @@ public final class MapboxMap: StyleManager {
}
}

/// Reduces memory use. Useful to call when the application gets paused or
/// Reduces memory use. This is called automatically when the application gets paused or
/// sent to background.
internal func reduceMemoryUse() {
///
/// Calling this might have lead to temporary increased CPU load, as in-memory caches of tiles, images, textures etc.
/// will be cleared. This will cause the map to fetch the required resources anew.
/// For example, the map tiles will be re-created for the currently displayed portion of the map.
public func reduceMemoryUse() {
__map.reduceMemoryUse()
}

Expand Down Expand Up @@ -405,21 +409,21 @@ public final class MapboxMap: StyleManager {
/// Set the map north orientation
///
/// - Parameter northOrientation: The map north orientation to set
func setNorthOrientation(northOrientation: NorthOrientation) {
public func setNorthOrientation(_ northOrientation: NorthOrientation) {
__map.setNorthOrientationFor(northOrientation)
}

/// Set the map constrain mode
///
/// - Parameter constrainMode: The map constraint mode to set
func setConstrainMode(_ constrainMode: ConstrainMode) {
public func setConstrainMode(_ constrainMode: ConstrainMode) {
__map.setConstrainModeFor(constrainMode)
}

/// Set the map viewport mode
///
/// - Parameter viewportMode: The map viewport mode to set
func setViewportMode(_ viewportMode: ViewportMode) {
public func setViewportMode(_ viewportMode: ViewportMode) {
__map.setViewportModeFor(viewportMode)
}

Expand Down Expand Up @@ -786,10 +790,18 @@ public final class MapboxMap: StyleManager {

// MARK: - Gesture and Animation Flags

/// Returns `true` if an animation is currently in progress.
public var isAnimationInProgress: Bool { __map.isUserAnimationInProgress() }

private var animationCount = 0

/// If implementing a custom animation mechanism, call this method when the animation begins.
/// Must always be paired with a corresponding call to `endAnimation()`
///
/// Tells the map rendering engine that the animation is currently performed by the
/// user (e.g. with a `setCamera` calls series). It adjusts the engine for the animation use case.
/// In particular, it brings more stability to symbol placement and rendering.
///
/// - Note: Must always be paired with a corresponding call to `endAnimation()`.
public func beginAnimation() {
animationCount += 1
if animationCount == 1 {
Expand All @@ -798,7 +810,8 @@ public final class MapboxMap: StyleManager {
}

/// If implementing a custom animation mechanism, call this method when the animation ends.
/// Must always be paired with a corresponding call to `beginAnimation()`
///
/// - Note: Must always be paired with a corresponding call to `beginAnimation()`.
public func endAnimation() {
assert(animationCount > 0)
animationCount -= 1
Expand All @@ -807,10 +820,18 @@ public final class MapboxMap: StyleManager {
}
}

/// Returns `true` if a gesture is currently in progress.
public var isGestureInProgress: Bool { __map.isGestureInProgress() }

private var gestureCount = 0

/// If implementing a custom gesture, call this method when the gesture begins.
/// Must always be paired with a corresponding call to `endGesture()`
///
/// Tells the map rendering engine that there is currently a gesture in progress. This
/// affects how the map renders labels, as it will use different texture filters if a gesture
/// is ongoing.
///
/// - Note: Must always be paired with a corresponding call to `endGesture()`
public func beginGesture() {
gestureCount += 1
if gestureCount == 1 {
Expand All @@ -820,7 +841,8 @@ public final class MapboxMap: StyleManager {
}

/// If implementing a custom gesture, call this method when the gesture ends.
/// Must always be paired with a corresponding call to `beginGesture()`
///
/// - Note: Must always be paired with a corresponding call to `beginGesture()`.
public func endGesture() {
assert(gestureCount > 0)
gestureCount -= 1
Expand Down
16 changes: 16 additions & 0 deletions Tests/MapboxMapsTests/Foundation/MapboxMapTests.swift
Original file line number Diff line number Diff line change
Expand Up @@ -250,6 +250,14 @@ final class MapboxMapTests: XCTestCase {
_ = mapboxMap as MapFeatureQueryable
}

func testGetAnimationInProgressGetter() {
XCTAssertFalse(mapboxMap.isAnimationInProgress)

mapboxMap.__testingMap.setUserAnimationInProgressForInProgress(true)

XCTAssertTrue(mapboxMap.isAnimationInProgress)
}

func testBeginAndEndAnimation() {
XCTAssertFalse(mapboxMap.__testingMap.isUserAnimationInProgress())

Expand Down Expand Up @@ -278,6 +286,14 @@ final class MapboxMapTests: XCTestCase {
XCTAssertFalse(mapboxMap.__testingMap.isUserAnimationInProgress())
}

func testGetGestureInProgressGetter() {
XCTAssertFalse(mapboxMap.isGestureInProgress)

mapboxMap.__testingMap.setGestureInProgressForInProgress(true)

XCTAssertTrue(mapboxMap.isGestureInProgress)
}

func testBeginAndEndGesture() {
XCTAssertFalse(mapboxMap.__testingMap.isGestureInProgress())

Expand Down
2 changes: 1 addition & 1 deletion Tests/MapboxMapsTests/Foundation/Mocks/MockMapboxMap.swift
Original file line number Diff line number Diff line change
Expand Up @@ -168,7 +168,7 @@ final class MockMapboxMap: MapboxMapProtocol {
}

let northOrientationStub = Stub<NorthOrientation, Void>()
func setNorthOrientation(northOrientation: NorthOrientation) {
func setNorthOrientation(_ northOrientation: NorthOrientation) {
northOrientationStub.call(with: northOrientation)
}

Expand Down

0 comments on commit d83148d

Please sign in to comment.