Commit 19024816 authored by lei's avatar lei

Merge branch 'gaoqucodecheck' of...

Merge branch 'gaoqucodecheck' of http://h.gemho.cn:7099/zhaojunbao/gaoquyingjih5-asd into gaoqucodecheck
parents 8bf451d2 dae4924b
image/code/erweimabg.png

527 KB | W: | H:

image/code/erweimabg.png

280 KB | W: | H:

image/code/erweimabg.png
image/code/erweimabg.png
image/code/erweimabg.png
image/code/erweimabg.png
  • 2-up
  • Swipe
  • Onion skin
...@@ -42,3 +42,8 @@ ...@@ -42,3 +42,8 @@
cursor: pointer; cursor: pointer;
margin-bottom: .4rem; margin-bottom: .4rem;
} }
.hideEle {
/* visibility: hidden; */
display: none;
}
\ No newline at end of file
...@@ -48,11 +48,16 @@ ...@@ -48,11 +48,16 @@
<div class="qr-card"> <div class="qr-card">
<!-- <canvas id="mainCanvas" width="3000" height="4000"></canvas> --> <!-- <canvas id="mainCanvas" width="3000" height="4000"></canvas> -->
<!-- 基础调试确认版 --> <!-- 基础调试确认版 -->
<canvas id="mainCanvas" width="420" height="594"></canvas> <!-- <canvas id="mainCanvas" width="420" height="594"></canvas> -->
<!-- 不晃动rev --> <!-- 不晃动rev -->
<!-- <canvas id="mainCanvas" width="375" height="530"></canvas> --> <!-- <canvas id="mainCanvas" width="375" height="530"></canvas> -->
<canvas id="displayCanvas"></canvas> <!-- 页面预览用 -->
</div> </div>
<button class="save-btn" onclick="saveCanvas()" v-if="canvasReady">保存二维码</button> <!-- <button class="save-btn" onclick="saveCanvas()" v-if="canvasReady">保存二维码</button> -->
<button class="save-btn" onclick="saveImage()" :class="{'showEle': true}">保存二维码</button>
</div> </div>
</body> </body>
......
var VUE = null var VUE = null
window.addEventListener('load', function () { window.addEventListener('load', function () {
const canvas = document.getElementById('mainCanvas') // const canvas = document.getElementById('mainCanvas')
const ctx = canvas.getContext('2d') // const ctx = canvas.getContext('2d')
ctx.imageSmoothingEnabled = true; // ctx.imageSmoothingEnabled = true;
ctx.imageSmoothingQuality = 'high'; // ctx.imageSmoothingQuality = 'high';
ctx.fillStyle = '#1890ff'; // 或其他所需颜色 // ctx.fillStyle = '#1890ff'; // 或其他所需颜色
ctx.fillRect(0, 0, canvas.width, canvas.height); // ctx.fillRect(0, 0, canvas.width, canvas.height);
// 配置参数
const CONFIG = {
bgSize: { width: 2480, height: 3502 }, // 背景图原始尺寸
qrSize: 1150, // 二维码尺寸
pageWidth: 375 // 页面显示宽度
};
// 初始化双Canvas
const displayCanvas = document.getElementById('displayCanvas');
const exportCanvas = document.createElement('canvas');
const displayCtx = displayCanvas.getContext('2d');
const exportCtx = exportCanvas.getContext('2d');
// 设置离屏Canvas(固定导出尺寸)
exportCanvas.width = CONFIG.bgSize.width;
exportCanvas.height = CONFIG.bgSize.height;
// 适配显示Canvas
function initDisplayCanvas() {
const dpr = window.devicePixelRatio || 1;
const displayHeight = (CONFIG.pageWidth / CONFIG.bgSize.width) * CONFIG.bgSize.height;
// 设置物理像素
displayCanvas.width = CONFIG.pageWidth * dpr;
displayCanvas.height = displayHeight * dpr;
// 调整CSS显示尺寸
displayCanvas.style.width = `${CONFIG.pageWidth}px`;
displayCanvas.style.height = `${displayHeight}px`;
// 缩放绘图上下文
displayCtx.scale(dpr, dpr);
displayCtx.imageSmoothingEnabled = true; // 抗锯齿
}
// 加载并绘制资源
async function drawPoster(bgUrl, qrUrl) {
const [bgImage, qrImage] = await Promise.all([
loadImage(bgUrl),
loadImage(qrUrl)
]);
if(!bgImage || !qrImage){
console.log('图片加载失败')
return
}
// 计算显示比例
const scale = CONFIG.pageWidth / CONFIG.bgSize.width;
// 绘制显示Canvas(适配页面宽度)
displayCtx.drawImage(bgImage, 0, 0, CONFIG.bgSize.width, CONFIG.bgSize.height,
0, 0, CONFIG.pageWidth, CONFIG.pageWidth * (CONFIG.bgSize.height/CONFIG.bgSize.width));
// 绘制二维码(居中显示)
const qrDisplaySize = CONFIG.qrSize * scale;
const qrX = (CONFIG.pageWidth - qrDisplaySize) / 2;
const qrY = displayCanvas.height/displayCtx.getTransform().a - qrDisplaySize - 50*scale -980*scale;
displayCtx.drawImage(qrImage, qrX, qrY, qrDisplaySize, qrDisplaySize);
// 绘制离屏Canvas(原始尺寸)
exportCtx.drawImage(bgImage, 0, 0);
const qrExportX = (CONFIG.bgSize.width - CONFIG.qrSize) / 2;
const qrExportY = CONFIG.bgSize.height - CONFIG.qrSize - 100 -980;
exportCtx.drawImage(qrImage, qrExportX, qrExportY, CONFIG.qrSize, CONFIG.qrSize);
// VUE.canvasReady = true
document.getElementById('saveBtn').classList.remove('hideEle')
}
// 图片加载器
function loadImage(url) {
return new Promise((resolve, reject) => {
const img = new Image();
img.crossOrigin = 'anonymous';
img.onload = () => resolve(img);
img.onerror = reject;
img.src = url;
});
}
// 导出图片
window.saveImage = function() {
// const link = document.createElement('a');
// link.download = 'poster.jpg';
// link.href = exportCanvas.toDataURL('image/jpeg', 0.9);
// link.click();
// const canvas = document.getElementById('mainCanvas')
const dataURL = exportCanvas.toDataURL('image/png', 0.9)
console.log(dataURL, '图片下载')
lightAppJssdk.media.savePhoto({
arg: dataURL,
success: function (data) {
// vant.Toast.clear()
// alert(JSON.stringify(data))
vant.Dialog.alert({
message: '保存成功',
})
},
fail: function (data) {
// vant.Toast.clear()
// alert('保存失败')
vant.Dialog.alert({
message: '保存失败',
})
},
})
}
// 初始化执行
initDisplayCanvas();
// const qrcodeUrl = ''
// drawPoster('../image/code/erweimabg.png', qrcodeUrl);
// 在原有Vue实例中添加 // 在原有Vue实例中添加
...@@ -17,40 +135,35 @@ window.addEventListener('load', function () { ...@@ -17,40 +135,35 @@ window.addEventListener('load', function () {
canvasReady: false, canvasReady: false,
loadedImages: 0, // 记录已加载的图片数量 loadedImages: 0, // 记录已加载的图片数量
formData: { formData: {
id: 1, id: '',
unitName: '威海火炬高技术产业开发区沸腾小火锅店', unitName: '',
businessAddress: '268-7-D2-4', businessAddress: '',
smallPlaceTypeId: 2, smallPlaceTypeId: 0,
useNature: '餐饮店', useNature: '',
unifiedSocialCreditCode: '92371000MA3U6FCR02', unifiedSocialCreditCode: '',
area: 51.61, area: '',
employeeCount: 2, employeeCount: 0,
owner: '朱德艳', owner: '',
merchantPhone: '13863159973', merchantPhone: '',
qrCodeUrl: '', qrCodeUrl: '',
community: '欧乐坊社区', community: '',
street: '田和街道', street: '',
gridMemberName: '于灏', gridMemberName: '',
gridMemberPhone: '17865160657', gridMemberPhone: '',
createBy: '', createBy: '',
createTime: null, createTime: null,
updateBy: '', updateBy: '',
updateTime: '2025-04-02 01:30:33', updateTime: '',
remark: '', remark: '',
deptId: 209, deptId: '',
merchantId: 0, merchantId: 0,
smallPlaceType: '', smallPlaceType: '',
smallPlaceTypeName: '小餐饮', smallPlaceTypeName: '',
principal: '', principal: '',
phone: '', phone: '',
area: '', area: '',
businessHours: '', businessHours: '',
type: '', // 新增类型字段 type: '', // 新增类型字段
sjName1: '威海市宝威酒店有限公司',
sjName2: 'XXX',
sjName3: '0631-522221212',
sjName4: '威海市XXXXXXXXX',
sjName5: '小餐饮',
}, },
showTypePicker: false, showTypePicker: false,
typeOptions: ['小餐饮', '酒店', '商场', '学校', '医疗机构'], typeOptions: ['小餐饮', '酒店', '商场', '学校', '医疗机构'],
...@@ -58,7 +171,6 @@ window.addEventListener('load', function () { ...@@ -58,7 +171,6 @@ window.addEventListener('load', function () {
}, },
computed: {}, computed: {},
mounted() { mounted() {
this.detail() this.detail()
}, },
methods: { methods: {
...@@ -100,7 +212,9 @@ window.addEventListener('load', function () { ...@@ -100,7 +212,9 @@ window.addEventListener('load', function () {
const QR_IMAGE_URL = result.data.qrCodeUrl const QR_IMAGE_URL = result.data.qrCodeUrl
// '' // ''
this.generateQRCode(QR_IMAGE_URL) // this.generateQRCode(QR_IMAGE_URL)
// const qrcodeUrl = ''
drawPoster('../image/code/erweimabg.png', QR_IMAGE_URL);
} }
}) })
...@@ -112,97 +226,99 @@ window.addEventListener('load', function () { ...@@ -112,97 +226,99 @@ window.addEventListener('load', function () {
this.showTypePicker = false this.showTypePicker = false
}, },
generateQRCode(QR_IMAGE_URL) { // generateQRCode(QR_IMAGE_URL) {
this.canvasReady = false // this.canvasReady = false
// 加载二维码图片 // // 加载二维码图片
const img = new Image() // const img = new Image()
img.crossOrigin = 'Anonymous' // 处理跨域问题 // img.crossOrigin = 'Anonymous' // 处理跨域问题
img.src = '../image/code/erweimabg.png' // QR_IMAGE_URL; // img.src = '../image/code/erweimabg.png' // QR_IMAGE_URL;
const img4erweima = new Image() // const img4erweima = new Image()
img4erweima.crossOrigin = 'Anonymous' // 处理跨域问题 // img4erweima.crossOrigin = 'Anonymous' // 处理跨域问题
img4erweima.src = QR_IMAGE_URL // QR_IMAGE_URL; // img4erweima.src = QR_IMAGE_URL // QR_IMAGE_URL;
img.onload = () => { // img.onload = () => {
this.loadedImages++ // this.loadedImages++
this.drawImages(img, img4erweima) // this.drawImages(img, img4erweima)
} // }
img4erweima.onload = () => { // img4erweima.onload = () => {
this.loadedImages++ // this.loadedImages++
this.drawImages(img, img4erweima) // this.drawImages(img, img4erweima)
} // }
}, // },
drawImages(img, img4erweima) { // drawImages(img, img4erweima) {
if (this.loadedImages === 2) { // if (this.loadedImages === 2) {
// 画布的宽度和高度 // // 画布的宽度和高度
const canvasWidth = canvas.width // const canvasWidth = canvas.width
const canvasHeight = canvas.height // const canvasHeight = canvas.height
// 图片的原始宽度和高度 // // 图片的原始宽度和高度
const imgWidth = img.width // const imgWidth = img.width
const imgHeight = img.height // const imgHeight = img.height
// 计算宽度和高度的缩放比例 // // 计算宽度和高度的缩放比例
const scaleX = canvasWidth / imgWidth // const scaleX = canvasWidth / imgWidth
const scaleY = canvasHeight / imgHeight // const scaleY = canvasHeight / imgHeight
// 取较小的缩放比例作为最终的缩放比例 // // 取较小的缩放比例作为最终的缩放比例
const scale = Math.min(scaleX, scaleY) // const scale = Math.min(scaleX, scaleY)
// 计算缩放后的图片宽度和高度 // // 计算缩放后的图片宽度和高度
const scaledWidth = imgWidth * scale // const scaledWidth = imgWidth * scale
const scaledHeight = imgHeight * scale // const scaledHeight = imgHeight * scale
// 计算图片在画布上的绘制位置,使其居中显示 // // 计算图片在画布上的绘制位置,使其居中显示
const x = (canvasWidth - scaledWidth) / 2 // const x = (canvasWidth - scaledWidth) / 2
const y = (canvasHeight - scaledHeight) / 2 // const y = (canvasHeight - scaledHeight) / 2
// 绘制图片到 canvas 上 // // 绘制图片到 canvas 上
ctx.drawImage(img, x, y, scaledWidth, scaledHeight) // ctx.drawImage(img, x, y, scaledWidth, scaledHeight)
// 绘制前景图标 // // 绘制前景图标
const fgIconSize = 180 // 假设前景图标显示的尺寸 // const fgIconSize = 180 // 假设前景图标显示的尺寸
const fgX = (canvasWidth - fgIconSize) / 2 // const fgX = (canvasWidth - fgIconSize) / 2
const fgY = ((canvasHeight - fgIconSize) / 2 ) + 15 // const fgY = ((canvasHeight - fgIconSize) / 2 ) + 15
// 绘制二维码 // // 绘制二维码
ctx.drawImage(img4erweima, fgX, fgY, fgIconSize, fgIconSize) // ctx.drawImage(img4erweima, fgX, fgY, fgIconSize, fgIconSize)
this.canvasReady = true // this.canvasReady = true
} // }
}, // },
}, },
}) })
}) })
function saveCanvas() { // function saveCanvas() {
if (!VUE.canvasReady) return // if (!VUE.canvasReady) return
vant.Toast.loading({ // vant.Toast.loading({
message: '图片保存中...', // message: '图片保存中...',
forbidClick: true, // forbidClick: true,
loadingType: 'spinner', // loadingType: 'spinner',
}); // });
// const canvas = document.getElementById('mainCanvas')
// const dataURL = canvas.toDataURL('image/png')
// console.log(dataURL, '图片下载')
// lightAppJssdk.media.savePhoto({
// arg: dataURL,
// success: function (data) {
// // vant.Toast.clear()
// // alert(JSON.stringify(data))
// vant.Dialog.alert({
// message: '保存成功',
// })
// },
// fail: function (data) {
// // vant.Toast.clear()
// // alert('保存失败')
// vant.Dialog.alert({
// message: '保存失败',
// })
// },
// })
// }
const canvas = document.getElementById('mainCanvas')
const dataURL = canvas.toDataURL('image/png')
console.log(dataURL, '图片下载')
lightAppJssdk.media.savePhoto({
arg: dataURL,
success: function (data) {
// vant.Toast.clear()
// alert(JSON.stringify(data))
vant.Dialog.alert({
message: '保存成功',
})
},
fail: function (data) {
// vant.Toast.clear()
// alert('保存失败')
vant.Dialog.alert({
message: '保存失败',
})
},
})
}
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment