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
9ecf8548
Commit
9ecf8548
authored
Apr 18, 2025
by
xinzhedeai
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
商户信息详情二维码-无poster
parent
63602ba3
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
57 additions
and
266 deletions
+57
-266
_shanghu_detail.html
src/_shanghu_detail.html
+28
-41
_shanghu_detail.js
src/_shanghu_detail.js
+29
-225
No files found.
src/_shanghu_detail.html
View file @
9ecf8548
...
@@ -9,25 +9,25 @@
...
@@ -9,25 +9,25 @@
<script
type=
"text/javascript"
src=
"../sdk/includeHead.js"
></script>
<script
type=
"text/javascript"
src=
"../sdk/includeHead.js"
></script>
</head>
</head>
<div
id=
"app"
>
<div
id=
"app"
>
<div
class=
"wrapper"
v-cloak
>
<div
class=
"wrapper"
v-cloak
>
<!-- 表单内容 -->
<!-- 表单内容 -->
<van-cell-group
inset
>
<van-cell-group
inset
>
<van-cell-group>
<van-cell-group>
<van-field
label=
"商家名称"
v-model=
"formData.unitName"
:disabled=
"flag=='XQ'"
/>
<van-field
label=
"商家名称"
v-model=
"formData.unitName"
:disabled=
"flag=='XQ'"
/>
</van-cell-group>
</van-cell-group>
<van-cell-group>
<van-cell-group>
<van-field
label=
"负责人"
v-model=
"formData.owner"
type=
"tel"
:disabled=
"flag=='XQ'"
/>
<van-field
label=
"负责人"
v-model=
"formData.owner"
type=
"tel"
:disabled=
"flag=='XQ'"
/>
</van-cell-group>
</van-cell-group>
<van-cell-group>
<van-cell-group>
<van-field
label=
"电话"
v-model=
"formData.merchantPhone"
type=
"number"
:disabled=
"flag=='XQ'"
/>
<van-field
label=
"电话"
v-model=
"formData.merchantPhone"
type=
"number"
:disabled=
"flag=='XQ'"
/>
</van-cell-group>
</van-cell-group>
<van-cell-group>
<van-cell-group>
<van-field
label=
"地址"
v-model=
"formData.businessAddress"
:disabled=
"flag=='XQ'"
/>
<van-field
label=
"地址"
v-model=
"formData.businessAddress"
:disabled=
"flag=='XQ'"
/>
</van-cell-group>
</van-cell-group>
<van-cell-group>
<van-cell-group>
<van-field
label=
"场所类型"
v-model=
"formData.smallPlaceTypeName"
:disabled=
"flag=='XQ'"
/>
<van-field
label=
"场所类型"
v-model=
"formData.smallPlaceTypeName"
:disabled=
"flag=='XQ'"
/>
</van-cell-group>
</van-cell-group>
<!-- <van-cell-group>
<!-- <van-cell-group>
<van-field label="场所类型" v-model="formData.type" placeholder="请选择场所类型" readonly clickable
<van-field label="场所类型" v-model="formData.type" placeholder="请选择场所类型" readonly clickable
@click="showTypePicker = true" />
@click="showTypePicker = true" />
</van-cell-group>
</van-cell-group>
...
@@ -37,28 +37,15 @@
...
@@ -37,28 +37,15 @@
@cancel="showTypePicker = false" />
@cancel="showTypePicker = false" />
</van-popup>
</van-popup>
-->
-->
<van-cell-group>
<van-cell-group>
<van-field
label=
"安全二维码"
:disabled=
"true"
/>
<van-field
label=
"安全二维码"
:disabled=
"true"
/>
</van-cell-group>
</van-cell-group>
</van-cell-group>
</van-cell-group>
</div>
</div>
<img
:src=
"formData.qrCodeUrl"
style=
"margin-left: 50%; transform: translateX(-50%);"
/>
<div
class=
"container"
>
<button
class=
"save-btn"
style=
"margin-left: 50%; transform: translateX(-50%);"
onclick=
"saveCanvas()"
v-if=
"formData.qrCodeUrl"
>
保存二维码
</button>
<div
class=
"qr-card"
>
</div>
<!-- <canvas id="mainCanvas" width="3000" height="4000"></canvas> -->
</div>
<!-- 基础调试确认版 -->
<!-- <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=
"saveImage()"
:class=
"{'showEle': true}"
>
保存二维码
</button>
</div>
</body>
</body>
</html>
</html>
\ No newline at end of file
src/_shanghu_detail.js
View file @
9ecf8548
var
VUE
=
null
var
VUE
=
null
window
.
addEventListener
(
'
load
'
,
function
()
{
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
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实例中添加
VUE
=
new
Vue
({
VUE
=
new
Vue
({
...
@@ -206,119 +81,48 @@ window.addEventListener('load', function () {
...
@@ -206,119 +81,48 @@ window.addEventListener('load', function () {
var
result
=
JSON
.
parse
(
res
)
var
result
=
JSON
.
parse
(
res
)
this
.
formData
=
result
.
data
this
.
formData
=
result
.
data
console
.
log
(
'
查看详情:
'
,
id
)
// this.formData = {} // 表单赋值
// this.formData = {} // 表单赋值
// 这里添加跳转逻辑
// 这里添加跳转逻辑
const
QR_IMAGE_URL
=
result
.
data
.
qrCodeUrl
const
QR_IMAGE_URL
=
result
.
data
.
qrCodeUrl
// ''
this
.
qrCodeUrl
=
result
.
data
.
qrCodeUrl
// this.generateQRCode(QR_IMAGE_URL)
// const qrcodeUrl = ''
drawPoster
(
'
../image/code/erweimabg.png
'
,
QR_IMAGE_URL
);
}
}
})
})
},
},
// 新增选择确认方法
// 新增选择确认方法
onConfirmType
(
value
)
{
// onConfirmType(value) {
this
.
formData
.
type
=
value
// this.formData.type = value
this
.
showTypePicker
=
false
// 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;
// const img4erweima = new Image()
// img4erweima.crossOrigin = 'Anonymous' // 处理跨域问题
// img4erweima.src = QR_IMAGE_URL // QR_IMAGE_URL;
// 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
// // 图片的原始宽度和高度
// const imgWidth = img.width
// const imgHeight = img.height
// // 计算宽度和高度的缩放比例
// const scaleX = canvasWidth / imgWidth
// const scaleY = canvasHeight / imgHeight
// // 取较小的缩放比例作为最终的缩放比例
// const scale = Math.min(scaleX, scaleY)
// // 计算缩放后的图片宽度和高度
// const scaledWidth = imgWidth * scale
// const scaledHeight = imgHeight * scale
// // 计算图片在画布上的绘制位置,使其居中显示
// const x = (canvasWidth - scaledWidth) / 2
// const y = (canvasHeight - scaledHeight) / 2
// // 绘制图片到 canvas 上
// ctx.drawImage(img, x, y, scaledWidth, scaledHeight)
// // 绘制前景图标
// const fgIconSize = 180 // 假设前景图标显示的尺寸
// const fgX = (canvasWidth - fgIconSize) / 2
// const fgY = ((canvasHeight - fgIconSize) / 2 ) + 15
// // 绘制二维码
// ctx.drawImage(img4erweima, fgX, fgY, fgIconSize, fgIconSize)
// this.canvasReady = true
// }
// },
// },
},
},
})
})
})
})
// function saveCanvas() {
function
saveCanvas
()
{
// if (!VUE.canvasReady) return
vant
.
Toast
.
loading
({
// vant.Toast.loading({
message
:
'
图片保存中...
'
,
// message: '图片保存中...',
forbidClick
:
true
,
// forbidClick: true,
loadingType
:
'
spinner
'
,
// loadingType: 'spinner',
});
// });
lightAppJssdk
.
media
.
savePhoto
({
// const canvas = document.getElementById('mainCanvas')
arg
:
VUE
.
formData
.
qrCodeUrl
,
// const dataURL = canvas.toDataURL('image/png')
success
:
function
(
data
)
{
// console.log(dataURL, '图片下载')
// vant.Toast.clear()
// alert(JSON.stringify(data))
// lightAppJssdk.media.savePhoto({
vant
.
Dialog
.
alert
({
// arg: dataURL,
message
:
'
保存成功
'
,
// success: function (data) {
})
// // vant.Toast.clear()
},
// // alert(JSON.stringify(data))
fail
:
function
(
data
)
{
// vant.Dialog.alert({
// vant.Toast.clear()
// message: '保存成功',
// alert('保存失败')
// })
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