使用 Esri 图标字体 (Calcite 主题)

字数统计: 10.5k
阅读时长: 约 40 分钟
当前版本: 4.29

Esri 图标字体是单色图标集。GeoScene JS Map SDK 支持使用Esri 图标字体文件。

Esri 图标字体有几个优点,例如能够快速更改其颜色、根据放置的文本大小自动调整其大小。

对于 2D MapViews,Esri 图标字体在托管字体文件中以 .pbf 格式提供。这些字体可通过 https://doc.geoscene.cn/resources/fonts 获得。通过设置 geosceneConfig.fontsUrl 属性,可以将 URL 配置为指向您自己的字体资源。

有关 Web 开发和字体的更多信息,请参阅基本文本和字体样式Web 字体 Mozilla 开发者网络文章。

将Esri 图标字体用作图形符号

图Esri 图标字体的一个潜在用途是将它们用作图形symbol 属性。在以下代码片段中,通过指定 colortextfont来创建 TextSymbolfont 属性是通过自动转换 Font 类创建的。

对于 2D MapViews3D SceneViews,图Esri 图标字体的 Font.familyCalciteWebCoreIcons

有关 Unicode 值的完整列表,请参阅本主题中的 CSS 类名和 Unicode 值部分。

js
const 2DtextSymbol = new TextSymbol({
    color: '#7A003C',
    text: '\ue61d', // esri-icon-map-pin
    font: { // autocast as new Font()
        size: 24,
        family: 'CalciteWebCoreIcons'
    }
});

const 3DtextSymbol = new TextSymbol({
    color: '#7A003C',
    text: '\ue61d', // esri-icon-map-pin
    font: { // autocast as new Font()
        size: 24,
        family: 'CalciteWebCoreIcons'
    }
});

将 Esri 图标字体用作标注

Esri 图标字体的另一个潜在用途是将它们用作 FeatureLayer 的 Label 类font.family 属性。在以下代码片段中,通过将符号类型自动转换为 textcolorfont 来创建 LabelClass。最后,定义了 labelPlacementlabelExpressionInfo

js
const labelClass = { // autocasts as new LabelClass()
    symbol: {
    type: 'text', // autocasts as new TextSymbol()
    color: 'green',https://developer.mozilla.org/zh-CN/docs
        font: { // autocast as new Font()
            family: 'CalciteWebCoreIcons',
            size: 12
        }
    },
    labelPlacement: 'above-left',
    labelExpressionInfo: {
        pression: '"\ue61d"' // esri-icon-map-pin
    }
};

CSS 类名和 Unicode 值

以下Esri 图标字体列表显示了字体预览、使用Esri 图标字体所需的 CSS 类名以及指定 content CSS 属性所需的 CSS unicode 值,此属性与 ::before::after 伪元素一起使用以在元素中生成内容或 TextSymbol.text 属性的值。

