您的位置:

java实现图层叠加(如何进行图层叠加)

本文目录一览:

java JPanel重叠覆盖问题。

首先遗憾的告诉你,add方法添加以后,本来就是覆盖式的,不存在透明化的问题,因为父panel会挨次调用子类的panel的paint方法,将其绘制在自己表面。也就是说,你想通过add,然后设置子面板透明的方法本身是行不通的。

但这并不意味着就没有办法了,很简单,你自己管理绘制就可以了。方法有两种:

1、自己修改一个panel类,继承自JPanel,这个类在paint方法中,先绘制本身的图像,然后才绘制子类的图像,并且会根据子类的图像区域进行透明处理。

2、在一个类中,自己通过内部数据处理,把两个panel的数据进行排比,然后统一画在panel中。

PS:通常用的都是第二种办法。第一种办法实现起来,即不灵活,也不如第二种方法直观快速。

java数组怎么进行叠加????

数组是不可以这样的,因为数组的大小一旦确定了就不可以改了,还是用集合框架的那些类吧,作为面向对象的实现方式,List,Map,Set等比数组实在是好太多了。

将图层混合模式设置为叠加在哪里

在图层-设置图层的混合模式里面。设置叠加方法如下:

1、首先在ps里面将需要的素材打开。

2、打开之后在右侧新建一个图层。

3、新建了图层之后,选中这个图层,并按住shift+F5组合键,给图层添加颜色。

4、然后点击图层-设置图层混合模式-叠加这个选项。

5、点击了之后,就可以看到图层的叠加效果了。

java开发 怎么把图层放到百度地图上

如果要在百度地图上实现一张自己自定义的地图,就需要使用百度地图自定义图层接口。实现效果如下:

但是百度地图中关于自定义图层的介绍甚少,便以此博文以记录,方便同行了解和使用。

百度地图官方文档中,关于自定义图层的介绍是这样的:

=========华丽丽的分隔线===========

自定义图层

地图坐标系

在使用自定义图层前,您需要了解百度地图的地图坐标系,百度地图坐标系涉及:

 经纬度球面坐标系统

 墨卡托平面坐标系统

 图块编号系统

经纬度是一种利用三维空间的球面来定义地球上的空间的球面坐标系,它能够标示地球上任何一个位置。通过伦敦格林尼治天文台原址的经线为0度经线,从0度经线向东、向西各分180度。赤道为0度纬线,赤道以北的纬线称为北纬、以南的称为南纬。在百度地图中,东经和北纬用正数表示,西经和南纬用负数表示。例如北京的位置大约是北纬39.9度,东经116.4度,那么用数值标示就是经度116.6,纬度39.9。

在百度地图中,习惯经度在前,纬度在后,例如:

var point = new BMap.Point(116.404, 39.915); // 创建点坐标,经度在前,纬度在后

由于百度地图是显示在平面上的,因此在地图内部系统中需要将球面坐标转换为平面坐标,这个转换过程称为投影。百度地图使用的是墨卡托投影。墨卡托平面坐标如下图所示,平面坐标与经纬度坐标系的原点是重合的。

百度地图在每一个级别将整个地图划分成若干个图块,通过编号系统将整个图块整合在一起以便显示完整的地图。当地图被拖动或者级别发生变化时,地图API将会根据平面坐标计算出当前视野内所需显示的图块的编号。百度地图图块编号规则如下图所示:

从平面坐标原点开始的右上方向的图块编号为0,0,以此类推。在最低的缩放级别(级别 1)中,整个地球由 4 张图块组成。随着级别的增长,地图所使用的图块个数也随之增多。

定义取图规则

通过TileLayer类开发者可以实现自定义图层。其中,TileLayer实例的getTilesUrl方法需要实现,用来告诉API取图规则。getTilesUrl方法的参数包括tileCoord和zoom,其中tileCoord为图块的编号信息,zoom为图块的级别,每当地图需要显示特定级别的特定位置的图块时就会自动调用此方法,并提供这两个参数。使用者需要告知API特定编号和级别所对应的图块的地址,这样API就能正常显示自定义的图层了。

添加和移除自定义图层

以下代码在每个图块的所有缩放级别上显示一个简单的透明叠加层,使用浮动红色小水滴表示图块的轮廓。

var map = new BMap.Map("l-map"); // 创建地图实例

var point = new BMap.Point(116.404, 39.915); // 创建点坐标

map.centerAndZoom(point,15); // 初始化地图,设置中心点坐标和地图级别

var tilelayer = new BMap.TileLayer(); // 创建地图层实例

tilelayer.getTilesUrl=function(){ // 设置图块路径

return "layer.gif";

};

map.addTileLayer(tilelayer); // 将图层添加到地图上

=========华丽丽的分隔线============

这里讲得让人一知半解,最主要的是,文档中并没有说明如何实现getTilesUrl方法,以及如何实现将一张自己的地图分隔成符合百度地图要求的图块。

现在记录一下我解决这个问题的过程。

首先,我先下载百度地图瓦格图片切图工具:

其次,找到自己的地图,导入其中进行切片,参考Sup_Heaven转的博文:

最后将图片放入项目资源文件中,实现getTitlesUrl方法即可。

这里需要补充一下的同,Sup_Heaven转的博文中,并没有详细说明中心点和瓦格图片之间的关系,只告诉我们其然却不知其所以然。借助度娘了解。百度地图的所有瓦格图片都是256px*256px的正方形图片,其图片的位置由经纬度和放大倍数zoom决定,所以在使用工具TileCutter时,设置对的级别范围和中心点,否则会导致切出的图片与实际需要不符。如果大家在使用过程有疑问的,欢迎留言交流