@rnmapbox/maps 10.2.7 → 10.2.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/android/build.gradle +9 -1
- package/android/src/main/java/com/rnmapbox/rnmbx/RNMBXPackage.kt +8 -0
- package/android/src/main/java/com/rnmapbox/rnmbx/components/mapview/RNMBXMapView.kt +7 -1
- package/android/src/main/java/com/rnmapbox/rnmbx/components/styles/RNMBXStyleFactory.kt +180 -0
- package/android/src/main/java/com/rnmapbox/rnmbx/components/styles/RNMBXStyleValue.kt +4 -0
- package/android/src/main/java/com/rnmapbox/rnmbx/modules/RNMBXModule.kt +2 -2
- package/android/src/main/java/com/rnmapbox/rnmbx/modules/RNMBXOfflineModuleLegacy.kt +10 -0
- package/android/src/main/mapbox-v11-compat/v10/com/mapbox/maps/extension/style/layers/generated/RasterParticleLayer.kt +58 -0
- package/android/src/main/mapbox-v11-compat/v10/com/mapbox/maps/extension/style/sources/generated/RasterArraySource.kt +20 -0
- package/android/src/main/mapbox-v11-compat/v10/com/rnmapbox/rnmbx/components/styles/layers/RNMBXRasterParticleLayer.kt +22 -0
- package/android/src/main/mapbox-v11-compat/v10/com/rnmapbox/rnmbx/components/styles/layers/RNMBXRasterParticleLayerManager.kt +59 -0
- package/android/src/main/mapbox-v11-compat/v10/com/rnmapbox/rnmbx/components/styles/sources/RNMBXRasterArraySource.kt +16 -0
- package/android/src/main/mapbox-v11-compat/v10/com/rnmapbox/rnmbx/components/styles/sources/RNMBXRasterArraySourceManager.kt +59 -0
- package/android/src/main/mapbox-v11-compat/v10/com/rnmapbox/rnmbx/v11compat/StyleFactory.kt +45 -0
- package/android/src/main/mapbox-v11-compat/v11/com/rnmapbox/rnmbx/components/styles/layers/RNMBXRasterParticleLayer.kt +38 -0
- package/android/src/main/mapbox-v11-compat/v11/com/rnmapbox/rnmbx/components/styles/layers/RNMBXRasterParticleLayerManager.kt +85 -0
- package/android/src/main/mapbox-v11-compat/v11/com/rnmapbox/rnmbx/components/styles/sources/RNMBXRasterArraySource.kt +41 -0
- package/android/src/main/mapbox-v11-compat/v11/com/rnmapbox/rnmbx/components/styles/sources/RNMBXRasterArraySourceManager.kt +76 -0
- package/android/src/main/old-arch/com/facebook/react/viewmanagers/RNMBXRasterArraySourceManagerDelegate.java +54 -0
- package/android/src/main/old-arch/com/facebook/react/viewmanagers/RNMBXRasterArraySourceManagerInterface.java +23 -0
- package/android/src/main/old-arch/com/facebook/react/viewmanagers/RNMBXRasterParticleLayerManagerDelegate.java +66 -0
- package/android/src/main/old-arch/com/facebook/react/viewmanagers/RNMBXRasterParticleLayerManagerInterface.java +27 -0
- package/ios/RNMBX/Offline/RNMBXOfflineModuleLegacy.m +2 -0
- package/ios/RNMBX/Offline/RNMBXOfflineModuleLegacy.swift +5 -0
- package/ios/RNMBX/RNMBXCamera.swift +88 -17
- package/ios/RNMBX/RNMBXCameraModule.h +3 -2
- package/ios/RNMBX/RNMBXCameraModule.mm +8 -16
- package/ios/RNMBX/RNMBXCustomLocationProvider.swift +18 -24
- package/ios/RNMBX/RNMBXImageModule.h +3 -2
- package/ios/RNMBX/RNMBXImageModule.mm +8 -16
- package/ios/RNMBX/RNMBXImages.swift +1 -4
- package/ios/RNMBX/RNMBXInteractiveElement.swift +22 -15
- package/ios/RNMBX/RNMBXMapView.swift +68 -6
- package/ios/RNMBX/RNMBXNativeUserLocation.swift +6 -6
- package/ios/RNMBX/RNMBXPointAnnotation.swift +6 -8
- package/ios/RNMBX/RNMBXPointAnnotationModule.h +3 -2
- package/ios/RNMBX/RNMBXPointAnnotationModule.mm +8 -16
- package/ios/RNMBX/RNMBXRasterArraySource.swift +47 -0
- package/ios/RNMBX/RNMBXRasterArraySourceComponentView.h +15 -0
- package/ios/RNMBX/RNMBXRasterArraySourceComponentView.mm +168 -0
- package/ios/RNMBX/RNMBXRasterArraySourceViewManager.swift +16 -0
- package/ios/RNMBX/RNMBXRasterParticleLayer.swift +100 -0
- package/ios/RNMBX/RNMBXRasterParticleLayerComponentView.h +15 -0
- package/ios/RNMBX/RNMBXRasterParticleLayerComponentView.mm +121 -0
- package/ios/RNMBX/RNMBXRasterParticleLayerViewManager.swift +17 -0
- package/ios/RNMBX/RNMBXShapeSource.swift +5 -4
- package/ios/RNMBX/RNMBXShapeSourceModule.h +3 -2
- package/ios/RNMBX/RNMBXShapeSourceModule.mm +8 -16
- package/ios/RNMBX/RNMBXSource.swift +51 -21
- package/ios/RNMBX/RNMBXStyle.swift +152 -27
- package/ios/RNMBX/RNMBXStyleValue.swift +27 -0
- package/ios/RNMBX/RNMBXViewport.swift +13 -13
- package/ios/RNMBX/RNMBXViewportModule.h +3 -2
- package/ios/RNMBX/RNMBXViewportModule.mm +8 -16
- package/lib/commonjs/plugin/build/withMapbox.js +1 -1
- package/lib/commonjs/plugin/src/withMapbox.ts +13 -3
- package/lib/module/Mapbox.native.js +2 -0
- package/lib/module/Mapbox.native.js.map +1 -1
- package/lib/module/RNMBXModule.js.map +1 -1
- package/lib/module/components/PointAnnotation.js.map +1 -1
- package/lib/module/components/RasterArraySource.js +67 -0
- package/lib/module/components/RasterArraySource.js.map +1 -0
- package/lib/module/components/RasterParticleLayer.js +40 -0
- package/lib/module/components/RasterParticleLayer.js.map +1 -0
- package/lib/module/modules/offline/offlineManagerLegacy.js +14 -0
- package/lib/module/modules/offline/offlineManagerLegacy.js.map +1 -1
- package/lib/module/specs/RNMBXRasterArraySourceNativeComponent.ts +22 -0
- package/lib/module/specs/RNMBXRasterParticleLayerNativeComponent.ts +39 -0
- package/lib/module/utils/MapboxStyles.js.map +1 -1
- package/lib/module/utils/styleMap.js +9 -0
- package/lib/module/utils/styleMap.js.map +1 -1
- package/lib/typescript/plugin/src/withMapbox.d.ts.map +1 -1
- package/lib/typescript/scripts/autogenHelpers/generateCodeWithEjs.d.mts.map +1 -1
- package/lib/typescript/scripts/autogenHelpers/globals.d.mts +1 -1
- package/lib/typescript/scripts/autogenHelpers/globals.d.mts.map +1 -1
- package/lib/typescript/src/Mapbox.native.d.ts +3 -1
- package/lib/typescript/src/Mapbox.native.d.ts.map +1 -1
- package/lib/typescript/src/RNMBXModule.d.ts.map +1 -1
- package/lib/typescript/src/components/PointAnnotation.d.ts +1 -1
- package/lib/typescript/src/components/PointAnnotation.d.ts.map +1 -1
- package/lib/typescript/src/components/RasterArraySource.d.ts +72 -0
- package/lib/typescript/src/components/RasterArraySource.d.ts.map +1 -0
- package/lib/typescript/src/components/RasterParticleLayer.d.ts +80 -0
- package/lib/typescript/src/components/RasterParticleLayer.d.ts.map +1 -0
- package/lib/typescript/src/modules/offline/offlineManagerLegacy.d.ts +11 -0
- package/lib/typescript/src/modules/offline/offlineManagerLegacy.d.ts.map +1 -1
- package/lib/typescript/src/specs/RNMBXRasterArraySourceNativeComponent.d.ts +16 -0
- package/lib/typescript/src/specs/RNMBXRasterArraySourceNativeComponent.d.ts.map +1 -0
- package/lib/typescript/src/specs/RNMBXRasterParticleLayerNativeComponent.d.ts +25 -0
- package/lib/typescript/src/specs/RNMBXRasterParticleLayerNativeComponent.d.ts.map +1 -0
- package/lib/typescript/src/utils/MapboxStyles.d.ts +44 -2
- package/lib/typescript/src/utils/MapboxStyles.d.ts.map +1 -1
- package/lib/typescript/src/utils/styleMap.d.ts.map +1 -1
- package/package.json +13 -1
- package/plugin/build/withMapbox.js +1 -1
- package/plugin/src/withMapbox.ts +13 -3
- package/rnmapbox-maps.podspec +1 -1
- package/src/Mapbox.native.ts +3 -0
- package/src/RNMBXModule.ts +1 -4
- package/src/components/PointAnnotation.tsx +2 -2
- package/src/components/RasterArraySource.tsx +134 -0
- package/src/components/RasterParticleLayer.tsx +117 -0
- package/src/modules/offline/offlineManagerLegacy.ts +14 -0
- package/src/specs/RNMBXRasterArraySourceNativeComponent.ts +22 -0
- package/src/specs/RNMBXRasterParticleLayerNativeComponent.ts +39 -0
- package/src/utils/MapboxStyles.ts +47 -1
- package/src/utils/styleMap.ts +10 -0
package/android/build.gradle
CHANGED
|
@@ -1,5 +1,13 @@
|
|
|
1
1
|
def defaultMapboxMapsImpl = "mapbox"
|
|
2
|
-
|
|
2
|
+
|
|
3
|
+
def getDefaultMapboxMapsVersion() {
|
|
4
|
+
def packageJson = new groovy.json.JsonSlurper().parseText(
|
|
5
|
+
new File(projectDir.getPath(), "../package.json").text
|
|
6
|
+
)
|
|
7
|
+
return packageJson.mapbox.android
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
def defaultMapboxMapsVersion = getDefaultMapboxMapsVersion()
|
|
3
11
|
|
|
4
12
|
def safeExtGet(prop, fallback) {
|
|
5
13
|
rootProject.ext.has(prop) ? rootProject.ext.get(prop) : fallback
|
|
@@ -34,11 +34,13 @@ import com.rnmapbox.rnmbx.components.styles.layers.RNMBXHeatmapLayerManager
|
|
|
34
34
|
import com.rnmapbox.rnmbx.components.styles.layers.RNMBXLineLayerManager
|
|
35
35
|
import com.rnmapbox.rnmbx.components.styles.layers.RNMBXModelLayerManager
|
|
36
36
|
import com.rnmapbox.rnmbx.components.styles.layers.RNMBXRasterLayerManager
|
|
37
|
+
import com.rnmapbox.rnmbx.components.styles.layers.RNMBXRasterParticleLayerManager
|
|
37
38
|
import com.rnmapbox.rnmbx.components.styles.layers.RNMBXSkyLayerManager
|
|
38
39
|
import com.rnmapbox.rnmbx.components.styles.layers.RNMBXSymbolLayerManager
|
|
39
40
|
import com.rnmapbox.rnmbx.components.styles.light.RNMBXLightManager
|
|
40
41
|
import com.rnmapbox.rnmbx.components.styles.model.RNMBXModelsManager
|
|
41
42
|
import com.rnmapbox.rnmbx.components.styles.sources.RNMBXImageSourceManager
|
|
43
|
+
import com.rnmapbox.rnmbx.components.styles.sources.RNMBXRasterArraySourceManager
|
|
42
44
|
import com.rnmapbox.rnmbx.components.styles.sources.RNMBXRasterDemSourceManager
|
|
43
45
|
import com.rnmapbox.rnmbx.components.styles.sources.RNMBXRasterSourceManager
|
|
44
46
|
import com.rnmapbox.rnmbx.components.styles.sources.RNMBXShapeSourceManager
|
|
@@ -140,6 +142,9 @@ class RNMBXPackage : TurboReactPackage() {
|
|
|
140
142
|
))
|
|
141
143
|
managers.add(RNMBXRasterDemSourceManager(reactApplicationContext))
|
|
142
144
|
managers.add(RNMBXRasterSourceManager(reactApplicationContext))
|
|
145
|
+
if (RNMBXRasterArraySourceManager.isImplemented) {
|
|
146
|
+
managers.add(RNMBXRasterArraySourceManager(reactApplicationContext))
|
|
147
|
+
}
|
|
143
148
|
managers.add(RNMBXImageSourceManager())
|
|
144
149
|
|
|
145
150
|
// images
|
|
@@ -154,6 +159,9 @@ class RNMBXPackage : TurboReactPackage() {
|
|
|
154
159
|
managers.add(RNMBXCircleLayerManager())
|
|
155
160
|
managers.add(RNMBXSymbolLayerManager())
|
|
156
161
|
managers.add(RNMBXRasterLayerManager())
|
|
162
|
+
if (RNMBXRasterParticleLayerManager.isImplemented) {
|
|
163
|
+
managers.add(RNMBXRasterParticleLayerManager())
|
|
164
|
+
}
|
|
157
165
|
managers.add(RNMBXSkyLayerManager())
|
|
158
166
|
managers.add(RNMBXTerrainManager())
|
|
159
167
|
managers.add(RNMBXAtmosphereManager())
|
|
@@ -917,7 +917,13 @@ open class RNMBXMapView(private val mContext: Context, var mManager: RNMBXMapVie
|
|
|
917
917
|
Logger.e("queryRenderedFeaturesAtPoint", "mapbox map is null")
|
|
918
918
|
return
|
|
919
919
|
}
|
|
920
|
-
|
|
920
|
+
// JS sends point values in DIP (see getPointInView which divides by display density),
|
|
921
|
+
// but Mapbox core expects screen pixel coordinates. Convert back to px here.
|
|
922
|
+
val density: Float = getDisplayDensity()
|
|
923
|
+
val screenCoordinate = ScreenCoordinate(
|
|
924
|
+
(point.x * density).toDouble(),
|
|
925
|
+
(point.y * density).toDouble()
|
|
926
|
+
)
|
|
921
927
|
val queryGeometry = RenderedQueryGeometry(screenCoordinate)
|
|
922
928
|
val layers = layerIDs?.takeUnless { it.isEmpty() } ?: null;
|
|
923
929
|
val queryOptions = RenderedQueryOptions(layers, filter)
|
|
@@ -13,6 +13,7 @@ import com.mapbox.maps.extension.style.layers.generated.SkyLayer
|
|
|
13
13
|
// import com.mapbox.maps.extension.style.layers.generated.PropertyFactory
|
|
14
14
|
// import com.mapbox.maps.extension.style.layers.generated.PropertyValue
|
|
15
15
|
import com.mapbox.maps.extension.style.layers.generated.RasterLayer
|
|
16
|
+
import com.mapbox.maps.extension.style.layers.generated.RasterParticleLayer
|
|
16
17
|
import com.mapbox.maps.extension.style.layers.generated.SymbolLayer
|
|
17
18
|
import com.mapbox.maps.extension.style.layers.generated.HeatmapLayer
|
|
18
19
|
import com.mapbox.maps.extension.style.layers.generated.HillshadeLayer
|
|
@@ -704,6 +705,44 @@ object RNMBXStyleFactory {
|
|
|
704
705
|
}
|
|
705
706
|
}
|
|
706
707
|
}
|
|
708
|
+
fun setRasterParticleLayerStyle(layer: RasterParticleLayer, style: RNMBXStyle ) {
|
|
709
|
+
val styleKeys = style.allStyleKeys
|
|
710
|
+
|
|
711
|
+
if (styleKeys.isEmpty()) {
|
|
712
|
+
return
|
|
713
|
+
}
|
|
714
|
+
|
|
715
|
+
for (styleKey in styleKeys) {
|
|
716
|
+
try {
|
|
717
|
+
val styleValue = style.getStyleValueForKey(styleKey)
|
|
718
|
+
|
|
719
|
+
when (styleKey) {
|
|
720
|
+
"visibility" ->
|
|
721
|
+
setVisibility(layer, styleValue)
|
|
722
|
+
"rasterParticleArrayBand" ->
|
|
723
|
+
setRasterParticleArrayBand(layer, styleValue)
|
|
724
|
+
"rasterParticleCount" ->
|
|
725
|
+
setRasterParticleCount(layer, styleValue)
|
|
726
|
+
"rasterParticleColor" ->
|
|
727
|
+
setRasterParticleColor(layer, styleValue)
|
|
728
|
+
"rasterParticleMaxSpeed" ->
|
|
729
|
+
setRasterParticleMaxSpeed(layer, styleValue)
|
|
730
|
+
"rasterParticleSpeedFactor" ->
|
|
731
|
+
setRasterParticleSpeedFactor(layer, styleValue)
|
|
732
|
+
"rasterParticleSpeedFactorTransition" ->
|
|
733
|
+
setRasterParticleSpeedFactorTransition(layer, styleValue)
|
|
734
|
+
"rasterParticleFadeOpacityFactor" ->
|
|
735
|
+
setRasterParticleFadeOpacityFactor(layer, styleValue)
|
|
736
|
+
"rasterParticleFadeOpacityFactorTransition" ->
|
|
737
|
+
setRasterParticleFadeOpacityFactorTransition(layer, styleValue)
|
|
738
|
+
"rasterParticleResetRateFactor" ->
|
|
739
|
+
setRasterParticleResetRateFactor(layer, styleValue)
|
|
740
|
+
}
|
|
741
|
+
} catch (e: MapboxStyleException) {
|
|
742
|
+
Logger.e(LOG_TAG, "Failed to update: $styleKey ${e.message}")
|
|
743
|
+
}
|
|
744
|
+
}
|
|
745
|
+
}
|
|
707
746
|
fun setHillshadeLayerStyle(layer: HillshadeLayer, style: RNMBXStyle ) {
|
|
708
747
|
val styleKeys = style.allStyleKeys
|
|
709
748
|
|
|
@@ -4354,6 +4393,147 @@ object RNMBXStyleFactory {
|
|
|
4354
4393
|
}
|
|
4355
4394
|
}
|
|
4356
4395
|
|
|
4396
|
+
fun setVisibility(layer: RasterParticleLayer, styleValue: RNMBXStyleValue ) {
|
|
4397
|
+
layer.visibility(Visibility.valueOf(styleValue.getEnumName()));
|
|
4398
|
+
}
|
|
4399
|
+
|
|
4400
|
+
fun setRasterParticleArrayBand(layer: RasterParticleLayer, styleValue: RNMBXStyleValue ) {
|
|
4401
|
+
if (styleValue.isExpression()) {
|
|
4402
|
+
val expression = styleValue.getExpression()
|
|
4403
|
+
if (expression != null) {
|
|
4404
|
+
layer.rasterParticleArrayBand(expression)
|
|
4405
|
+
} else {
|
|
4406
|
+
Logger.e("RNMBXRasterParticle", "Expression for rasterParticleArrayBand is null")
|
|
4407
|
+
}
|
|
4408
|
+
} else {
|
|
4409
|
+
val value = styleValue.getString(VALUE_KEY)
|
|
4410
|
+
if (value != null) {
|
|
4411
|
+
layer.rasterParticleArrayBand(value)
|
|
4412
|
+
} else {
|
|
4413
|
+
Logger.e("RNMBXRasterParticle", "value for rasterParticleArrayBand is null")
|
|
4414
|
+
}
|
|
4415
|
+
}
|
|
4416
|
+
}
|
|
4417
|
+
|
|
4418
|
+
fun setRasterParticleCount(layer: RasterParticleLayer, styleValue: RNMBXStyleValue ) {
|
|
4419
|
+
if (styleValue.isExpression()) {
|
|
4420
|
+
val expression = styleValue.getExpression()
|
|
4421
|
+
if (expression != null) {
|
|
4422
|
+
layer.rasterParticleCount(expression)
|
|
4423
|
+
} else {
|
|
4424
|
+
Logger.e("RNMBXRasterParticle", "Expression for rasterParticleCount is null")
|
|
4425
|
+
}
|
|
4426
|
+
} else {
|
|
4427
|
+
val value = styleValue.getLong(VALUE_KEY)
|
|
4428
|
+
if (value != null) {
|
|
4429
|
+
layer.rasterParticleCount(value)
|
|
4430
|
+
} else {
|
|
4431
|
+
Logger.e("RNMBXRasterParticle", "value for rasterParticleCount is null")
|
|
4432
|
+
}
|
|
4433
|
+
}
|
|
4434
|
+
}
|
|
4435
|
+
|
|
4436
|
+
fun setRasterParticleColor(layer: RasterParticleLayer, styleValue: RNMBXStyleValue ) {
|
|
4437
|
+
if (styleValue.isExpression()) {
|
|
4438
|
+
val expression = styleValue.getExpression()
|
|
4439
|
+
if (expression != null) {
|
|
4440
|
+
layer.rasterParticleColor(expression)
|
|
4441
|
+
} else {
|
|
4442
|
+
Logger.e("RNMBXRasterParticle", "Expression for rasterParticleColor is null")
|
|
4443
|
+
}
|
|
4444
|
+
} else {
|
|
4445
|
+
layer.rasterParticleColor(styleValue.getIntExpression(VALUE_KEY))
|
|
4446
|
+
}
|
|
4447
|
+
}
|
|
4448
|
+
|
|
4449
|
+
fun setRasterParticleMaxSpeed(layer: RasterParticleLayer, styleValue: RNMBXStyleValue ) {
|
|
4450
|
+
if (styleValue.isExpression()) {
|
|
4451
|
+
val expression = styleValue.getExpression()
|
|
4452
|
+
if (expression != null) {
|
|
4453
|
+
layer.rasterParticleMaxSpeed(expression)
|
|
4454
|
+
} else {
|
|
4455
|
+
Logger.e("RNMBXRasterParticle", "Expression for rasterParticleMaxSpeed is null")
|
|
4456
|
+
}
|
|
4457
|
+
} else {
|
|
4458
|
+
val value = styleValue.getDouble(VALUE_KEY)
|
|
4459
|
+
if (value != null) {
|
|
4460
|
+
layer.rasterParticleMaxSpeed(value)
|
|
4461
|
+
} else {
|
|
4462
|
+
Logger.e("RNMBXRasterParticle", "value for rasterParticleMaxSpeed is null")
|
|
4463
|
+
}
|
|
4464
|
+
}
|
|
4465
|
+
}
|
|
4466
|
+
|
|
4467
|
+
fun setRasterParticleSpeedFactor(layer: RasterParticleLayer, styleValue: RNMBXStyleValue ) {
|
|
4468
|
+
if (styleValue.isExpression()) {
|
|
4469
|
+
val expression = styleValue.getExpression()
|
|
4470
|
+
if (expression != null) {
|
|
4471
|
+
layer.rasterParticleSpeedFactor(expression)
|
|
4472
|
+
} else {
|
|
4473
|
+
Logger.e("RNMBXRasterParticle", "Expression for rasterParticleSpeedFactor is null")
|
|
4474
|
+
}
|
|
4475
|
+
} else {
|
|
4476
|
+
val value = styleValue.getDouble(VALUE_KEY)
|
|
4477
|
+
if (value != null) {
|
|
4478
|
+
layer.rasterParticleSpeedFactor(value)
|
|
4479
|
+
} else {
|
|
4480
|
+
Logger.e("RNMBXRasterParticle", "value for rasterParticleSpeedFactor is null")
|
|
4481
|
+
}
|
|
4482
|
+
}
|
|
4483
|
+
}
|
|
4484
|
+
|
|
4485
|
+
|
|
4486
|
+
fun setRasterParticleSpeedFactorTransition(layer: RasterParticleLayer, styleValue: RNMBXStyleValue) {
|
|
4487
|
+
val transition = styleValue.transition
|
|
4488
|
+
if (transition != null) {
|
|
4489
|
+
layer.rasterParticleSpeedFactorTransition(transition);
|
|
4490
|
+
}
|
|
4491
|
+
}
|
|
4492
|
+
|
|
4493
|
+
fun setRasterParticleFadeOpacityFactor(layer: RasterParticleLayer, styleValue: RNMBXStyleValue ) {
|
|
4494
|
+
if (styleValue.isExpression()) {
|
|
4495
|
+
val expression = styleValue.getExpression()
|
|
4496
|
+
if (expression != null) {
|
|
4497
|
+
layer.rasterParticleFadeOpacityFactor(expression)
|
|
4498
|
+
} else {
|
|
4499
|
+
Logger.e("RNMBXRasterParticle", "Expression for rasterParticleFadeOpacityFactor is null")
|
|
4500
|
+
}
|
|
4501
|
+
} else {
|
|
4502
|
+
val value = styleValue.getDouble(VALUE_KEY)
|
|
4503
|
+
if (value != null) {
|
|
4504
|
+
layer.rasterParticleFadeOpacityFactor(value)
|
|
4505
|
+
} else {
|
|
4506
|
+
Logger.e("RNMBXRasterParticle", "value for rasterParticleFadeOpacityFactor is null")
|
|
4507
|
+
}
|
|
4508
|
+
}
|
|
4509
|
+
}
|
|
4510
|
+
|
|
4511
|
+
|
|
4512
|
+
fun setRasterParticleFadeOpacityFactorTransition(layer: RasterParticleLayer, styleValue: RNMBXStyleValue) {
|
|
4513
|
+
val transition = styleValue.transition
|
|
4514
|
+
if (transition != null) {
|
|
4515
|
+
layer.rasterParticleFadeOpacityFactorTransition(transition);
|
|
4516
|
+
}
|
|
4517
|
+
}
|
|
4518
|
+
|
|
4519
|
+
fun setRasterParticleResetRateFactor(layer: RasterParticleLayer, styleValue: RNMBXStyleValue ) {
|
|
4520
|
+
if (styleValue.isExpression()) {
|
|
4521
|
+
val expression = styleValue.getExpression()
|
|
4522
|
+
if (expression != null) {
|
|
4523
|
+
layer.rasterParticleResetRateFactor(expression)
|
|
4524
|
+
} else {
|
|
4525
|
+
Logger.e("RNMBXRasterParticle", "Expression for rasterParticleResetRateFactor is null")
|
|
4526
|
+
}
|
|
4527
|
+
} else {
|
|
4528
|
+
val value = styleValue.getDouble(VALUE_KEY)
|
|
4529
|
+
if (value != null) {
|
|
4530
|
+
layer.rasterParticleResetRateFactor(value)
|
|
4531
|
+
} else {
|
|
4532
|
+
Logger.e("RNMBXRasterParticle", "value for rasterParticleResetRateFactor is null")
|
|
4533
|
+
}
|
|
4534
|
+
}
|
|
4535
|
+
}
|
|
4536
|
+
|
|
4357
4537
|
fun setVisibility(layer: HillshadeLayer, styleValue: RNMBXStyleValue ) {
|
|
4358
4538
|
layer.visibility(Visibility.valueOf(styleValue.getEnumName()));
|
|
4359
4539
|
}
|
|
@@ -33,6 +33,10 @@ class RNMBXStyleValue(key: String?, config: ReadableMap) {
|
|
|
33
33
|
return mPayload!!.getInt(key!!)
|
|
34
34
|
}
|
|
35
35
|
|
|
36
|
+
fun getLong(key: String?): Long {
|
|
37
|
+
return mPayload!!.getInt(key!!).toLong()
|
|
38
|
+
}
|
|
39
|
+
|
|
36
40
|
fun getIntExpression(key: String?): Expression {
|
|
37
41
|
return Expression.literal(mPayload!!.getInt(key!!).toLong())
|
|
38
42
|
}
|
|
@@ -12,8 +12,8 @@ import com.rnmapbox.rnmbx.events.constants.EventTypes
|
|
|
12
12
|
import com.rnmapbox.rnmbx.modules.RNMBXOfflineModule
|
|
13
13
|
import com.rnmapbox.rnmbx.modules.RNMBXLocationModule
|
|
14
14
|
import com.facebook.react.bridge.ReactMethod
|
|
15
|
+
import com.facebook.react.bridge.Arguments
|
|
15
16
|
import com.facebook.react.bridge.ReadableMap
|
|
16
|
-
import com.facebook.react.bridge.buildReadableMap
|
|
17
17
|
import com.facebook.react.common.MapBuilder
|
|
18
18
|
import com.mapbox.bindgen.None
|
|
19
19
|
import com.mapbox.common.*
|
|
@@ -173,7 +173,7 @@ class RNMBXModule(private val mReactContext: ReactApplicationContext) : ReactCon
|
|
|
173
173
|
}
|
|
174
174
|
|
|
175
175
|
@ReactMethod
|
|
176
|
-
fun addCustomHeaderWithOptions(headerName: String, headerValue: String, options: ReadableMap? =
|
|
176
|
+
fun addCustomHeaderWithOptions(headerName: String, headerValue: String, options: ReadableMap? = Arguments.createMap()) {
|
|
177
177
|
try {
|
|
178
178
|
val urlRegexp = options?.getString("urlRegexp")?.toRegex()
|
|
179
179
|
CustomHttpHeaders.addCustomHeader(headerName, headerValue, CustomHttpHeadersOptions(urlRegexp = urlRegexp))
|
|
@@ -374,6 +374,16 @@ class RNMBXOfflineModuleLegacy(private val mReactContext: ReactApplicationContex
|
|
|
374
374
|
}
|
|
375
375
|
}
|
|
376
376
|
|
|
377
|
+
@ReactMethod
|
|
378
|
+
fun setTileCountLimit(tileCountLimit: Int) {
|
|
379
|
+
UiThreadUtil.runOnUiThread {
|
|
380
|
+
val offlineRegionManager = getOfflineRegionManager {
|
|
381
|
+
RNMBXModule.getAccessToken(mReactContext)
|
|
382
|
+
}
|
|
383
|
+
offlineRegionManager.setOfflineMapboxTileCountLimit(tileCountLimit.toLong())
|
|
384
|
+
}
|
|
385
|
+
}
|
|
386
|
+
|
|
377
387
|
@ReactMethod
|
|
378
388
|
fun resetDatabase(promise: Promise) {
|
|
379
389
|
UiThreadUtil.runOnUiThread {
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
// Dummy RasterParticleLayer for v10 compatibility
|
|
2
|
+
// RasterParticleLayer is only available in Mapbox SDK v11+
|
|
3
|
+
package com.mapbox.maps.extension.style.layers.generated
|
|
4
|
+
|
|
5
|
+
import com.mapbox.maps.extension.style.expressions.generated.Expression
|
|
6
|
+
import com.mapbox.maps.extension.style.layers.properties.generated.Visibility
|
|
7
|
+
import com.mapbox.maps.extension.style.types.StyleTransition
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* Dummy implementation of RasterParticleLayer for v10 compatibility.
|
|
11
|
+
* This class should never be instantiated in v10 builds.
|
|
12
|
+
* Note: Does not extend Layer to avoid abstract method issues in v10.
|
|
13
|
+
*/
|
|
14
|
+
class RasterParticleLayer(private val id: String, private val sourceId: String) {
|
|
15
|
+
|
|
16
|
+
val layerId: String
|
|
17
|
+
get() = id
|
|
18
|
+
|
|
19
|
+
var minZoom: Double? = null
|
|
20
|
+
private set
|
|
21
|
+
|
|
22
|
+
var maxZoom: Double? = null
|
|
23
|
+
private set
|
|
24
|
+
|
|
25
|
+
var visibility: Visibility? = null
|
|
26
|
+
private set
|
|
27
|
+
|
|
28
|
+
fun minZoom(minZoom: Double): RasterParticleLayer {
|
|
29
|
+
this.minZoom = minZoom
|
|
30
|
+
return this
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
fun maxZoom(maxZoom: Double): RasterParticleLayer {
|
|
34
|
+
this.maxZoom = maxZoom
|
|
35
|
+
return this
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
fun getType(): String = "raster-particle"
|
|
39
|
+
|
|
40
|
+
fun rasterParticleArrayBand(value: String) {}
|
|
41
|
+
fun rasterParticleArrayBand(expression: Expression) {}
|
|
42
|
+
fun rasterParticleCount(value: Long) {}
|
|
43
|
+
fun rasterParticleCount(expression: Expression) {}
|
|
44
|
+
fun rasterParticleColor(expression: Expression) {}
|
|
45
|
+
fun rasterParticleMaxSpeed(value: Double) {}
|
|
46
|
+
fun rasterParticleMaxSpeed(expression: Expression) {}
|
|
47
|
+
fun rasterParticleSpeedFactor(value: Double) {}
|
|
48
|
+
fun rasterParticleSpeedFactor(expression: Expression) {}
|
|
49
|
+
fun rasterParticleSpeedFactorTransition(transition: StyleTransition) {}
|
|
50
|
+
fun rasterParticleFadeOpacityFactor(value: Double) {}
|
|
51
|
+
fun rasterParticleFadeOpacityFactor(expression: Expression) {}
|
|
52
|
+
fun rasterParticleFadeOpacityFactorTransition(transition: StyleTransition) {}
|
|
53
|
+
fun rasterParticleResetRateFactor(value: Double) {}
|
|
54
|
+
fun rasterParticleResetRateFactor(expression: Expression) {}
|
|
55
|
+
fun visibility(visibility: Visibility) {
|
|
56
|
+
this.visibility = visibility
|
|
57
|
+
}
|
|
58
|
+
}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
// Dummy RasterArraySource for v10 compatibility
|
|
2
|
+
// RasterArraySource is only available in Mapbox SDK v11+
|
|
3
|
+
package com.mapbox.maps.extension.style.sources.generated
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* Dummy implementation of RasterArraySource for v10 compatibility.
|
|
7
|
+
* This class should never be instantiated in v10 builds.
|
|
8
|
+
* Note: Does not extend Source to avoid abstract method issues in v10.
|
|
9
|
+
*/
|
|
10
|
+
class RasterArraySource private constructor(
|
|
11
|
+
builder: Builder
|
|
12
|
+
) {
|
|
13
|
+
val sourceId: String = builder.sourceId
|
|
14
|
+
|
|
15
|
+
class Builder(val sourceId: String) {
|
|
16
|
+
fun url(url: String): Builder = this
|
|
17
|
+
fun tileSize(tileSize: Long): Builder = this
|
|
18
|
+
fun build(): RasterArraySource = RasterArraySource(this)
|
|
19
|
+
}
|
|
20
|
+
}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
package com.rnmapbox.rnmbx.components.styles.layers
|
|
2
|
+
|
|
3
|
+
import android.content.Context
|
|
4
|
+
import android.view.ViewGroup
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* Dummy implementation of RNMBXRasterParticleLayer for v10 compatibility.
|
|
8
|
+
* This class extends ViewGroup directly (instead of RNMBXLayer) to avoid
|
|
9
|
+
* inheriting from Layer which has internal abstract methods in v10.
|
|
10
|
+
* This class should never be instantiated in v10 builds.
|
|
11
|
+
*/
|
|
12
|
+
class RNMBXRasterParticleLayer(context: Context) : ViewGroup(context) {
|
|
13
|
+
var mSourceLayerID: String? = null
|
|
14
|
+
|
|
15
|
+
override fun onLayout(changed: Boolean, l: Int, t: Int, r: Int, b: Int) {
|
|
16
|
+
// Stub - never called
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
fun setSourceLayerID(sourceLayer: String?) {
|
|
20
|
+
mSourceLayerID = sourceLayer
|
|
21
|
+
}
|
|
22
|
+
}
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
package com.rnmapbox.rnmbx.components.styles.layers
|
|
2
|
+
|
|
3
|
+
import com.facebook.react.bridge.Dynamic
|
|
4
|
+
import com.facebook.react.uimanager.ThemedReactContext
|
|
5
|
+
import com.facebook.react.uimanager.ViewGroupManager
|
|
6
|
+
import com.facebook.react.uimanager.annotations.ReactProp
|
|
7
|
+
import com.facebook.react.viewmanagers.RNMBXRasterParticleLayerManagerInterface
|
|
8
|
+
|
|
9
|
+
class RNMBXRasterParticleLayerManager : ViewGroupManager<RNMBXRasterParticleLayer>(),
|
|
10
|
+
RNMBXRasterParticleLayerManagerInterface<RNMBXRasterParticleLayer> {
|
|
11
|
+
override fun getName(): String {
|
|
12
|
+
return REACT_CLASS
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
override fun createViewInstance(reactContext: ThemedReactContext): RNMBXRasterParticleLayer {
|
|
16
|
+
throw UnsupportedOperationException("RasterParticleLayer is only supported in Mapbox v11+")
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
@ReactProp(name = "id")
|
|
20
|
+
override fun setId(layer: RNMBXRasterParticleLayer, id: Dynamic) {}
|
|
21
|
+
|
|
22
|
+
@ReactProp(name = "existing")
|
|
23
|
+
override fun setExisting(layer: RNMBXRasterParticleLayer, existing: Dynamic) {}
|
|
24
|
+
|
|
25
|
+
@ReactProp(name = "sourceID")
|
|
26
|
+
override fun setSourceID(layer: RNMBXRasterParticleLayer, sourceID: Dynamic) {}
|
|
27
|
+
|
|
28
|
+
@ReactProp(name = "aboveLayerID")
|
|
29
|
+
override fun setAboveLayerID(layer: RNMBXRasterParticleLayer, aboveLayerID: Dynamic) {}
|
|
30
|
+
|
|
31
|
+
@ReactProp(name = "belowLayerID")
|
|
32
|
+
override fun setBelowLayerID(layer: RNMBXRasterParticleLayer, belowLayerID: Dynamic) {}
|
|
33
|
+
|
|
34
|
+
@ReactProp(name = "layerIndex")
|
|
35
|
+
override fun setLayerIndex(layer: RNMBXRasterParticleLayer, layerIndex: Dynamic) {}
|
|
36
|
+
|
|
37
|
+
@ReactProp(name = "minZoomLevel")
|
|
38
|
+
override fun setMinZoomLevel(layer: RNMBXRasterParticleLayer, minZoomLevel: Dynamic) {}
|
|
39
|
+
|
|
40
|
+
@ReactProp(name = "maxZoomLevel")
|
|
41
|
+
override fun setMaxZoomLevel(layer: RNMBXRasterParticleLayer, maxZoomLevel: Dynamic) {}
|
|
42
|
+
|
|
43
|
+
@ReactProp(name = "reactStyle")
|
|
44
|
+
override fun setReactStyle(layer: RNMBXRasterParticleLayer, style: Dynamic) {}
|
|
45
|
+
|
|
46
|
+
@ReactProp(name = "sourceLayerID")
|
|
47
|
+
override fun setSourceLayerID(layer: RNMBXRasterParticleLayer, sourceLayerID: Dynamic) {}
|
|
48
|
+
|
|
49
|
+
@ReactProp(name = "filter")
|
|
50
|
+
override fun setFilter(layer: RNMBXRasterParticleLayer, filterList: Dynamic) {}
|
|
51
|
+
|
|
52
|
+
@ReactProp(name = "slot")
|
|
53
|
+
override fun setSlot(layer: RNMBXRasterParticleLayer, slot: Dynamic) {}
|
|
54
|
+
|
|
55
|
+
companion object {
|
|
56
|
+
const val REACT_CLASS = "RNMBXRasterParticleLayer"
|
|
57
|
+
const val isImplemented = false
|
|
58
|
+
}
|
|
59
|
+
}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
package com.rnmapbox.rnmbx.components.styles.sources
|
|
2
|
+
|
|
3
|
+
import android.content.Context
|
|
4
|
+
import android.view.ViewGroup
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* Dummy implementation of RNMBXRasterArraySource for v10 compatibility.
|
|
8
|
+
* This class extends ViewGroup directly (instead of RNMBXTileSource) to avoid
|
|
9
|
+
* inheriting from Source which has internal abstract methods in v10.
|
|
10
|
+
* This class should never be instantiated in v10 builds.
|
|
11
|
+
*/
|
|
12
|
+
class RNMBXRasterArraySource(context: Context) : ViewGroup(context) {
|
|
13
|
+
override fun onLayout(changed: Boolean, l: Int, t: Int, r: Int, b: Int) {
|
|
14
|
+
// Stub - never called
|
|
15
|
+
}
|
|
16
|
+
}
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
package com.rnmapbox.rnmbx.components.styles.sources
|
|
2
|
+
|
|
3
|
+
import com.facebook.react.bridge.Dynamic
|
|
4
|
+
import com.facebook.react.bridge.ReactApplicationContext
|
|
5
|
+
import com.facebook.react.uimanager.ThemedReactContext
|
|
6
|
+
import com.facebook.react.uimanager.ViewGroupManager
|
|
7
|
+
import com.facebook.react.uimanager.annotations.ReactProp
|
|
8
|
+
import com.facebook.react.viewmanagers.RNMBXRasterArraySourceManagerInterface
|
|
9
|
+
import javax.annotation.Nonnull
|
|
10
|
+
|
|
11
|
+
class RNMBXRasterArraySourceManager(reactApplicationContext: ReactApplicationContext) :
|
|
12
|
+
ViewGroupManager<RNMBXRasterArraySource>(),
|
|
13
|
+
RNMBXRasterArraySourceManagerInterface<RNMBXRasterArraySource> {
|
|
14
|
+
@Nonnull
|
|
15
|
+
override fun getName(): String {
|
|
16
|
+
return REACT_CLASS
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
@Nonnull
|
|
20
|
+
override fun createViewInstance(@Nonnull reactContext: ThemedReactContext): RNMBXRasterArraySource {
|
|
21
|
+
throw UnsupportedOperationException("RasterArraySource is only supported in Mapbox v11+")
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
@ReactProp(name = "id")
|
|
25
|
+
override fun setId(source: RNMBXRasterArraySource, id: Dynamic) {}
|
|
26
|
+
|
|
27
|
+
@ReactProp(name = "url")
|
|
28
|
+
override fun setUrl(source: RNMBXRasterArraySource, url: Dynamic) {}
|
|
29
|
+
|
|
30
|
+
@ReactProp(name = "tileUrlTemplates")
|
|
31
|
+
override fun setTileUrlTemplates(source: RNMBXRasterArraySource, tileUrlTemplates: Dynamic) {}
|
|
32
|
+
|
|
33
|
+
@ReactProp(name = "tileSize")
|
|
34
|
+
override fun setTileSize(source: RNMBXRasterArraySource, tileSize: Dynamic) {}
|
|
35
|
+
|
|
36
|
+
@ReactProp(name = "minZoomLevel")
|
|
37
|
+
override fun setMinZoomLevel(source: RNMBXRasterArraySource, minZoomLevel: Dynamic) {}
|
|
38
|
+
|
|
39
|
+
@ReactProp(name = "maxZoomLevel")
|
|
40
|
+
override fun setMaxZoomLevel(source: RNMBXRasterArraySource, maxZoomLevel: Dynamic) {}
|
|
41
|
+
|
|
42
|
+
@ReactProp(name = "attribution")
|
|
43
|
+
fun setAttribution(source: RNMBXRasterArraySource, attribution: Dynamic) {}
|
|
44
|
+
|
|
45
|
+
fun customEvents(): Map<String, String>? {
|
|
46
|
+
return null
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
companion object {
|
|
50
|
+
const val REACT_CLASS = "RNMBXRasterArraySource"
|
|
51
|
+
const val isImplemented = false
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
@ReactProp(name = "existing")
|
|
55
|
+
override fun setExisting(source: RNMBXRasterArraySource, value: Dynamic) {}
|
|
56
|
+
|
|
57
|
+
@ReactProp(name = "sourceBounds")
|
|
58
|
+
override fun setSourceBounds(source: RNMBXRasterArraySource, value: Dynamic) {}
|
|
59
|
+
}
|
|
@@ -762,3 +762,48 @@ fun FillExtrusionLayer.fillExtrusionEmissiveStrengthTransition(
|
|
|
762
762
|
) {
|
|
763
763
|
// V11 only
|
|
764
764
|
}
|
|
765
|
+
|
|
766
|
+
// RasterParticleLayer - v11 only
|
|
767
|
+
internal fun setRasterParticleLayerStyle(layer: Any, style: Any) {
|
|
768
|
+
TODO("RasterParticleLayer is v11 only")
|
|
769
|
+
}
|
|
770
|
+
|
|
771
|
+
internal fun setVisibility(layer: Any, styleValue: Any) {
|
|
772
|
+
TODO("RasterParticleLayer is v11 only")
|
|
773
|
+
}
|
|
774
|
+
|
|
775
|
+
internal fun setRasterParticleArrayBand(layer: Any, styleValue: Any) {
|
|
776
|
+
TODO("RasterParticleLayer is v11 only")
|
|
777
|
+
}
|
|
778
|
+
|
|
779
|
+
internal fun setRasterParticleCount(layer: Any, styleValue: Any) {
|
|
780
|
+
TODO("RasterParticleLayer is v11 only")
|
|
781
|
+
}
|
|
782
|
+
|
|
783
|
+
internal fun setRasterParticleColor(layer: Any, styleValue: Any) {
|
|
784
|
+
TODO("RasterParticleLayer is v11 only")
|
|
785
|
+
}
|
|
786
|
+
|
|
787
|
+
internal fun setRasterParticleMaxSpeed(layer: Any, styleValue: Any) {
|
|
788
|
+
TODO("RasterParticleLayer is v11 only")
|
|
789
|
+
}
|
|
790
|
+
|
|
791
|
+
internal fun setRasterParticleSpeedFactor(layer: Any, styleValue: Any) {
|
|
792
|
+
TODO("RasterParticleLayer is v11 only")
|
|
793
|
+
}
|
|
794
|
+
|
|
795
|
+
internal fun setRasterParticleSpeedFactorTransition(layer: Any, styleValue: Any) {
|
|
796
|
+
TODO("RasterParticleLayer is v11 only")
|
|
797
|
+
}
|
|
798
|
+
|
|
799
|
+
internal fun setRasterParticleFadeOpacityFactor(layer: Any, styleValue: Any) {
|
|
800
|
+
TODO("RasterParticleLayer is v11 only")
|
|
801
|
+
}
|
|
802
|
+
|
|
803
|
+
internal fun setRasterParticleFadeOpacityFactorTransition(layer: Any, styleValue: Any) {
|
|
804
|
+
TODO("RasterParticleLayer is v11 only")
|
|
805
|
+
}
|
|
806
|
+
|
|
807
|
+
internal fun setRasterParticleResetRateFactor(layer: Any, styleValue: Any) {
|
|
808
|
+
TODO("RasterParticleLayer is v11 only")
|
|
809
|
+
}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
package com.rnmapbox.rnmbx.components.styles.layers
|
|
2
|
+
|
|
3
|
+
import android.content.Context
|
|
4
|
+
import com.mapbox.maps.MapboxExperimental
|
|
5
|
+
import com.mapbox.maps.extension.style.layers.generated.RasterParticleLayer
|
|
6
|
+
import com.rnmapbox.rnmbx.components.styles.RNMBXStyle
|
|
7
|
+
import com.rnmapbox.rnmbx.components.styles.RNMBXStyleFactory
|
|
8
|
+
import com.rnmapbox.rnmbx.utils.Logger
|
|
9
|
+
|
|
10
|
+
class RNMBXRasterParticleLayer(context: Context?) : RNMBXLayer<RasterParticleLayer?>(
|
|
11
|
+
context!!
|
|
12
|
+
) {
|
|
13
|
+
var mSourceLayerID: String? = null
|
|
14
|
+
|
|
15
|
+
override fun makeLayer(): RasterParticleLayer {
|
|
16
|
+
val result = RasterParticleLayer(iD!!, mSourceID!!)
|
|
17
|
+
mSourceLayerID?.let {
|
|
18
|
+
result.sourceLayer(it)
|
|
19
|
+
}
|
|
20
|
+
return result
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
override fun addStyles() {
|
|
24
|
+
mLayer?.also {
|
|
25
|
+
RNMBXStyleFactory.setRasterParticleLayerStyle(it, RNMBXStyle(context, mReactStyle, mMap!!))
|
|
26
|
+
} ?: run {
|
|
27
|
+
Logger.e("RNMBXRasterParticleLayer", "mLayer is null")
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
@OptIn(MapboxExperimental::class)
|
|
32
|
+
fun setSourceLayerID(sourceLayer: String?) {
|
|
33
|
+
mSourceLayerID = sourceLayer
|
|
34
|
+
mLayer?.let {
|
|
35
|
+
it.sourceLayer(sourceLayer!!)
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
}
|