我的编程空间,编程开发者的网络收藏夹
学习永远不晚

vue怎么使用AIlabel标注组件

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

vue怎么使用AIlabel标注组件

这篇“vue怎么使用AIlabel标注组件”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“vue怎么使用AIlabel标注组件”文章吧。

1.下载组件

npm i ailabel

2.下载完成后vue页面标签页面代码

这个是需要渲染的盒子

<div id="hello-map" ></div>

需要操作的盒子是 setMode这个是触发方法 RECT这个代表是矩形形状

 <div class="box" @click="setMode('RECT')" >矩形</div>

3.js 代码

 import AILabel from "ailabel";data() {    return {      img:require("../assets/img/homepage/bj.jpg"),      gMap: null, //AILabel实例      gFirstFeatureLayer: null, //矢量图层实例(矩形,多边形等矢量)      //矩形样式      RectStyle: {        lineWidth: 1.5, //边框宽度        strokeStyle: "", //边框颜色        fill: true, //是否填充背景色        fillStyle: "rgba(255,255,255,0.1)", //背景颜色      },    };  },//初始化 标注工具并渲染  initMap() {      // npm i ailabel      let drawingStyle = {}; // 绘制过程中样式        const gMap = new AILabel.Map('hello-map', {            center: {x: 350, y: 210}, // 为了让图片居中            zoom: 705,            mode: 'PAN', // PAN 可以平移和放大缩小   ban  可以平移             refreshDelayWhenZooming: true, // 缩放时是否允许刷新延时,性能更优            zoomWhenDrawing: true,            panWhenDrawing: false,            zoomWheelRatio: 5, // 控制滑轮缩放缩率[0, 10), 值越小,则缩放越快,反之越慢            withHotKeys: true // 关闭快捷键        });                // 图片层添加        const gFirstImageLayer = new AILabel.Layer.Image(            'layer-image', // id            {                class="lazy" data-src: require('../assets/img/homepage/bj.jpg'),                width:700,                height: 500,                crossOrigin: false, // 如果跨域图片,需要设置为true                position: { // 左上角相对中心点偏移量                    x: 0,                    y: 0                },            }, // imageInfo            {name: '第一个图片图层'}, // props            {zIndex: 5} // 这里写样式 层级        );        // click单击事件 这里可以直接修改单击触发 比如如果没触发可以直接把事件放进来写成单击一个点渲染        gMap.events.on('click', point => {            console.log('--click--', point);        });        // data 代表r半径shape;data1代表sr半径shape        gMap.events.on('drawDone', (type, data, data1) => {            if (type === 'MARKER') {                const marker = new AILabel.Marker(                    `${+new Date()}`, // id                    {                        class="lazy" data-src: '',                        position: data,                        offset: {                            x: 0,                            y:0                        }                    }, // markerInfo                    {name: '第一个marker注记'} // props                );                marker.events.on('click', marker => {                    gMap.markerLayer.removeMarkerById(marker.id);                });                gMap.markerLayer.addMarker(marker);            }            else if (type === 'POINT') {              // 创建图层 然后实例在图片上                const pointFeature = new AILabel.Feature.Point(                    `${+new Date()}`, // id                    data, // shape                    {name: '第一个矢量图层'}, // props                   {fillStyle: '#00f'} // style                );                gFirstFeatureLayer.addFeature(pointFeature);            }            // else if (type === 'CIRCLE') {            //     // data 代表r半径shape;data1代表sr半径shape            //     const circleFeature = new AILabel.Feature.Circle(            //         `${+new Date()}`, // id            //         data, // data1代表屏幕坐标 shape            //         {name: '第一个矢量图层'}, // props            //         {fillStyle: '#F4A460', strokeStyle: '#D2691E', lineWidth: 2} // style            //     );            //     gFirstFeatureLayer.addFeature(circleFeature);            // }            else if (type === 'LINE') {                const scale = gMap.getScale();                const width = drawingStyle.lineWidth / scale;                const lineFeature = new AILabel.Feature.Line(                    `${+new Date()}`, // id                    {...data, width}, // shape                    {name: '第一个矢量图层'}, // props                    drawingStyle // style                );                gFirstFeatureLayer.addFeature(lineFeature);            }            else if (type === 'POLYLINE') {                const scale = gMap.getScale();                const width = drawingStyle.lineWidth / scale;                const polylineFeature = new AILabel.Feature.Polyline(                    `${+new Date()}`, // id                    {points: data, width}, // shape                    {name: '第一个矢量图层'}, // props                    drawingStyle // style drawingStyle 这里可以改变图形或者线的颜色 动态赋值                );                gFirstFeatureLayer.addFeature(polylineFeature);            }            else if (type === 'RECT') {                const rectFeature = new AILabel.Feature.Rect(                    `${+new Date()}`, // id                    data, // shape                    {name: '矢量图形'}, // props                    {fillStyle: '#F4A460', strokeStyle: '#D2691E', lineWidth: 2} // style                );                gFirstFeatureLayer.addFeature(rectFeature);            }            else if (type === 'POLYGON') {                const polygonFeature = new AILabel.Feature.Polygon(                    `${+new Date()}`, // id                    {points: data}, // shape                    {name: '矢量图形'}, // props                   {strokeStyle: '#00f', fillStyle: '#0f0', globalAlpha: .1, lineWidth: 1, fill: true, } // style fill 图形中阴影 globalAlpha 阴影的显示程度 strokeStyle 线的颜色 fillStyle 阴影的颜色                 );                           });        // 视野范围发生变化        gMap.events.on('boundsChanged', data => {            // console.log('--map boundsChanged--');            return 2222;        });        // 在绘制模式下双击feature触发选中        gMap.events.on('featureSelected', feature => {            this.getid(feature.id)            // gMap.setActiveFeature(feature);        });        gMap.events.on('featureUnselected', () => {            // 取消featureSelected            gMap.setActiveFeature(null);        });        gMap.events.on('featureUpdated', (feature, shape) => {            feature.updateShape(shape);             const markerId = feature.props.deleteMarkerId;            const targetMarker = gMap.markerLayer.getMarkerById(markerId);            targetMarker.updatePosition(feature.getPoints()[1]);        });        gMap.events.on('featureDeleted', ({id: featureId}) => {            gFirstFeatureLayer.removeFeatureById(featureId);        });                   // 图片层相关事件监听        gFirstImageLayer.events.on('loadStart', (a, b) => {            console.log('--loadStart--', a, b);        });        gFirstImageLayer.events.on('loadEnd', (a, b) => {            console.log('--loadEnd--', a, b);        });        gFirstImageLayer.events.on('loadError', (a, b) => {            console.log('--loadError--', a, b);        });        // 添加到gMap对象        gMap.addLayer(gFirstImageLayer);                const gFirstFeatureLayer = new AILabel.Layer.Feature(            'first-layer-feature', // id            {name: '第一个矢量图层'}, // props            {zIndex: 10} // style        );        gMap.addLayer(gFirstFeatureLayer);     const gFirstTextLayer = new AILabel.Layer.Text(            'first-layer-text', // id            {text:'这是一给文字',position: {x: 300, y: 300}},            {name: '第一个文本图层'}, // props            {fillStyle: '#F4A460', strokeStyle: '#D2691E', background: true, globalAlpha: 1, fontColor: '#0f0'} // style            );            gMap.addLayer(gFirstTextLayer);             //自适应      this.gFirstFeatureLayer = gFirstFeatureLayer;      this.gMap = gMap;      window.onresize = function () {        gMap && gMap.resize();      };    }, // 触发 工具功能 类型会自动触发工具内对应渲染的图形      setMode(mode) {            this.gMap.setMode(mode);            //  动态颜色可以在这里赋值 精确到某一个操作            var drawingStyle            // 后续对应模式处理            switch (mode) {                case 'PAN': {                    break;                }                case 'MARKER': {                    // 忽略                    break;                }                case 'POINT': {                    drawingStyle = {fillStyle: '#9370DB',strokeStyle:'#f00'};                    this.gMap.setDrawingStyle(drawingStyle);                    break;                }                // case 'CIRCLE': {                //     drawingStyle = {fillStyle: '#9370DB', strokeStyle: '#f00', lineWidth: 2};                //     this.gMap.setDrawingStyle(drawingStyle);                //     break;                // }                case 'LINE': {                    drawingStyle = {strokeStyle: '#FF0000', lineJoin: 'round', lineCap: 'round', lineWidth: 5, arrow: false};                    this.gMap.setDrawingStyle(drawingStyle);                    break;                }                case 'POLYLINE': {                    drawingStyle = {strokeStyle: '#FF1493', lineJoin: 'round', lineCap: 'round', lineWidth: 1}                    this.gMap.setDrawingStyle(drawingStyle);                    break;                }                case 'RECT': {                    drawingStyle = {strokeStyle: '#f00', lineWidth: 1}                    this.gMap.setDrawingStyle(drawingStyle);                    break;                }                case 'POLYGON': {                    drawingStyle = {strokeStyle: '#00f', fillStyle: '#0f0', globalAlpha: .3, lineWidth: 1, fill: true, stroke: true}                    this.gMap.setDrawingStyle(drawingStyle);                    break;                }                // case 'DRAWMASK': {                //     drawingStyle = {strokeStyle: 'rgba(255, 0, 0, .5)', fillStyle: '#00f', lineWidth: 50}                //     this.gMap.setDrawingStyle(drawingStyle);                //     break;                // }                // case 'CLEARMASK': {                //     drawingStyle = {fillStyle: '#00f', lineWidth: 30}                //     this.gMap.setDrawingStyle(drawingStyle);                //     break;                // }                case 'TEXT': {                    drawingStyle = {fillStyle: '#00f', lineWidth: 30}                    this.gMap.setDrawingStyle(drawingStyle);                    break;                }                default:                    break;            }        },

4.个人思路进行一些针对性的操作

     //  全部清空        del(){          this.gMap.removeAllLayers();          this.initMap()        },        // 双击删除当前图形 这里是直接一次删一个图形 也可以根据坐标删除上一次操作        getid(id){            let index =  this.gFirstFeatureLayer.features.findIndex((ele) => {                return ele.id == id;                });              this.gFirstFeatureLayer.features.splice(index,1)             this.gMap.resize();        },        // 撤回上一步        dels(){          this.gFirstFeatureLayer.features.splice(this.gFirstFeatureLayer.features.length-1,1)          this.gMap.resize();        }

以上就是关于“vue怎么使用AIlabel标注组件”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注编程网行业资讯频道。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

vue怎么使用AIlabel标注组件

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

vue怎么使用AIlabel标注组件

这篇“vue怎么使用AIlabel标注组件”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“vue怎么使用AIlabel标注组件
2023-06-30

vue组件库怎么使用

今天小编给大家分享一下vue组件库怎么使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。完整项目目录结构git clone到
2023-07-04

vue组件image-viewer使用要注意什么

使用Vue组件`image-viewer`时,需要注意以下几点:引入组件:在Vue项目中,需先引入`image-viewer`组件,可以通过`import`语句或者在``标签中引入。依赖:`image-viewer`组件依赖于Vue和一些其
2023-10-26

vue内置组件怎么使用

这篇文章主要介绍了vue内置组件怎么使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇vue内置组件怎么使用文章都会有所收获,下面我们一起来看看吧。vue组件有:1、component,用于渲染一个“元组件”为
2023-07-04

Vue异步组件怎么使用

本篇内容主要讲解“Vue异步组件怎么使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Vue异步组件怎么使用”吧!1、前置要求建议使用webpack;Browserify在默认情况下不支持;2、
2023-07-04

vue缓存组件怎么使用

今天小编给大家分享一下vue缓存组件怎么使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。在vue中,缓存组件是“keep-
2023-07-04

Vue动态组件与异步组件怎么使用

这篇“Vue动态组件与异步组件怎么使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Vue动态组件与异步组件怎么使用”文章吧
2023-07-05

VUE页面声音+标题闪烁通知组件怎么使用

这篇文章主要介绍“VUE页面声音+标题闪烁通知组件怎么使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“VUE页面声音+标题闪烁通知组件怎么使用”文章能帮助大家解决问题。一个VUE页面声音+标题闪烁
2023-07-05

Vue中的KeepAlive组件怎么使用

这篇文章主要介绍“Vue中的KeepAlive组件怎么使用”,在日常操作中,相信很多人在Vue中的KeepAlive组件怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Vue中的KeepAlive组件怎
2023-07-04

vue动态组件component怎么使用

本篇内容介绍了“vue动态组件component怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1、component如何实现动态组件
2023-06-21

vue组件component的注册与使用详解

组件是Vue是一个可以重复使用的Vue实例,它拥有独一无二的组件名称,它可以扩展HTML元素,以组件名称的方式作为自定义的HTML标签,这篇文章主要介绍了vue组件component的注册与使用,需要的朋友可以参考下
2022-11-13

Vue拖拽排序组件Vue-Slicksort怎么使用

这篇“Vue拖拽排序组件Vue-Slicksort怎么使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Vue拖拽排序组件V
2023-07-05

VUE页面声音和标题闪烁通知组件怎么使用

本文小编为大家详细介绍“VUE页面声音和标题闪烁通知组件怎么使用”,内容详细,步骤清晰,细节处理妥当,希望这篇“VUE页面声音和标题闪烁通知组件怎么使用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。1.使用方法1
2023-07-04

keep-alive组件怎么在Vue中使用

这篇文章将为大家详细讲解有关keep-alive组件怎么在Vue中使用,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。 一、keep-alive 用法< keep-alive> 包裹动态组件时
2023-06-14

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录