说明:

项目中使用vector图层做图片撒点功能,发现加载gif没有效果。网上查找资料发现,openlayers不支持gif图片样式。

后面采用overlay的方式,gif图片赋值给DOM元素

解决方案:

1、单个点

先在地图容器里新增一个id为marks的<div>标签

/*加载gif图片格式*/
function addGifMarks() {
let aa = document.getElementById('marks');
let lyr = new ol.Overlay({
id: "overlay",
position: [0, 0],//默认空
positioning: 'center-bottom',
element: aa,//绑定上面添加的元素
//stopEvent: false,
offset: [-13.5, -40]//图片偏移量
});
encMap.encmap.addOverlay(lyr);
var src = './assets/green.gif';//拼接图片地址
document.getElementById('marks').style.backgroundImage = 'url(' + src + ')';
lyr.setPosition([12970694.29785, 4743563.564]); //显示
}

这个方法的核心在于使用Overlay的element属性绑定一个<div>标签,然后将gif图片路径设置给这个<div>标签的backgroundImage样式。(这个思路可以用在很多地方)

2、多点

    /**
* @description 撒点(以overlay的element方式,解决openlayers无法加载gif图片等问题)
* @param {Map} _map 地图对象
* @param {Array} _points 点集,格式[{attributes:{x:12976694.29785,y:4743563.56400}},{attributes:{x:12937907.75571,y:4778074.42433}}]
* @param {Object} _imgParam 图片名称,格式{src:图片url,width:50px,height:100px),格式{src:图片url,width:图片宽,height:图片高}
* @param {String} _elementId overlay添加的容器Id
* @param {Function} _clickFunc 点击图片回调函数
*/
this.addMarksByOverlay = function (_map, _points, _imgParam, _elementId, _clickFunc) {
let marker = null;
//循环点集
for (let i = 0; i < _points.length; i++) {
//新增放置overly的div
let _overlay = document.getElementById(_elementId);
_overlay.id = _elementId;
if(document.getElementById("overlay" + i))
{
let _removeLyr = _map.encmap.getOverlayById("overlay" + i);
_map.encmap.removeOverlay(_removeLyr);
}
let sElement = document.createElement("div");
sElement.id = "overlay" + i;
sElement.style.width = _imgParam.width;
sElement.style.height = _imgParam.height;
sElement.attr = _points[i].attributes;
sElement.x = _points[i].attributes.x;
sElement.y = _points[i].attributes.y;
_overlay.appendChild(sElement); //新增overly
var lyr = new ol.Overlay({
id: 'overlay' + i,
positioning: 'center-center',
//属性
attributes: _points[i].attributes,
//overly放置的div
element: document.getElementById('overlay' + i),
stopEvent: false
}); //逐个把overly添加到地图上
_map.encmap.addOverlay(lyr);
var src = _imgParam.src;//拼接图片地址
document.getElementById('overlay' + i).style.backgroundImage = 'url(' + src + ')';
lyr.setPosition([_points[i].attributes.x, _points[i].attributes.y]); //显示 //如果点击事件
if (_clickFunc) {
document.getElementById('overlay' + i).onclick = function (evt) {
if (!evt.currentTarget.attr) {
return;
}
let attr = evt.currentTarget.attr;
attr.x = evt.currentTarget.attr.x ? evt.currentTarget.attr.x : 0;
attr.y = evt.currentTarget.attr.y ? evt.currentTarget.attr.y : 0;
_clickFunc(attr);
};
}
}
}

多点的核心思路和加载单点一样,但是多了一个逻辑。

设想一下,如果一个Overlay绑定一个div,一个div生成一个点要素的话,可以推得一个Overlay就相当于一个点。

问题就来了,如果按单点的方法来的话,我撒100个点就需要预先建100个div,这并不科学。

因此这里我采用动态构建div的方法,找到id为_elementId的控件,在里面新建id为overlay1,overlay2,overlay3...的div,并循环绑定Overlay

第二次加载前,会判断是否加载过,如果加载过,则先清空上一次的div

附清空方法:

     let olLyrs = this.encmap.getOverlays().getArray();
let olLyrsLength = this.encmap.getOverlays().getArray().length;
for(let i = 0;i < olLyrsLength;i++){
olLyrs[i].setPosition(undefined);
//olLyrs[i] = null;
}