esri-icon-close
esri-icon-drag-horizontal
esri-icon-drag-vertical
esri-icon-handle-horizontal
esri-icon-handle-vertical
esri-icon-check-mark
esri-icon-left-triangle-arrow
esri-icon-right-triangle-arrow
esri-icon-down-arrow
esri-icon-up-arrow
esri-icon-overview-arrow-bottom-left
esri-icon-overview-arrow-bottom-right
esri-icon-overview-arrow-top-left
esri-icon-overview-arrow-top-right
esri-icon-maximize
esri-icon-minimize
esri-icon-checkbox-unchecked
esri-icon-checkbox-checked
esri-icon-radio-unchecked
esri-icon-radio-checked
esri-icon-up-arrow-circled
esri-icon-down-arrow-circled
esri-icon-left-arrow-circled
esri-icon-right-arrow-circled
esri-icon-zoom-out-fixed
esri-icon-zoom-in-fixed
esri-icon-refresh
esri-icon-edit
esri-icon-authorize
esri-icon-map-pin
esri-icon-blank-map-pin
esri-icon-table
esri-icon-plus
esri-icon-minus
esri-icon-beginning
esri-icon-reverse
esri-icon-pause
esri-icon-play
esri-icon-forward
esri-icon-end
esri-icon-erase
esri-icon-up-down-arrows
esri-icon-left
esri-icon-right
esri-icon-announcement
esri-icon-notice-round
esri-icon-notice-triangle
esri-icon-home
esri-icon-locate
esri-icon-expand
esri-icon-collapse
esri-icon-layer-list
esri-icon-basemap
esri-icon-globe
esri-icon-applications
esri-icon-arrow-up-circled
esri-icon-arrow-down-circled
esri-icon-arrow-left-circled
esri-icon-arrow-right-circled
esri-icon-minus-circled
esri-icon-plus-circled
esri-icon-add-attachment
esri-icon-attachment
esri-icon-calendar
esri-icon-close-circled
esri-icon-browser
esri-icon-collection
esri-icon-comment
esri-icon-configure-popup
esri-icon-contact
esri-icon-dashboard
esri-icon-deny
esri-icon-description
esri-icon-directions
esri-icon-directions2
esri-icon-documentation
esri-icon-duplicate
esri-icon-review
esri-icon-environment-settings
esri-icon-error
esri-icon-error2
esri-icon-experimental
esri-icon-feature-layer
esri-icon-filter
esri-icon-grant
esri-icon-group
esri-icon-key
esri-icon-labels
esri-icon-tag
esri-icon-layers
esri-icon-left-arrow
esri-icon-right-arrow
esri-icon-link-external
esri-icon-link
esri-icon-loading-indicator
esri-icon-maps
esri-icon-marketplace
esri-icon-media
esri-icon-media2
esri-icon-menu
esri-icon-mobile
esri-icon-phone
esri-icon-navigation
esri-icon-pan
esri-icon-printer
esri-icon-pie-chart
esri-icon-chart
esri-icon-line-chart
esri-icon-question
esri-icon-resend-invitation
esri-icon-rotate
esri-icon-save
esri-icon-settings
esri-icon-settings2
esri-icon-share
esri-icon-sign-out
esri-icon-support
esri-icon-user
esri-icon-time-clock
esri-icon-trash
esri-icon-upload
esri-icon-download
esri-icon-zoom-in-magnifying-glass
esri-icon-search
esri-icon-zoom-out-magnifying-glass
esri-icon-locked
esri-icon-unlocked
esri-icon-favorites
esri-icon-compass
esri-icon-down
esri-icon-up
esri-icon-chat
esri-icon-dock-bottom
esri-icon-dock-left
esri-icon-dock-right
esri-icon-organization
esri-icon-north-navigation
esri-icon-locate-circled
esri-icon-dial
esri-icon-polygon
esri-icon-polyline
esri-icon-visible
esri-icon-non-visible
esri-icon-link-vertical
esri-icon-unlocked-link-vertical
esri-icon-link-horizontal
esri-icon-unlocked-link-horizontal
esri-icon-swap
esri-icon-cta-link-external
esri-icon-reply
esri-icon-public
esri-icon-share2
esri-icon-launch-link-external
esri-icon-rotate-back
esri-icon-pan2
esri-icon-tracking
esri-icon-expand2
esri-icon-arrow-down
esri-icon-arrow-up
esri-icon-hollow-eye
esri-icon-play-circled
esri-icon-volume-off
esri-icon-volume-on
esri-icon-bookmark
esri-icon-lightbulb
esri-icon-sketch-rectangle
esri-icon-north-navigation-filled
esri-icon-default-action
esri-icon-undo
esri-icon-redo
esri-icon-cursor
esri-icon-cursor-filled
esri-icon-measure-line
esri-icon-measure
esri-icon-measure-area
esri-icon-legend
esri-icon-sliders
esri-icon-sliders-horizontal
esri-icon-cursor-marquee
esri-icon-lasso
esri-icon-elevation-profile
esri-icon-line-of-sight
esri-icon-slice
esri-icon-zoom-to-object
esri-icon-urban-model
esri-icon-measure-building-height-shadow
esri-icon-partly-cloudy