Hi!
It's not possible to create a CIM Symbol with vector markers with custom text symbols.
Trying to achieve:
2D: (working as expected)
3D: (Only working with version 4.21)
It's working with v 4.21 but not with v 4.25.. because text symbols with CIMPolygons are not supported.
My CIM:
{
"id": "meteo-xtra-large",
"type": "simple",
"symbol": {
"type": "CIMSymbolReference",
"symbol": {
"type": "CIMPointSymbol",
"symbolLayers": [
{
"type": "CIMVectorMarker",
"enable": true,
"anchorPoint": {
"x": 0,
"y": 0
},
"anchorPointUnits": "Relative",
"dominantSizeAxis3D": "Y",
"size": 100,
"billboardMode3D": "FaceNearPlane",
"frame": {
"xmin": -50,
"ymin": -58,
"xmax": 50,
"ymax": 42
},
"markerGraphics": [
{
"type": "CIMMarkerGraphic",
"geometry": {
"x": 0,
"y": 0
},
"primitiveName": "averageWindSpeedInBft",
"textString": "",
"symbol": {
"type": "CIMTextSymbol",
"fontFamilyName": "Arial Bold",
"height": 20,
"billboardMode3D": "FaceNearPlane",
"depth3D": 3,
"symbol3DProperties": {
"type": "CIM3DSymbolProperties",
"dominantSizeAxis3D": "Y"
},
"horizontalAlignment": "Center",
"symbol": {
"type": "CIMPolygonSymbol",
"symbolLayers": [
{
"type": "CIMSolidFill",
"enable": true,
"color": [
27,
36,
61,
255
]
}
]
},
"verticalAlignment": "Center"
}
}
],
"scaleSymbolsProportionally": true,
"respectFrame": true,
"colorLocked": false
},
{
"type": "CIMVectorMarker",
"enable": true,
"anchorPoint": {
"x": 0,
"y": 0
},
"anchorPointUnits": "Relative",
"dominantSizeAxis3D": "Y",
"size": 100,
"billboardMode3D": "FaceNearPlane",
"frame": {
"xmin": -50,
"ymin": -39,
"xmax": 50,
"ymax": 61
},
"markerGraphics": [
{
"type": "CIMMarkerGraphic",
"geometry": {
"x": 0,
"y": 0
},
"textString": "BF",
"symbol": {
"type": "CIMTextSymbol",
"fontFamilyName": "Arial Bold",
"height": 10,
"billboardMode3D": "FaceNearPlane",
"depth3D": 3,
"symbol3DProperties": {
"type": "CIM3DSymbolProperties",
"dominantSizeAxis3D": "Y"
},
"horizontalAlignment": "Center",
"symbol": {
"type": "CIMPolygonSymbol",
"symbolLayers": [
{
"type": "CIMSolidFill",
"enable": true,
"color": [
27,
36,
61,
255
]
}
]
},
"verticalAlignment": "Center"
}
}
],
"scaleSymbolsProportionally": true,
"respectFrame": true,
"colorLocked": false
},
{
"type": "CIMPictureMarker",
"enable": true,
"anchorPoint": {
"x": 0,
"y": 0,
"z": 0
},
"anchorPointUnits": "Relative",
"dominantSizeAxis3D": "Y",
"billboardMode3D": "FaceNearPlane",
"invertBackfaceTexture": true,
"offsetX": 0,
"offsetY": 0,
"rotateClockwise": true,
"primitiveName": "averageWindDirection",
"scaleX": 1,
"textureFilter": "Picture",
"tintColor": [
255,
255,
255,
255
],
"size": 100,
"url": "./assets/images/compass-direction.svg"
},
{
"type": "CIMPictureMarker",
"enable": true,
"anchorPoint": {
"x": 0,
"y": 0,
"z": 0
},
"anchorPointUnits": "Relative",
"dominantSizeAxis3D": "Y",
"billboardMode3D": "FaceNearPlane",
"invertBackfaceTexture": true,
"offsetX": 0,
"offsetY": 0,
"rotateClockwise": true,
"primitiveName": "minAverageWindDirection",
"scaleX": 1,
"textureFilter": "Picture",
"tintColor": [
255,
255,
255,
255
],
"size": 100,
"url": "./assets/images/compass-direction-borders.svg"
},
{
"type": "CIMPictureMarker",
"enable": true,
"anchorPoint": {
"x": 0,
"y": 0,
"z": 0
},
"anchorPointUnits": "Relative",
"dominantSizeAxis3D": "Y",
"billboardMode3D": "FaceNearPlane",
"invertBackfaceTexture": true,
"offsetX": 0,
"offsetY": 0,
"rotateClockwise": true,
"primitiveName": "maxAverageWindDirection",
"scaleX": 1,
"textureFilter": "Picture",
"tintColor": [
255,
255,
255,
255
],
"size": 100,
"url": "./assets/images/compass-direction-borders.svg"
},
{
"type": "CIMPictureMarker",
"enable": true,
"anchorPoint": {
"x": 0,
"y": 0,
"z": 0
},
"anchorPointUnits": "Relative",
"dominantSizeAxis3D": "Y",
"billboardMode3D": "FaceNearPlane",
"invertBackfaceTexture": true,
"offsetX": 0,
"offsetY": 0,
"rotateClockwise": true,
"scaleX": 1,
"textureFilter": "Picture",
"tintColor": [
255,
255,
255,
255
],
"size": 100,
"url": ""
}
]
},
"primitiveOverrides": [
{
"type": "CIMPrimitiveOverride",
"primitiveName": "averageWindSpeedInBft",
"propertyName": "TextString",
"valueExpressionInfo": {
"type": "CIMExpressionInfo",
"title": "Custom",
"expression": "$feature.averageWindSpeedInBft",
"returnType": "Default"
}
},
{
"type": "CIMPrimitiveOverride",
"primitiveName": "averageWindDirection",
"propertyName": "Rotation",
"valueExpressionInfo": {
"type": "CIMExpressionInfo",
"title": "Custom",
"expression": "$feature.averageWindDirection",
"returnType": "Default"
}
},
{
"type": "CIMPrimitiveOverride",
"primitiveName": "minAverageWindDirection",
"propertyName": "Rotation",
"valueExpressionInfo": {
"type": "CIMExpressionInfo",
"title": "Custom",
"expression": "$feature.minAverageWindDirection",
"returnType": "Default"
}
},
{
"type": "CIMPrimitiveOverride",
"primitiveName": "maxAverageWindDirection",
"propertyName": "Rotation",
"valueExpressionInfo": {
"type": "CIMExpressionInfo",
"title": "Custom",
"expression": "$feature.maxAverageWindDirection",
"returnType": "Default"
}
}
]
}
}
Is there any way to achieve this CIM visualisation with text? Or is it planned for the next release?
Thanks
Hi @MKpoa - could you provide a codepen or some sort of repro case with your symbol?
I was not able to render your symbol directly since I did not have access to the images/data you were referencing, but I was able to render your symbol with just the first two symbol layers (VectorMarkers with embedded TextSymbols) correctly in 3D. Here's a codepen: https://codepen.io/annefitz/pen/xxJrKQr?editors=1000
Hi Anne,
I made a codepen with the correct symbol visualisation:
https://codepen.io/michaelk95/pen/eYexMqx?editors=1010
[esri.views.3d.layers.graphics.Graphics3DCore] CIM symbol of type 'CIMPolygonSymbol' is unsupported in 3D
This feature is working on 4.21.
Can you have a look? 🙂
That app appears to be working as expected for me, and I do not see the error. The symbols render as expected, as shown in the image below:
I tested your app across different browsers and devices and still cannot reproduce this error. If you are still running into issues, I would recommend reaching out to Esri support.
Hi Anne!
I changed
"symbol": {
"type": "cim",
"data": {
"type": "CIMSymbolReference",
"symbol": {
"type": "CIMPolygonymbol",
to "type": "CIMPointymbol". And now its working.
The only issue left is:
in 2D (mapView) my CIMSymbol is looking fine (with a custom font*)
*custom font and my esri config:
esriConfig.fontsUrl = './assets/font/';
When switching to 3D the CIM symbol can't find the custom font? And it looks like:
Is this a known issue? Should I reapply my custom font or renderers or ...?
@AnneFitz Thanks in advance
Gr
Michael
My CIMSymbol:
{
"type": "cim",
"data": {
"type": "CIMSymbolReference",
"symbol": {
"type": "CIMPointSymbol",
"symbolLayers": [
{
"type": "CIMVectorMarker",
"enable": true,
"anchorPoint": {
"x": 0,
"y": 0
},
"anchorPointUnits": "Relative",
"dominantSizeAxis3D": "Y",
"size": 40,
"billboardMode3D": "FaceNearPlane",
"frame": {
"xmin": -20,
"ymin": -20,
"xmax": 20,
"ymax": 20
},
"markerGraphics": [
{
"type": "CIMMarkerGraphic",
"geometry": {
"x": 0,
"y": 0
},
"textString": "\ue928",
"symbol": {
"type": "CIMTextSymbol",
"fontFamilyName": "apica-font",
"height": 40,
"horizontalAlignment": "Center",
"symbol": {
"type": "CIMPolygonSymbol",
"symbolLayers": [
{
"type": "CIMSolidFill",
"enable": true,
"color": [
27,
36,
61,
255
]
}
]
},
"billboardMode3D": "FaceNearPlane",
"depth3D": 3,
"verticalAlignment": "Center"
}
},
{
"type": "CIMMarkerGraphic",
"geometry": {
"x": 0,
"y": 0
},
"textString": "\ue90D",
"symbol": {
"type": "CIMTextSymbol",
"fontFamilyName": "apica-font",
"height": 11.200000000000001,
"horizontalAlignment": "Center",
"symbol": {
"type": "CIMPolygonSymbol",
"symbolLayers": [
{
"type": "CIMSolidFill",
"enable": true,
"color": [
255,
255,
255,
255
]
}
]
},
"billboardMode3D": "FaceNearPlane",
"depth3D": 3,
"verticalAlignment": "Center"
}
}
],
"scaleSymbolsProportionally": true,
"respectFrame": true,
"colorLocked": true
}
]
}
}
}
You can reproduce the issue using this repo:
https://github.com/michaelkeesdev/arcgis-js
npm install + npm start
When chaning SceneView to MapView (app.component.ts) you'll see what I mean. Thanks 🙂
@AnneFitz
@michaelkdev thanks for providing a repro case! We'll take a look.
Thanks! 🙂