Openlayers Overlay加载gif图片的更多相关文章

  1. WebView加载HTML图片大小自适应与文章自动换行

    http://www.brighttj.com/ios/ios-webview-load-html-image-adaptive.html 在很多App中都会使用到webview,尤其是在加载新闻内容 ...

  2. Android ListView 图片异步加载和图片内存缓存

    开发Android应用经常需要处理图片的加载问题.因为图片一般都是存放在服务器端,需要联网去加载,而这又是一个比较耗时的过程,所以Android中都是通过开启一个异步线程去加载.为了增加用户体验,给用 ...

  3. WPF中加载高分辨率图片性能优化

    在最近的项目中,遇到一个关于WPF中同时加载多张图片时,内存占用非常高的问题. 问题背景: 在一个ListView中同时加载多张图片,注意:我们需要加载的图片分辨率非常高. 代码: XAML: < ...

  4. Fresco 使用笔记(一):加载gif图片并播放

    项目总结 --------------------------------------------------------------------- 前言: 项目中图文混合使用的太多太多了,但是绝大部 ...

  5. 图片_ _Android有效解决加载大图片时内存溢出的问题 2

    Android有效解决加载大图片时内存溢出的问题 博客分类: Android Android游戏虚拟机算法JNI 尽量不要使用setImageBitmap或 setImageResource或 Bit ...

  6. Delphi7 第三方控件1stClass4000的TfcImageBtn按钮控件动态加载jpg图片例子

    Delphi7 第三方控件1stClass4000的TfcImageBtn按钮控件动态加载jpg图片例子 procedure TForm1.Button1Click(Sender: TObject); ...

  7. Adobe Edge Animate –解决图形边缘精确检测问题-通过jquery加载svg图片

    Adobe Edge Animate –解决图形边缘精确检测问题-通过jquery加载svg图片 版权声明: 本文版权属于 北京联友天下科技发展有限公司. 转载的时候请注明版权和原文地址. 在edge ...

  8. android95 缩放加载大图片

    MainActivity: package com.itheima.loadimage; import android.os.Bundle; import android.app.Activity; ...

  9. Android(java)学习笔记236:多媒体之加载大图片到内存(Bitmap API)

    1.Bitmap (API使用) android里面的bitmap中,一个像素点需要4个byte去表示,这是因为android表示颜色是" argb ":其中 a 表示是透明度,然 ...

随机推荐

  1. 音视频入门-11-PNG文件格式详解

    * 音视频入门文章目录 * PNG 文件格式解析 PNG 图像格式文件由一个 8 字节的 PNG 文件署名域和 3 个以上的后续数据块(IHDR.IDAT.IEND)组成. PNG 文件包括 8 字节 ...

  2. SpringBoot学习(三)探究Springboot自动装配

    目录 什么是自动装配 何时自动装配 原理分析 注:以下展示的代码springboot的版本为2.0.3版.因源码过长,大家选择展开代码 ㄟ( ▔, ▔ )ㄏ 什么是自动装配 自动装配还是利用了Spri ...

  3. CMMS系统中工单派案&调度

    系统为客户经理提供一个有效的调度控制台,由客户经理负责将需要外派现场处理的工单进行统一的分配调度,系统显示每个技术人员的时间表,根据专业技能.可用性.距离或其他资格标准筛选技术服务人员,并向调度人员提 ...

  4. Spring Boot 配置 - 配置信息加密

    ▶ Spring Boot 依赖与配置 Maven 依赖 <dependency> <groupId>org.springframework.boot</groupId& ...

  5. (五)Unity插件生成

    1)新建空的AndroidStudio工程,但是新建过程时最小SDK版本要与unity一致,如下图所示,本次操作均为api16 2)创建Library,如下图所示,新建module,然后选择Andro ...

  6. Nginx、WSGI、 uWSGI、 uwsgi的区别

    当我们部署完一个应用程序,浏览网页时具体的过程是怎样的呢?首先我们得有一个 Web 服务器来处理 HTTP 协议的内容,Web 服务器获得客户端的请求,交给应用程序,应用程序处理完,返回给 Web 服 ...

  7. Mongo 导出为csv文件

    遇到需要从Mongo库导出到csv的情况,特此记录. 先贴上在mongo目录下命令行的语句: ./mongoexport -h 10.175.54.77 -u userName -p password ...

  8. 【XSY2558】圆上的蚂蚁 Ants on circle

    Description L个点围成一个圆. 我们选定任意一个点作为原点, 则每个点的坐标为从原点顺时针走到这个点的距离. 圆上有N只蚂蚁, 分别被编号为1到N. 开始时, 第ii只蚂蚁在坐标为Xi的点 ...

  9. Weed:线段树

    观察复杂度,是log级别以下回答询问的. O(1)?逗我kx呢? 自然而然地想到线段树. 学长讲的原题啊考场上还不会打. 线段树上的每个节点都表示一个操作区间. 线段树上维护的权值有3个:这个子区间一 ...

  10. P1041 传染病控制(noip2003)(搜索)

    呃呃呃...真的是惨烈啊... 今天的模拟赛是真的惨..... 本题,正解居然是搜索!!!!!! 蒟蒻自己歪歪了一个貌似是正解但是却连一半都没过的错解. 先解释一下自己的dp思路把. $f[i][u] ...