husq
2023-10-08 503f0d43ebab6be92650ee64060d018e1532423e
地理位置搜索样式修改
1 files modified
36 ■■■■■ changed files
src/components/cesiumMap/cesium.vue 36 ●●●●● patch | view | raw | blame | history
src/components/cesiumMap/cesium.vue
@@ -2,15 +2,12 @@
  <div class="height-100 width-100 cesium" id="cesiumContainer"></div>
  <div v-if="centerConfig.type && !centerConfig.latitude" class="pointLongitude">在地图上点击绘制项目中心点</div>
  <div class="search">
    <a-auto-complete
    v-model:value="searchText"
    style="width: 200px"
    placeholder="请输入地址"
    @select="enter"
    @change="searchLocation"
    :options='resultList'
  >
  </a-auto-complete>
    <a-auto-complete v-if="show" v-model:value="searchText" style="width: 200px;height: 100%;" placeholder="请输入地址" @select="enter"
      @change="searchLocation" :options='resultList'>
    </a-auto-complete>
    <span class="search-icon" @click="() => show = !show">
      <SearchOutlined style="fontSize:24px; color: blue;" />
    </span>
  </div>
  <div class="switch">
    <div class="2d" v-if="dimension === 2" @click="switchDimension('3D')">2D</div>
@@ -23,13 +20,14 @@
import _ from 'lodash'
import { cesiumOperation } from '/@/hooks/use-cesium-tsa'
import { gaodeSearch } from '/@/api/gaode'
import { SearchOutlined } from '@ant-design/icons-vue'
import { useMyStore } from '/@/store'
import * as Cesium from 'cesium'
type result = {
  label: string,
  value: string,
  location: string,
  district:string,
  district: string,
}
const searchText = ref('')
const resultList = ref<result[]>([])
@@ -37,6 +35,7 @@
const centerConfig = computed(() => {
  return store.state.map.centerConfig
})
const show = ref(false)
const search = async () => {
  resultList.value = []
  const params = {
@@ -46,7 +45,7 @@
  if (res.code !== 0) return
  if (res.data.tips.length > 0) {
    res.data.tips.shift()
    resultList.value = res.data.tips.map((v:any) => {
    resultList.value = res.data.tips.map((v: any) => {
      return {
        value: `${v.name}(${v.district})`,
        label: v.name,
@@ -58,7 +57,7 @@
}
const searchLocation = _.debounce(search, 500)
const { flyTo, addPoint, removeById, switchModel, dimension } = cesiumOperation()
const enter = (e:string) => {
const enter = (e: string) => {
  removeById('key')
  const filterItem = resultList.value.find(v => v.value === e)
  const [longitude, latitude] = filterItem?.location.split(',')
@@ -86,7 +85,7 @@
  addPoint({ ...pointParams, ...params })
  flyTo(params)
}
const switchDimension = (type:string) => {
const switchDimension = (type: string) => {
  switchModel(type)
}
</script>
@@ -111,13 +110,24 @@
  text-align: center;
  font-size: 16px;
}
.search {
  position: absolute;
  top: 40px;
  right: 20px;
  color: #fff;
  font-size: 16px;
  display: flex;
  align-items: center;
  height: 32px;
  .search-icon {
    padding: 5px;
    background-color: #fff;
    height: 32px;
    cursor: pointer;
  }
}
.switch {
  position: absolute;
  background-color: #fff;