说明:

项目中使用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. nuxt.js部署vue应用到服务端过程

    由于seo的需要,最近将项目移植道nuxt.js下采用ssr渲染 移植完成后,一路顺畅,但是到了要部署到服务器端上时候,还是个头疼的问题,但最终还是顺利完成.现在记录一下部署中的过程. 注:部署时候过 ...

  2. SpringBoot系列教程之Bean之指定初始化顺序的若干姿势

    上一篇博文介绍了@Order注解的常见错误理解,它并不能指定 bean 的加载顺序,那么问题来了,如果我需要指定 bean 的加载顺序,那应该怎么办呢? 本文将介绍几种可行的方式来控制 bean 之间 ...

  3. 使用haproxy实现负载均衡集群

    一.HAProxy概述: HAProxy提供高可用性.负载均衡以及基于TCP和HTTP应用的代理,支持虚拟主机,它是免费.快速并且可靠的一种解决方案.根据官方数据,其最高极限支持10G的并发. HAP ...

  4. vue-music 使用better-scroll遇到轮播图不能自动轮播

    根据vue-music视频中slider组建的使用,当安装新版本的better-scroll,轮播组件,不能正常轮播 这是因为,better-scroll发布新版本之后,参数设置发生改变 这是旧版本: ...

  5. spring-boot-plus V1.4.0发布 集成用户角色权限部门管理

    RBAC用户角色权限 用户角色权限部门管理核心接口介绍 Shiro权限配置

  6. 通俗地说逻辑回归【Logistic regression】算法(一)

    在说逻辑回归前,还是得提一提他的兄弟,线性回归.在某些地方,逻辑回归算法和线性回归算法是类似的.但它和线性回归最大的不同在于,逻辑回归是作用是分类的. 还记得之前说的吗,线性回归其实就是求出一条拟合空 ...

  7. 对比讲解lambda表达式与传统接口函数实现方式

    在本号之前写过的一些文章中,笔者使用了lambda表达式语法,一些读者反映说代码看不懂.本以为java 13都已经出了,java 8中最重要特性lambda表达式大家应该都掌握了,实际上还是存在大量的 ...

  8. windows服务参考

    dll文件 aaclient.dll 何时何地都可以访问客户端 accessibilitycpl.dll 轻松访问控制面板 acledit.dll 访问控制列表编辑器 aclui.dll 安全描述符编 ...

  9. C语言作业007

    问题 答案 这个作业属于那个课程 C语言程序设计1 这个作业要求在哪里 我在这个课程的目的是 学习并掌握C语言 这个作业在那个具体方面帮助我实现目标 参考文献 四 作业格式 1PTA作业贴图 1.1题 ...

  10. 看电影(movie):组合数

    Description 到了难得的假期,小白班上组织大家去看电影.但由于假期里看电影的人太多,很难做到让全班看上同一场电影,最后大家在一个偏僻的小胡同里找到了一家电影院.但这家电影院分配座位的方式很特 ...