cesium修改TileCoordinatesImageryLayer源码实现随机颜色,点选显示坐标

本文主要是介绍cesium修改TileCoordinatesImageryLayer源码实现随机颜色,点选显示坐标,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

cesium修改TileCoordinatesImageryLayer源码实现随机颜色,点选显示坐标。

1、修改函数requestImage:实现了随机颜色的瓦片覆盖。

TileCoordinatesImageryProvider.prototype.requestImage = function (x,y,level,request) {/*随机获取颜色*/function getRandomColor() {var r = Math.floor(Math.random() * 256);var g = Math.floor(Math.random() * 256);var b = Math.floor(Math.random() * 256);var a=0.3//设置透明度return "rgba(" + r + ',' + g + ',' + b + ',' + a +")";//return '#' + Math.floor(Math.random() * 0xffffff).toString(16);}  var canvas = document.createElement("canvas");canvas.width = 256;canvas.height = 256;var context = canvas.getContext("2d");var cssColor = this._color.toCssColorString();    context.strokeStyle = cssColor;    context.lineWidth = 2;context.strokeRect(1, 1, 255, 255);context.fillStyle = getRandomColor();context.fillRect(1, 1, 255, 255);/*    context.font = "bold 25px Arial";context.textAlign = "center";context.fillStyle = cssColor;context.fillText("L: " + level, 124, 86);context.fillText("X: " + x, 124, 136);context.fillText("Y: " + y, 124, 186); */return canvas;};

2、编写函数pickFeatures:实现点选瓦片操作,并在四个角标出经纬度。

TileCoordinatesImageryProvider.prototype.pickFeatures = function (x,y,level,longitude,latitude) {var interval = 180.0 / Math.pow(2, level);var lon = (x + 0.5) * interval-180;var lat = 90 - (y + 0.5) * interval;var step=0.5*interval;var labelLevel = 'L:' + level;var labelLonMin = 'Lo:'+(lon-step);var labelLatMin = 'La:'+(lat-step);var labelLonMax = 'Lo:'+(lon+step);var labelLatMax = 'La:'+(lat+step);var canvas = document.createElement("canvas");canvas.width = 256;canvas.height = 256;var context = canvas.getContext("2d");//var cssColor = this._color.toCssColorString();context.strokeStyle = "#FF0000";//cssColor;context.lineWidth = 5;context.strokeRect(1, 1, 255, 255);context.font = "bold 15px Arial";    context.fillStyle = "#000080"//cssColor; context.textAlign = "center";   context.fillText(labelLevel, 124, 128);context.textAlign = "left";context.fillText(labelLonMin, 5, 20);context.fillText(labelLatMax, 5, 35);context.fillText(labelLonMin, 5, 230);context.fillText(labelLatMin, 5, 245);context.textAlign = "right";context.fillText(labelLonMax, 250, 20);context.fillText(labelLatMax, 250, 35);context.fillText(labelLonMax, 250, 230);context.fillText(labelLatMin, 250, 245);    //console.log(canvas);var pintest=canvas.toDataURL();var imageryLayers = viewer.imageryLayers;viewer.entities.removeAll();viewer.entities.add({name: 'heatmap',rectangle: {coordinates: Cesium.Rectangle.fromDegrees(lon-step, lat-step, lon+step, lat+step),material: new Cesium.ImageMaterialProperty({image: pintest,transparent: true})}});return canvas;};

 

这篇关于cesium修改TileCoordinatesImageryLayer源码实现随机颜色,点选显示坐标的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Idea实现接口的方法上无法添加@Override注解的解决方案

《Idea实现接口的方法上无法添加@Override注解的解决方案》文章介绍了在IDEA中实现接口方法时无法添加@Override注解的问题及其解决方法,主要步骤包括更改项目结构中的Languagel... 目录Idea实现接China编程口的方法上无法添加@javascriptOverride注解错误原因解决方

轻松上手MYSQL之JSON函数实现高效数据查询与操作

《轻松上手MYSQL之JSON函数实现高效数据查询与操作》:本文主要介绍轻松上手MYSQL之JSON函数实现高效数据查询与操作的相关资料,MySQL提供了多个JSON函数,用于处理和查询JSON数... 目录一、jsON_EXTRACT 提取指定数据二、JSON_UNQUOTE 取消双引号三、JSON_KE

MySql死锁怎么排查的方法实现

《MySql死锁怎么排查的方法实现》本文主要介绍了MySql死锁怎么排查的方法实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录前言一、死锁排查方法1. 查看死锁日志方法 1:启用死锁日志输出方法 2:检查 mysql 错误

修改若依框架Token的过期时间问题

《修改若依框架Token的过期时间问题》本文介绍了如何修改若依框架中Token的过期时间,通过修改`application.yml`文件中的配置来实现,默认单位为分钟,希望此经验对大家有所帮助,也欢迎... 目录修改若依框架Token的过期时间修改Token的过期时间关闭Token的过期时js间总结修改若依

CSS3中使用flex和grid实现等高元素布局的示例代码

《CSS3中使用flex和grid实现等高元素布局的示例代码》:本文主要介绍了使用CSS3中的Flexbox和Grid布局实现等高元素布局的方法,通过简单的两列实现、每行放置3列以及全部代码的展示,展示了这两种布局方式的实现细节和效果,详细内容请阅读本文,希望能对你有所帮助... 过往的实现方法是使用浮动加

Go Mongox轻松实现MongoDB的时间字段自动填充

《GoMongox轻松实现MongoDB的时间字段自动填充》这篇文章主要为大家详细介绍了Go语言如何使用mongox库,在插入和更新数据时自动填充时间字段,从而提升开发效率并减少重复代码,需要的可以... 目录前言时间字段填充规则Mongox 的安装使用 Mongox 进行插入操作使用 Mongox 进行更

MySQL修改密码的四种实现方式

《MySQL修改密码的四种实现方式》文章主要介绍了如何使用命令行工具修改MySQL密码,包括使用`setpassword`命令和`mysqladmin`命令,此外,还详细描述了忘记密码时的处理方法,包... 目录mysql修改密码四种方式一、set password命令二、使用mysqladmin三、修改u

Java实现状态模式的示例代码

《Java实现状态模式的示例代码》状态模式是一种行为型设计模式,允许对象根据其内部状态改变行为,本文主要介绍了Java实现状态模式的示例代码,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来... 目录一、简介1、定义2、状态模式的结构二、Java实现案例1、电灯开关状态案例2、番茄工作法状态案例

一文教你使用Python实现本地分页

《一文教你使用Python实现本地分页》这篇文章主要为大家详细介绍了Python如何实现本地分页的算法,主要针对二级数据结构,文中的示例代码简洁易懂,有需要的小伙伴可以了解下... 在项目开发的过程中,遇到分页的第一页就展示大量的数据,导致前端列表加载展示的速度慢,所以需要在本地加入分页处理,把所有数据先放

SpringMVC前后端传值的几种实现方式

《SpringMVC前后端传值的几种实现方式》本文主要介绍了SpringMVC前后端传值的方式实现,包括使用HttpServletRequest、HttpSession、Model和ModelAndV... 目录一、从Controller层到JSP界面1、使用HttpServletRequest的方式2、使