【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>
相关推荐
科普瑞传感仪器19 小时前
从轴孔装配到屏幕贴合:六维力感知的机器人柔性对位应用详解
前端·javascript·数据库·人工智能·机器人·自动化·无人机
n***F87519 小时前
SpringMVC 请求参数接收
前端·javascript·算法
wordbaby19 小时前
搞不懂 px、dpi 和 dp?看这一篇就够了:图解 RN 屏幕适配逻辑
前端
程序员爱钓鱼19 小时前
使用 Node.js 批量导入多语言标签到 Strapi
前端·node.js·trae
鱼樱前端19 小时前
uni-app开发app之前提须知(IOS/安卓)
前端·uni-app
V***u45319 小时前
【学术会议论文投稿】Spring Boot实战:零基础打造你的Web应用新纪元
前端·spring boot·后端
i听风逝夜20 小时前
Web 3D地球实时统计访问来源
前端·后端
iMonster20 小时前
React 组件的组合模式之道 (Composition Pattern)
前端
呐呐呐呐呢20 小时前
antd渐变色边框按钮
前端
元直数字电路验证20 小时前
Jakarta EE Web 聊天室技术梳理
前端