三十五、openlayers官网示例Dynamic Data——在地图上加载动态数据形成动画效果

本文主要是介绍三十五、openlayers官网示例Dynamic Data——在地图上加载动态数据形成动画效果,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

官网demo地址:

 Dynamic Data

 初始化地图

 const tileLayer = new TileLayer({source: new OSM(),});const map = new Map({layers: [tileLayer],target: "map",view: new View({center: [0, 0],zoom: 2,}),});

    创建了三个样式

const imageStyle = new Style({image: new CircleStyle({radius: 5,fill: new Fill({ color: "yellow" }),stroke: new Stroke({ color: "red", width: 1 }),}),});const headInnerImageStyle = new Style({image: new CircleStyle({radius: 2,fill: new Fill({ color: "blue" }),}),});const headOuterImageStyle = new Style({image: new CircleStyle({radius: 5,fill: new Fill({ color: "black" }),}),});

绘制动画效果主要还是利用了postrender事件,其原理解析可以参考这篇

十八、openlayers官网示例Custom Animation解析——地图上添加自定义动画、圆圈涟漪效果_unbykey(listenerkey);-CSDN博客

// 点的数量,用于定义图形的分辨率const n = 200;// 角速度常量,用于计算当前时间的角度const omegaTheta = 30000;// 大圆的半径const R = 7e6;// 小圆的半径const r = 2e6;// 距离小圆中心的点的距离const p = 2e6;tileLayer.on("postrender", function (event) {//获取渲染上下文和帧状态//用于在地图上绘制矢量图形const vectorContext = getVectorContext(event);//包含当前帧的状态,包括时间信息const frameState = event.frameState;//计算当前角度 theta 根据当前时间和 omegaTheta 计算当前角度 theta,用于动画效果const theta = (2 * Math.PI * frameState.time) / omegaTheta;//生成外旋轮线的坐标数组const coordinates = [];let i;for (i = 0; i < n; ++i) {const t = theta + (2 * Math.PI * i) / n;const x = (R + r) * Math.cos(t) + p * Math.cos(((R + r) * t) / r);const y = (R + r) * Math.sin(t) + p * Math.sin(((R + r) * t) / r);coordinates.push([x, y]);}vectorContext.setStyle(imageStyle);//设置样式 imageStyle 并绘制多点几何(MultiPoint)vectorContext.drawGeometry(new MultiPoint(coordinates));const headPoint = new Point(coordinates[coordinates.length - 1]);//将头部的圆标注出来设置成不同样式vectorContext.setStyle(headOuterImageStyle);vectorContext.drawGeometry(headPoint);vectorContext.setStyle(headInnerImageStyle);vectorContext.drawGeometry(headPoint);//强制重新渲染地图map.render();});

完整代码:

<template><div class="box"><h1>Dynamic Data动态数据</h1><div id="map"></div></div>
</template><script>
import Map from "ol/Map.js";
import OSM from "ol/source/OSM.js";
import TileLayer from "ol/layer/Tile.js";
import View from "ol/View.js";
import { Circle as CircleStyle, Fill, Stroke, Style } from "ol/style.js";
import { MultiPoint, Point } from "ol/geom.js";
import { getVectorContext } from "ol/render.js";
export default {name: "",components: {},data() {return {map: null,};},computed: {},created() {},mounted() {const tileLayer = new TileLayer({source: new OSM(),});const map = new Map({layers: [tileLayer],target: "map",view: new View({center: [0, 0],zoom: 2,}),});const imageStyle = new Style({image: new CircleStyle({radius: 5,fill: new Fill({ color: "yellow" }),stroke: new Stroke({ color: "red", width: 1 }),}),});const headInnerImageStyle = new Style({image: new CircleStyle({radius: 2,fill: new Fill({ color: "blue" }),}),});const headOuterImageStyle = new Style({image: new CircleStyle({radius: 5,fill: new Fill({ color: "black" }),}),});// 点的数量,用于定义图形的分辨率const n = 200;// 角速度常量,用于计算当前时间的角度const omegaTheta = 30000;// 大圆的半径const R = 7e6;// 小圆的半径const r = 2e6;// 距离小圆中心的点的距离const p = 2e6;tileLayer.on("postrender", function (event) {//获取渲染上下文和帧状态//用于在地图上绘制矢量图形const vectorContext = getVectorContext(event);//包含当前帧的状态,包括时间信息const frameState = event.frameState;//计算当前角度 theta 根据当前时间和 omegaTheta 计算当前角度 theta,用于动画效果const theta = (2 * Math.PI * frameState.time) / omegaTheta;//生成外旋轮线的坐标数组const coordinates = [];let i;for (i = 0; i < n; ++i) {const t = theta + (2 * Math.PI * i) / n;const x = (R + r) * Math.cos(t) + p * Math.cos(((R + r) * t) / r);const y = (R + r) * Math.sin(t) + p * Math.sin(((R + r) * t) / r);coordinates.push([x, y]);}vectorContext.setStyle(imageStyle);//设置样式 imageStyle 并绘制多点几何(MultiPoint)vectorContext.drawGeometry(new MultiPoint(coordinates));const headPoint = new Point(coordinates[coordinates.length - 1]);//将头部的圆标注出来设置成不同样式vectorContext.setStyle(headOuterImageStyle);vectorContext.drawGeometry(headPoint);vectorContext.setStyle(headInnerImageStyle);vectorContext.drawGeometry(headPoint);//强制重新渲染地图map.render();});map.render();},methods: {},
};
</script><style lang="scss" scoped>
#map {width: 100%;height: 500px;
}
.box {height: 100%;
}
</style>

