【uniapp+mapbox】存一下uniapp用renderjs加载mapbox的写法

本文记录vue2用renderjs使用mapbox的写法;

本人通常单独写个组件,再加上控制显隐的,利用:change:paramsthis.$ownerInstance.callMethod('functionName')传参;

有别的写法但是没搞懂,其他欢迎大佬们补充~

直接看:

复制代码
<template>
  <view
    id="map-box"
    style="width: 100%;height: 100%;"
    :mapShow="mapShow"
    :change:mapShow="mapbox.handleMapShow"
    :userLocation="userLocation"
    :change:userLocation="mapbox.handleUserLocation"
  ></view>
</template>

<script>
export default {
  data() {
    return {
      mapShow: false,
      userLocation: [],
      
      mapLoaded: false,
    };
  },
  methods: {
    changeMapLoaded(val) {
      this.mapLoaded = val;
      
      ... // 其他处理
    }
  }
}
</script>

<script module="mapbox" lang="renderjs">
// import * as turf from '@turf/turf';
// import _ from 'lodash';
// import MapboxLanguage from '@mapbox/mapbox-gl-language';
import mapboxgl from 'mapbox-gl/dist/mapbox-gl.js';

let mapShow = false; // 是否展示地图
let map = null; // 地图实例
let mapLoaded = false; // 地图是否加载了
let center = [116.413467, 39.915156]; // 北京

// 业务上的数据存储
let userMarker = null;
let userLocation = [];

export default {
  methods: {
    handleMapShow(val) {
      mapShow = val;
      
      if (mapShow && !map) this.initMap();
    },
    initMap() {
      mapboxgl.accessToken = '...'
      map = new mapboxgl.Map({
        container: 'map-box',
        ... // 初始化
      })
      
      // map.addControl(new MapboxLanguage({
      //   defaultLanguage: "zh-Hans"
      // }));
      
      map.on('load', () => {
        mapLoaded = true;
        this.$ownerInstance.callMethod('changeMapLoaded', true);

        this.addUserMarker();
      })
    },
    handleUserLocation(val) {
      userLocation = val;
      
      this.addUserMarker()
    },
    addUserMarker() {
      if (!userLocation.length || !mapLoaded) return;
      
      if (userMarker) userMarker.setLngLat(userLocation)
      else {
        const el = document.createElement('div');
        el.className = 'marker_user';
        userMarker = new mapboxgl.Marker({
          anchor: 'bottom',
          element: el
        })
          .setLngLat(userLocation)
          .addTo(map);
      }
    },
  }
}
</script>

<style lang="scss" scoped>
@import "mapbox-gl/dist/mapbox-gl.css";

.mapboxgl-ctrl-logo {
  display: none !important;
}

::v-deep .mapboxgl-ctrl-logo {
  display: none;
}

::v-deep .mapboxgl-ctrl-attrib-inner {
  display: none;
}

::v-deep .mapboxgl-ctrl-attrib.mapboxgl-compact {
  display: none;
}

::v-deep .marker_user {
  ... // 图标样式等
}
</style>
相关推荐
IT_陈寒1 小时前
Vite的热更新突然失效,原来是因为这个配置
前端·人工智能·后端
ZC跨境爬虫1 小时前
3D 地球卫星轨道可视化平台开发 Day8(分步渲染200颗卫星+ 前端分页控制)
前端·python·3d·重构·html
竹林8181 小时前
RainbowKit快速集成多链钱包连接,我如何从“连不上”到“丝滑切换”
前端·javascript
笨笨狗吞噬者1 小时前
Opus 4.7 使用体验
前端·ai编程
No8g攻城狮2 小时前
【前端】Vue 中 const、var、let 的区别
前端·javascript·vue.js
文心快码BaiduComate2 小时前
Comate搭载Kimi K2.6,长程13h!
前端·后端·程序员
豹哥学前端2 小时前
新手小白学前端day4: Position定位
前端
fishmemory7sec2 小时前
Vue大屏自适应容器组件:v-scale-screen
前端·javascript·vue.js
饺子不吃醋2 小时前
Promise原理、手写与 async、await
前端·javascript
PILIPALAPENG2 小时前
第3周 Day 2:Function Calling —— 让 Agent 听懂人话,自己干活
前端·人工智能·python