From 62dfa93d00514cbb99d594b7c698ab03b205a4eb Mon Sep 17 00:00:00 2001 From: suyubin <84109842+websybin@users.noreply.github.com> Date: Fri, 8 Mar 2024 11:00:09 +0800 Subject: [PATCH] =?UTF-8?q?feat:=20=E6=96=B0=E5=A2=9E=E5=AF=BC=E5=87=BA?= =?UTF-8?q?=E5=9B=BE=E7=89=87=E7=BB=84=E4=BB=B6=20(#52)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * feat: 新增导出图片组件 * fix: 修改下载图片名称 --------- Co-authored-by: syb01094648 --- .vscode/settings.json | 2 +- docs/docs/index.md | 1 + .../export-image-control/index.tsx | 48 +++++++++++++++++++ .../export-image-control/styles.ts | 28 +++++++++++ src/components/map-control-group/index.tsx | 3 ++ src/constants/index.ts | 10 +++- src/locales/langs/en-US.ts | 1 + src/locales/langs/zh-CN.ts | 1 + src/types/l7editor.ts | 1 + src/utils/index.ts | 7 +++ 10 files changed, 99 insertions(+), 3 deletions(-) create mode 100644 src/components/map-control-group/export-image-control/index.tsx create mode 100644 src/components/map-control-group/export-image-control/styles.ts diff --git a/.vscode/settings.json b/.vscode/settings.json index 777b1491..065ad692 100644 --- a/.vscode/settings.json +++ b/.vscode/settings.json @@ -3,7 +3,7 @@ "i18n-ally.keystyle": "nested", "i18n-ally.sortKeys": true, "i18n-ally.enabledParsers": ["ts", "json"], - "i18n-ally.sourceLanguage": "en-US", + "i18n-ally.sourceLanguage": "zh-CN", "i18n-ally.displayLanguage": "zh-CN", "i18n-ally.enabledFrameworks": ["react"] } diff --git a/docs/docs/index.md b/docs/docs/index.md index beb99f5f..81729ffa 100644 --- a/docs/docs/index.md +++ b/docs/docs/index.md @@ -162,6 +162,7 @@ LngLat 文本编辑器,可以通过输入 LngLat 数据实现数据展示(目 | mapAdministrativeControl | 查看当前行政区域控件 | | logoControl | Logo 控件 | | textLayerControl | 文本图层 控件 | +| exportImageControl | 导出图片 控件 | #### toolbar diff --git a/src/components/map-control-group/export-image-control/index.tsx b/src/components/map-control-group/export-image-control/index.tsx new file mode 100644 index 00000000..272c65cb --- /dev/null +++ b/src/components/map-control-group/export-image-control/index.tsx @@ -0,0 +1,48 @@ +import { ExportImageControl } from '@antv/larkmap'; +import { Image, Modal } from 'antd'; +import React, { useState } from 'react'; +import { useTranslation } from 'react-i18next'; +import { downloadImg } from '.././../../utils'; +import useStyle from './styles'; + +export const ExportImage = () => { + const styles = useStyle(); + const [imageData, setImageData] = useState(''); + const [isModalOpen, setIsModalOpen] = useState(false); + const { t } = useTranslation(); + + const onExport = (value: string) => { + setIsModalOpen(true); + setImageData(value); + }; + + const handle = () => { + setIsModalOpen(false); + setImageData(''); + }; + + const onOk = () => { + setIsModalOpen(false); + downloadImg(imageData); + setImageData(''); + }; + return ( + <> + + + + + + ); +}; diff --git a/src/components/map-control-group/export-image-control/styles.ts b/src/components/map-control-group/export-image-control/styles.ts new file mode 100644 index 00000000..dc4d9fc5 --- /dev/null +++ b/src/components/map-control-group/export-image-control/styles.ts @@ -0,0 +1,28 @@ +import { css } from '@emotion/css'; +import { theme } from 'antd'; + +const useStyle = () => { + const { useToken } = theme; + const { token } = useToken(); + + const { colorBgContainer, colorIcon, colorText } = + token; + return { + l7ExportImg: css` + background: ${colorBgContainer}; + color: ${colorIcon}; + svg { + fill: ${colorIcon} !important; + } + + :hover { + background: ${colorBgContainer} !important; + svg { + color: ${colorText} !important; + fill: ${colorText} !important; + } + } + `, + }; +}; +export default useStyle; diff --git a/src/components/map-control-group/index.tsx b/src/components/map-control-group/index.tsx index acfc3dee..02ccf7b0 100644 --- a/src/components/map-control-group/index.tsx +++ b/src/components/map-control-group/index.tsx @@ -14,6 +14,7 @@ import { AdministrativeSelect } from './administrative-select-control'; import { AutoControl } from './auto-control'; import { ClearControl } from './clear-control'; import DrawControl from './draw-control'; +import { ExportImage } from './export-image-control'; import FilterControl from './filter-form-list-control'; import { L7MapOptionControl } from './l7-option-control'; import LayerColorControl from './layer-color-control'; @@ -46,6 +47,7 @@ const DefaultMapControl: MapControlProps = { mapAdministrativeControl: true, logoControl: true, textLayerControl: true, + exportImageControl: true, L7MapOptionControl: true, }; export const MapControlGroup: React.FC = ({ @@ -101,6 +103,7 @@ export const MapControlGroup: React.FC = ({ )} {layerType.includes(OfficeLayerEnum.GoogleSatellite) && } {isControlGroupState.textLayerControl && } + {isControlGroupState.exportImageControl && } {isControlGroupState.L7MapOptionControl && } ); diff --git a/src/constants/index.ts b/src/constants/index.ts index ece62d27..fb1f2f82 100644 --- a/src/constants/index.ts +++ b/src/constants/index.ts @@ -21,8 +21,8 @@ export enum LocalStorageKey { firstOpening = 'firstOpening', wasmPath = 'wasmPath', customTiles = 'customTiles', - showDrawDistance = "showDrawDistance", - showDrawArea = "showDrawArea" + showDrawDistance = 'showDrawDistance', + showDrawArea = 'showDrawArea', } export enum LayerId { @@ -46,10 +46,16 @@ export const FeatureKey = { export const MapBoxConfig = { token: 'pk.eyJ1IjoibGl1dmlnb25nenVvc2hpIiwiYSI6ImNsaGs2czBrcTBvczUzbnFzOHU0dzk2ZWQifQ.hVvTgcbg_Ym-VQz36psLRg', + WebGLParams: { + preserveDrawingBuffer: true, + }, }; export const GaodeConfig = { token: '5ae4492ef912cbbc93034fea0e66ff2a', + WebGLParams: { + preserveDrawingBuffer: true, + }, }; export const LayerZIndex = 100; diff --git a/src/locales/langs/en-US.ts b/src/locales/langs/en-US.ts index 0ff128d4..2e2eb746 100644 --- a/src/locales/langs/en-US.ts +++ b/src/locales/langs/en-US.ts @@ -231,6 +231,7 @@ export default { 'text-layer-control_wenBenTuCengPeiZhi': 'Text Layer Configuration', 'text-layer-control_description': 'Open the text layer configuration, you can display the serial number of all the current data, you can also use the multi-select box to properties fields in the data to select different data for display.', + 'export-img-control_title': 'Preview Picture', 'btn.setting_btn.mianJi': 'Show area text when drawing', 'btn.setting_btn.juLi': 'Whether to display distance text when drawing', 'l7Options.huoqucanshu': 'Get map status parameters', diff --git a/src/locales/langs/zh-CN.ts b/src/locales/langs/zh-CN.ts index c0c3540a..7d1eee47 100644 --- a/src/locales/langs/zh-CN.ts +++ b/src/locales/langs/zh-CN.ts @@ -198,6 +198,7 @@ export default { 'text-layer-control_wenBenTuCengPeiZhi': '文本图层配置', 'text-layer-control_description': '开启文本图层配置,可以显示当前所有数据的序号,也可以通过多选框在数据中properties字段去选择不同的数据来进行展示', + 'export-img-control_title': '预览图片', 'btn.setting_btn.mianJi': '绘制时是否展示面积文本', 'btn.setting_btn.juLi': '绘制时是否展示距离文本', 'l7Options.huoqucanshu': '获取地图状态参数', diff --git a/src/types/l7editor.ts b/src/types/l7editor.ts index 7f00c3f4..bccaa5b9 100644 --- a/src/types/l7editor.ts +++ b/src/types/l7editor.ts @@ -28,6 +28,7 @@ export interface MapControlProps { administrativeSelectControl?: boolean; mapAdministrativeControl?: boolean; textLayerControl?: boolean; + exportImageControl?: boolean; L7MapOptionControl?: boolean; } diff --git a/src/utils/index.ts b/src/utils/index.ts index 77fe9d54..38408c5d 100644 --- a/src/utils/index.ts +++ b/src/utils/index.ts @@ -46,6 +46,13 @@ export const downloadText = (text: string, ext: string | 'json' | 'txt') => { aTag.click(); }; +export const downloadImg = (link: string) => { + const aTag = document.createElement('a'); + aTag.href = link; + aTag.download = `${dayjs().format('YYYY年MM月DD日HH时mm分ss秒')}.jpeg`; + aTag.dispatchEvent(new MouseEvent('click')); +}; + export const getParamsNew = (key: string) => { const temData = new URLSearchParams(window.location.search); return temData.get(key);