这篇关于三十五、openlayers官网示例Dynamic Data——在地图上加载动态数据形成动画效果的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1028921

相关文章

C++20管道运算符的实现示例

《C++20管道运算符的实现示例》本文简要介绍C++20管道运算符的使用与实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录标准库的管道运算符使用自己实现类似的管道运算符我们不打算介绍太多,因为它实际属于c++20最为重要的

Java中调用数据库存储过程的示例代码

《Java中调用数据库存储过程的示例代码》本文介绍Java通过JDBC调用数据库存储过程的方法,涵盖参数类型、执行步骤及数据库差异,需注意异常处理与资源管理,以优化性能并实现复杂业务逻辑,感兴趣的朋友... 目录一、存储过程概述二、Java调用存储过程的基本javascript步骤三、Java调用存储过程示

ModelMapper基本使用和常见场景示例详解

《ModelMapper基本使用和常见场景示例详解》ModelMapper是Java对象映射库,支持自动映射、自定义规则、集合转换及高级配置(如匹配策略、转换器),可集成SpringBoot,减少样板... 目录1. 添加依赖2. 基本用法示例:简单对象映射3. 自定义映射规则4. 集合映射5. 高级配置匹

C++11作用域枚举(Scoped Enums)的实现示例

《C++11作用域枚举(ScopedEnums)的实现示例》枚举类型是一种非常实用的工具,C++11标准引入了作用域枚举,也称为强类型枚举,本文主要介绍了C++11作用域枚举(ScopedEnums... 目录一、引言二、传统枚举类型的局限性2.1 命名空间污染2.2 整型提升问题2.3 类型转换问题三、C

Java实现自定义table宽高的示例代码

《Java实现自定义table宽高的示例代码》在桌面应用、管理系统乃至报表工具中,表格(JTable)作为最常用的数据展示组件,不仅承载对数据的增删改查,还需要配合布局与视觉需求,而JavaSwing... 目录一、项目背景详细介绍二、项目需求详细介绍三、相关技术详细介绍四、实现思路详细介绍五、完整实现代码

C++ 检测文件大小和文件传输的方法示例详解

《C++检测文件大小和文件传输的方法示例详解》文章介绍了在C/C++中获取文件大小的三种方法,推荐使用stat()函数,并详细说明了如何设计一次性发送压缩包的结构体及传输流程,包含CRC校验和自动解... 目录检测文件的大小✅ 方法一:使用 stat() 函数(推荐)✅ 用法示例:✅ 方法二:使用 fsee

mysql查询使用_rowid虚拟列的示例

《mysql查询使用_rowid虚拟列的示例》MySQL中,_rowid是InnoDB虚拟列,用于无主键表的行ID查询,若存在主键或唯一列,则指向其,否则使用隐藏ID(不稳定),推荐使用ROW_NUM... 目录1. 基本查询(适用于没有主键的表)2. 检查表是否支持 _rowid3. 注意事项4. 最佳实

Spring如何使用注解@DependsOn控制Bean加载顺序

《Spring如何使用注解@DependsOn控制Bean加载顺序》:本文主要介绍Spring如何使用注解@DependsOn控制Bean加载顺序,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录1.javascript 前言2. 代码实现总结1. 前言默认情况下,Spring加载Bean的顺

HTML中meta标签的常见使用案例(示例详解)

《HTML中meta标签的常见使用案例(示例详解)》HTMLmeta标签用于提供文档元数据,涵盖字符编码、SEO优化、社交媒体集成、移动设备适配、浏览器控制及安全隐私设置,优化页面显示与搜索引擎索引... 目录html中meta标签的常见使用案例一、基础功能二、搜索引擎优化(seo)三、社交媒体集成四、移动

HTML input 标签示例详解

《HTMLinput标签示例详解》input标签主要用于接收用户的输入,随type属性值的不同,变换其具体功能,本文通过实例图文并茂的形式给大家介绍HTMLinput标签,感兴趣的朋友一... 目录通用属性输入框单行文本输入框 text密码输入框 password数字输入框 number电子邮件输入编程框