Vue2 中使用C-Lodop打印控件时无法调整二维码大小问题

简介: Vue2 中使用C-Lodop打印控件时无法调整二维码大小问题,打印模板里配置的二维码是偏小的,但是在页面使用打印的时候打印预览的二维码不是预期大小

问题描述:
   打印模板里配置的二维码是偏小的,但是在页面使用打印的时候打印预览的二维码不是预期大小,如图:
5366a9c0cd4d4421ae7ee376cf82b28f.png
6378f426c7854a318051cbe17937ab2d.png
原因:
配置二维码的时候上下左右(图中箭头)会有一部分区域,打印时的二维码会根据图中虚线的范围作为二维码的宽高,因此会导致二维码的大小不能达到预期。
4f6dc2d60d0d4f479dcaed49a0ee307c.png
4f6dc2d60d0d4f479dcaed49a0ee307c.png
解决办法:
用模板的 width 和 height 来判断当前的阴影部分,若 width > height,那么就将 height作为二维码的宽高,左边的偏移量为 ( width - height ) / 2。若 width < height,那么将 width 作为二维码的宽高。(备注:左边偏移量不设置会导致二维码的位置不对)
代码如下:



let size = null;
let left = null;
if (item.options.width > item.options.height) {
     size = item.options.height;
     left = (item.options.width - item.options.height) / 2;
   } else {
     size = item.options.width;
   }
LODOP.ADD_PRINT_IMAGE(
    item.options.top * 1.35,
    (item.options.left + left) * 1.4,
    size * 1.45,
    size * 1.45,
    `<img border='0' src='${imageUrl}' width='100%' />`

});
相关文章
|
7月前
|
前端开发 JavaScript
vue实现页面截图、保存图片功能
vue实现页面截图、保存图片功能
206 1
|
6月前
vue2.0移动端自定义性别选择提示框
vue2.0移动端自定义性别选择提示框
34 0
|
6月前
vue-element日期框点击不显示,不刷新
vue-element日期框点击不显示,不刷新
[Vue3+Element-Plus]点击列表中的图片预览时,图片被表格覆盖。
点击图片进行预览,但是还能继续选中其他的图片进行预览,鼠标放在表格上,那一行表格也会选中,如图所示第一行,那么该如何解决呢?
|
12月前
|
JSON JavaScript API
Vue2.x-01点击按钮弹出子Vue组件,遍历JSON展示数据
Vue2.x-01点击按钮弹出子Vue组件,遍历JSON展示数据
202 0
|
JavaScript
Vue 修改网页标题和图标
Vue 修改网页标题和图标
296 0
|
JavaScript 定位技术
vue 里怎么使用 echarts 实现地图自动轮播功能、自定义 tooltip 悬浮位置提示、自定义 label 标签位置样式?
vue 里怎么使用 echarts 实现地图自动轮播功能、自定义 tooltip 悬浮位置提示、自定义 label 标签位置样式?
794 0
vue 里怎么使用 echarts 实现地图自动轮播功能、自定义 tooltip 悬浮位置提示、自定义 label 标签位置样式?
|
JavaScript
vue 里实现文本超出时点击左右按钮滚动?
vue 里实现文本超出时点击左右按钮滚动?
290 0
vue 里实现文本超出时点击左右按钮滚动?
|
JavaScript 前端开发 API
vue里怎么实现文本溢出才显示title提示
vue里怎么实现文本溢出才显示title提示
383 0
vue里怎么实现文本溢出才显示title提示
|
前端开发 JavaScript
Vue3实现一个标题点击变粗且底部有提示的效果(一)
Vue3实现一个标题点击变粗且底部有提示的效果
Vue3实现一个标题点击变粗且底部有提示的效果(一)