使用html2canvas对有百度地图的Dom元素处理成图片的解决

所属分类: HTML/Xhtml / 网页制作 阅读数: 544
收藏 0 赞 0 分享

问题1:百度地图应用的是瓦片式图片(地图是一张张图片拼出来的),html2canvas 处理时,遇到非同一域名下的图片,浏览器会显示跨域的报错,也无法用反向代理来解决,因为瓦片图片的域名不确定,无法指定 proxy_pass

解决:使用百度地图静态图处理( http://lbsyun.baidu.com/index.php?title=static ),这时域名确定了( http://api.map.baidu.com ),可以用反向代理来解决跨域

<!--html--><el-image:src="`/baidu-static/staticimage/v2?ak=yourak&width=1024&height=400¢er=${center.lng
}
,${center.lat
}
&zoom=16`"><div  slot="placeholder"
  class="image-slot">
  加载中<span class="dot">...</span></div></el-image><!--nginx-->location ^~ /baidu-static/ {add_header 'Access-Control-Allow-Origin' "$http_origin" always;add_header 'Access-Control-Allow-Credentials' 'true' always;add_header 'Access-Control-Allow-Methods' 'GET, OPTIONS' always;add_header 'Access-Control-Allow-Headers' 'Accept,Authorization,Cache-Control,Content-Type,DNT,If-Modified-Since,Keep-Alive,Origin,User-Agent,X-Requested-With' always;proxy_pass http://api.map.baidu.com/;
}

问题2:地图上的覆盖物怎么显示出来呢

解决:看了下百度地图静态图的 api, 不能很好的支持覆盖物自定义样式,最多可以让你指定一张自定义的图片(不能是本地图片)。中间试过很多办法,觉得可行的是使用 openLayers.Map, 可是代码改动的工作量太大了,果断放弃了。再后来想到自己用 div 直接模拟好覆盖物,设置比静态图层级高一点就可以解决了。

问题3:用 css 样式画了一个虚线圆,在 html2canvas 处理后的生成的图,发现虚线变成了实线

解决:使用 canvas 来画圆

问题4:一个 icon 采用绝对定位,在 html2canvas 处理后的生成的图,发现 icon 没有显示

解决:给 icon 设置 z-index 大于百度静态图层级(PS: 静态图的样式也用了绝对定位的情况下)

问题5:在 html2canvas 处理后生成的图片,有黑色背景色

解决: image/png 改成 image/jpg

try {
  html2canvas(sharePage, {
    useCORS: true  
}
).then((canvas) => {
    const imgBase64 = canvas.toDataURL('image/jpg')    this.data64 = imgBase64    
}
)  
}
 catch (err) {
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

更多精彩内容其他人还在看

Html屏蔽右键菜单和左键划字功能的示例

禁止右键菜单<body oncontextmenu=self.event.returnValue=false>禁止左键划字复制<body onselectstart="return false">采用CSS来控制是否可以选择文字.uns... 查看详情
收藏 0 赞 0 分享

html+css+js 实现拍照预览上传图片功能

前言:我们在做网页时经常会需要有上传图片的需求,可能是选择图片或者拍照上传,如果简单的使用<input type="file"/>这种方式虽然也能实现功能,但用户体验上可能会差了一些,所以本文记录了使用css+js实现图片选中后的预览及压缩上传功能... 查看详情
收藏 0 赞 0 分享

HTML阻止iframe跳转页面并使用iframe在页面内嵌微信网页版的实现方法

就想弄一个winform结合html5的一个小东西,突有兴致,想在里面嵌套一个微信网页版。好了,想法一出来,就行动吧,最终效果如下图:一开始就打算在页面里面嵌套一个iframe指向https://wx.qq.com就OK了,但是我还是太天真,微信网页版会自动跳转。结果如下图:于是... 查看详情
收藏 0 赞 0 分享

详解HTML常用的标签中行内元素和块级元素

块元素(block element) HTML标签分类明细     * address - 地址     * blockquote - 块引用     * center - 举中对... 查看详情
收藏 0 赞 0 分享

解决移动端跳转问题(CSS过渡、target伪类)

前言很多刚刚接触移动端的小伙伴都可能对于点击跳转路由这方面有些疑惑,特别是运用了Vue路由,因此这篇文章就带领小伙伴一起尝试用css进行页面跳转效果如图,由于是移动端,所以选择预览的手机模拟:HTML <body> <main> ... 查看详情
收藏 0 赞 0 分享

浅谈HTML中src和href之间的区别

简单来说 src 就是 “我想加载这个资源”,而 href 就是 “我想和这个资源建立关联”src 主要用于元素替换,href 用于和相关文档和外部资源建立相关链接。href 属性说明本地Web资源和定义的资源建立了链接。如:<... 查看详情
收藏 0 赞 0 分享

HTML中的if判断用法

在django的web开发过程中,编写html时,从后端传入同名列表变量,但是内容格式有所区别,需要分别判断,查阅了很多文章试了好几种方法,格式似乎都不太对(本人没有系统学习过前端,基本都是照葫芦画瓢)后来找到django框架下html的if用法形式大致如下  ... 查看详情
收藏 0 赞 0 分享

详解html的几种水平垂直居中的方式(基础)

前言我们在编写马过程中,想必大家对水平垂直居中的方法了解并不多。所以我给大家总结式的列出几种常用的水平垂直居中的方法。第一种方法<!--html盒子代码--><!--水平垂直居中--><div class="Centered1"&... 查看详情
收藏 0 赞 0 分享

纯css实现(无脚本)Html指令式tooltip文字提示效果

 分析执行流程 鼠标移入节点 检测是该节点是否存在开启实现 tooltip 实现的标识(类名,属性等) 检测主题、位置(类名,属性等) 生成 / 显示气泡 借鉴他人让我们先来看看 element-ui的tooltip 样式很明显, 气泡的位置 是通过 javascrip... 查看详情
收藏 0 赞 0 分享

Markodwn 标题对齐的同步滚动实现思路详解

前言需要给正在写的Markodwn编辑器加上同步滚动的功能,百度了一通,没找到比较好的思路。就自己写了一个。Github上是写好的库,和更直观的Demo。Github这篇文章主要讲的是实现的思路。介绍同步滚动的实现方式有很多种。简单粗暴的就直接让 HTMLElement.scro... 查看详情
收藏 0 赞 0 分享
查看更多