Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
GaoQuYingJiH5-ASD
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
xinzhedeai
GaoQuYingJiH5-ASD
Commits
7719368e
Commit
7719368e
authored
Apr 17, 2025
by
xinzhedeai
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
add 商户详情:二维码海报(高清)
parent
1e204885
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
239 additions
and
113 deletions
+239
-113
erweimabg.png
image/code/erweimabg.png
+0
-0
_shanghu_detail.css
src/_shanghu_detail.css
+5
-0
_shanghu_detail.html
src/_shanghu_detail.html
+7
-2
_shanghu_detail.js
src/_shanghu_detail.js
+227
-111
No files found.
image/code/erweimabg.png
View replaced file @
1e204885
View file @
7719368e
527 KB
|
W:
|
H:
280 KB
|
W:
|
H:
2-up
Swipe
Onion skin
src/_shanghu_detail.css
View file @
7719368e
...
...
@@ -42,3 +42,8 @@
cursor
:
pointer
;
margin-bottom
:
.4rem
;
}
.hideEle
{
/* visibility: hidden; */
display
:
none
;
}
\ No newline at end of file
src/_shanghu_detail.html
View file @
7719368e
...
...
@@ -48,11 +48,16 @@
<div
class=
"qr-card"
>
<!-- <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 -->
<!-- <canvas id="mainCanvas" width="375" height="530"></canvas> -->
<canvas
id=
"displayCanvas"
></canvas>
<!-- 页面预览用 -->
</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>
</body>
...
...
src/_shanghu_detail.js
View file @
7719368e
var
VUE
=
null
window
.
addEventListener
(
'
load
'
,
function
()
{
const
canvas
=
document
.
getElementById
(
'
mainCanvas
'
)
const
ctx
=
canvas
.
getContext
(
'
2d
'
)
ctx
.
imageSmoothingEnabled
=
true
;
ctx
.
imageSmoothingQuality
=
'
high
'
;
ctx
.
fillStyle
=
'
#1890ff
'
;
// 或其他所需颜色
ctx
.
fillRect
(
0
,
0
,
canvas
.
width
,
canvas
.
height
);
// const canvas = document.getElementById('mainCanvas')
// const ctx = canvas.getContext('2d')
// ctx.imageSmoothingEnabled = true;
// ctx.imageSmoothingQuality = 'high';
// ctx.fillStyle = '#1890ff'; // 或其他所需颜色
// 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实例中添加
...
...
@@ -17,40 +135,35 @@ window.addEventListener('load', function () {
canvasReady
:
false
,
loadedImages
:
0
,
// 记录已加载的图片数量
formData
:
{
id
:
1
,
unitName
:
'
威海火炬高技术产业开发区沸腾小火锅店
'
,
businessAddress
:
'
268-7-D2-4
'
,
smallPlaceTypeId
:
2
,
useNature
:
'
餐饮店
'
,
unifiedSocialCreditCode
:
'
92371000MA3U6FCR02
'
,
area
:
51.61
,
employeeCount
:
2
,
owner
:
'
朱德艳
'
,
merchantPhone
:
'
13863159973
'
,
id
:
''
,
unitName
:
''
,
businessAddress
:
''
,
smallPlaceTypeId
:
0
,
useNature
:
''
,
unifiedSocialCreditCode
:
''
,
area
:
''
,
employeeCount
:
0
,
owner
:
''
,
merchantPhone
:
''
,
qrCodeUrl
:
''
,
community
:
'
欧乐坊社区
'
,
street
:
'
田和街道
'
,
gridMemberName
:
'
于灏
'
,
gridMemberPhone
:
'
17865160657
'
,
community
:
''
,
street
:
''
,
gridMemberName
:
''
,
gridMemberPhone
:
''
,
createBy
:
''
,
createTime
:
null
,
updateBy
:
''
,
updateTime
:
'
2025-04-02 01:30:33
'
,
updateTime
:
''
,
remark
:
''
,
deptId
:
209
,
deptId
:
''
,
merchantId
:
0
,
smallPlaceType
:
''
,
smallPlaceTypeName
:
'
小餐饮
'
,
smallPlaceTypeName
:
''
,
principal
:
''
,
phone
:
''
,
area
:
''
,
businessHours
:
''
,
type
:
''
,
// 新增类型字段
sjName1
:
'
威海市宝威酒店有限公司
'
,
sjName2
:
'
XXX
'
,
sjName3
:
'
0631-522221212
'
,
sjName4
:
'
威海市XXXXXXXXX
'
,
sjName5
:
'
小餐饮
'
,
},
showTypePicker
:
false
,
typeOptions
:
[
'
小餐饮
'
,
'
酒店
'
,
'
商场
'
,
'
学校
'
,
'
医疗机构
'
],
...
...
@@ -58,7 +171,6 @@ window.addEventListener('load', function () {
},
computed
:
{},
mounted
()
{
this
.
detail
()
},
methods
:
{
...
...
@@ -100,7 +212,9 @@ window.addEventListener('load', function () {
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 () {
this
.
showTypePicker
=
false
},
generateQRCode
(
QR_IMAGE_URL
)
{
this
.
canvasReady
=
false
// 加载二维码图片
const
img
=
new
Image
()
img
.
crossOrigin
=
'
Anonymous
'
// 处理跨域问题
img
.
src
=
'
../image/code/erweimabg.png
'
// QR_IMAGE_URL;
//
generateQRCode(QR_IMAGE_URL) {
//
this.canvasReady = false
//
// 加载二维码图片
//
const img = new Image()
//
img.crossOrigin = 'Anonymous' // 处理跨域问题
//
img.src = '../image/code/erweimabg.png' // QR_IMAGE_URL;
const
img4erweima
=
new
Image
()
img4erweima
.
crossOrigin
=
'
Anonymous
'
// 处理跨域问题
img4erweima
.
src
=
QR_IMAGE_URL
// QR_IMAGE_URL;
//
const img4erweima = new Image()
//
img4erweima.crossOrigin = 'Anonymous' // 处理跨域问题
//
img4erweima.src = QR_IMAGE_URL // QR_IMAGE_URL;
img
.
onload
=
()
=>
{
this
.
loadedImages
++
this
.
drawImages
(
img
,
img4erweima
)
}
//
img.onload = () => {
//
this.loadedImages++
//
this.drawImages(img, img4erweima)
//
}
img4erweima
.
onload
=
()
=>
{
this
.
loadedImages
++
this
.
drawImages
(
img
,
img4erweima
)
}
},
drawImages
(
img
,
img4erweima
)
{
if
(
this
.
loadedImages
===
2
)
{
// 画布的宽度和高度
const
canvasWidth
=
canvas
.
width
const
canvasHeight
=
canvas
.
height
//
img4erweima.onload = () => {
//
this.loadedImages++
//
this.drawImages(img, img4erweima)
//
}
//
},
//
drawImages(img, img4erweima) {
//
if (this.loadedImages === 2) {
//
// 画布的宽度和高度
//
const canvasWidth = canvas.width
//
const canvasHeight = canvas.height
// 图片的原始宽度和高度
const
imgWidth
=
img
.
width
const
imgHeight
=
img
.
height
//
// 图片的原始宽度和高度
//
const imgWidth = img.width
//
const imgHeight = img.height
// 计算宽度和高度的缩放比例
const
scaleX
=
canvasWidth
/
imgWidth
const
scaleY
=
canvasHeight
/
imgHeight
//
// 计算宽度和高度的缩放比例
//
const scaleX = canvasWidth / imgWidth
//
const scaleY = canvasHeight / imgHeight
// 取较小的缩放比例作为最终的缩放比例
const
scale
=
Math
.
min
(
scaleX
,
scaleY
)
//
// 取较小的缩放比例作为最终的缩放比例
//
const scale = Math.min(scaleX, scaleY)
// 计算缩放后的图片宽度和高度
const
scaledWidth
=
imgWidth
*
scale
const
scaledHeight
=
imgHeight
*
scale
//
// 计算缩放后的图片宽度和高度
//
const scaledWidth = imgWidth * scale
//
const scaledHeight = imgHeight * scale
// 计算图片在画布上的绘制位置,使其居中显示
const
x
=
(
canvasWidth
-
scaledWidth
)
/
2
const
y
=
(
canvasHeight
-
scaledHeight
)
/
2
//
// 计算图片在画布上的绘制位置,使其居中显示
//
const x = (canvasWidth - scaledWidth) / 2
//
const y = (canvasHeight - scaledHeight) / 2
// 绘制图片到 canvas 上
ctx
.
drawImage
(
img
,
x
,
y
,
scaledWidth
,
scaledHeight
)
//
// 绘制图片到 canvas 上
//
ctx.drawImage(img, x, y, scaledWidth, scaledHeight)
// 绘制前景图标
const
fgIconSize
=
180
// 假设前景图标显示的尺寸
const
fgX
=
(
canvasWidth
-
fgIconSize
)
/
2
const
fgY
=
((
canvasHeight
-
fgIconSize
)
/
2
)
+
15
//
// 绘制前景图标
//
const fgIconSize = 180 // 假设前景图标显示的尺寸
//
const fgX = (canvasWidth - fgIconSize) / 2
//
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
()
{
if
(
!
VUE
.
canvasReady
)
return
vant
.
Toast
.
loading
({
message
:
'
图片保存中...
'
,
forbidClick
:
true
,
loadingType
:
'
spinner
'
,
});
// function saveCanvas() {
// if (!VUE.canvasReady) return
// vant.Toast.loading({
// message: '图片保存中...',
// forbidClick: true,
// 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
:
'
保存失败
'
,
})
},
})
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment