| | |
| | | <SearchOutlined style="fontSize:24px; color: blue;" /> |
| | | </span> |
| | | </div> |
| | | |
| | | <div class="zoon"> |
| | | <span class="zoon-in" @mousedown="handleMouseDown(zoonIn)" @mouseup="handleMouseUp"> |
| | | <PlusOutlined style="fontSize:24px; color: black;" /> |
| | | </span> |
| | | |
| | | <span class="zoon-out" @mousedown="handleMouseDown(zoonOut)" @mouseup="handleMouseUp"> |
| | | <MinusOutlined style="fontSize:24px; color: black;" /> |
| | | </span> |
| | | </div> |
| | | <div class="switch"> |
| | | <div class="2d" v-if="dimension === 2" @click="switchDimension('3D')">2D</div> |
| | | <div class="3d" v-else @click="switchDimension('2D')">3D</div> |
| | |
| | | import _ from 'lodash' |
| | | import { cesiumOperation } from '/@/hooks/use-cesium-tsa' |
| | | import { gaodeSearch } from '/@/api/gaode' |
| | | import { SearchOutlined } from '@ant-design/icons-vue' |
| | | import { SearchOutlined, PlusOutlined, MinusOutlined } from '@ant-design/icons-vue' |
| | | import { useMyStore } from '/@/store' |
| | | import * as Cesium from 'cesium' |
| | | type result = { |
| | |
| | | } |
| | | const searchText = ref('') |
| | | const resultList = ref<result[]>([]) |
| | | const timer = ref<any>(null) |
| | | const store = useMyStore() |
| | | const centerConfig = computed(() => { |
| | | return store.state.map.centerConfig |
| | |
| | | } |
| | | } |
| | | const searchLocation = _.debounce(search, 500) |
| | | const { flyTo, addPoint, removeById, switchModel, dimension } = cesiumOperation() |
| | | const { flyTo, addPoint, removeById, switchModel, dimension, zoonIn, zoonOut } = cesiumOperation() |
| | | const enter = (e: string) => { |
| | | removeById('key') |
| | | const filterItem = resultList.value.find(v => v.value === e) |
| | |
| | | const switchDimension = (type: string) => { |
| | | switchModel(type) |
| | | } |
| | | const handleMouseDown = (fn:Function) => { |
| | | // clearInterval(timer.value) |
| | | timer.value = setInterval(() => { |
| | | fn(10) |
| | | }, 100) |
| | | } |
| | | const handleMouseUp = () => { |
| | | clearInterval(timer.value) |
| | | } |
| | | |
| | | </script> |
| | | |
| | | <style scoped lang="scss"> |
| | |
| | | } |
| | | } |
| | | |
| | | .zoon { |
| | | position: absolute; |
| | | right: 20px; |
| | | bottom: 340px; |
| | | color: #fff; |
| | | font-size: 16px; |
| | | display: flex; |
| | | align-items: center; |
| | | flex-direction: column; |
| | | height: 32px; |
| | | &-in, &-out { |
| | | padding: 5px; |
| | | background-color: #fff; |
| | | height: 32px; |
| | | cursor: pointer; |
| | | margin-top: 10px; |
| | | } |
| | | } |
| | | |
| | | .switch { |
| | | position: absolute; |
| | | background-color: #fff; |
| | | z-index: 30; |
| | | bottom: 80px; |
| | | bottom: 400px; |
| | | font-size: 14px; |
| | | right: 20px; |
| | | cursor: pointer; |
| | | box-shadow: 0 0 4px 0 rgba(0, 0, 0, .6); |
| | | width: 28px; |
| | | height: 28px; |
| | | width: 34px; |
| | | height: 34px; |
| | | color: #4e4e4e; |
| | | font-weight: 600; |
| | | display: flex; |