Merge branch 'dev' of 47.94.45.65:angelo/web-zk-h5 into test
This commit is contained in:
commit
aef797ebf9
|
@ -3,38 +3,40 @@
|
||||||
<!-- 背景图片,替代CSS background -->
|
<!-- 背景图片,替代CSS background -->
|
||||||
<img
|
<img
|
||||||
class="share-bg-image"
|
class="share-bg-image"
|
||||||
src="/static/images/share-bg.jpg"
|
src="@/static/images/share-bg.jpg"
|
||||||
crossorigin="anonymous"
|
crossorigin="anonymous"
|
||||||
@load="onBackgroundImageLoad"
|
@load="onBackgroundImageLoad"
|
||||||
@error="onBackgroundImageError"
|
@error="onBackgroundImageError"
|
||||||
/>
|
/>
|
||||||
|
<view class="qr-code-outer">
|
||||||
<view class="share-wrapper">
|
<image
|
||||||
<view class="portal-frame" :class="{ 'is-loaded': isLoaded }">
|
class="qr-code"
|
||||||
<!-- 二维码样式区域 - 用户自定义样式位置 -->
|
:src="qrCodeImage"
|
||||||
<view class="qr-code-outer">
|
mode="aspectFit"
|
||||||
<image
|
v-if="qrCodeImage"
|
||||||
class="qr-code"
|
></image>
|
||||||
:src="qrCodeImage"
|
<view v-else class="qr-code-placeholder">
|
||||||
mode="aspectFit"
|
<view class="loader"></view>
|
||||||
v-if="qrCodeImage"
|
|
||||||
></image>
|
|
||||||
<view v-else class="qr-code-placeholder">
|
|
||||||
<view class="loader"></view>
|
|
||||||
</view>
|
|
||||||
</view>
|
|
||||||
|
|
||||||
<!-- 会员编号样式区域 - 用户自定义样式位置 -->
|
|
||||||
<text class="member-code-text">{{
|
|
||||||
desensitization(userInfo.memberCode)
|
|
||||||
}}</text>
|
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
|
<view class="member-code-outer">
|
||||||
|
<text
|
||||||
|
class="member-code-text"
|
||||||
|
style="
|
||||||
|
font-size: 20rpx;
|
||||||
|
color: #fff;
|
||||||
|
font-weight: bold;
|
||||||
|
margin-top: 20rpx;
|
||||||
|
"
|
||||||
|
>{{ desensitization(userInfo.memberCode) }}</text
|
||||||
|
>
|
||||||
|
</view>
|
||||||
</view>
|
</view>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
import html2canvas from 'html2canvas'
|
import html2canvas from 'html2canvas'
|
||||||
|
import { snapdom } from '@zumer/snapdom'
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
name: 'DefaultSharePage',
|
name: 'DefaultSharePage',
|
||||||
|
@ -91,7 +93,7 @@ export default {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
uni.showLoading({ title: '加载中...', mask: true })
|
uni.showLoading({ title: '加载中...' })
|
||||||
|
|
||||||
try {
|
try {
|
||||||
this.shareButtonShow = false
|
this.shareButtonShow = false
|
||||||
|
@ -128,30 +130,23 @@ export default {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
console.log(
|
const scale = 3
|
||||||
'开始html2canvas截取,容器尺寸:',
|
|
||||||
element.offsetWidth,
|
|
||||||
'x',
|
|
||||||
element.offsetHeight
|
|
||||||
)
|
|
||||||
|
|
||||||
html2canvas(element, {
|
html2canvas(element, {
|
||||||
useCORS: true,
|
useCORS: true,
|
||||||
allowTaint: true,
|
// allowTaint: true,
|
||||||
backgroundColor: null,
|
backgroundColor: null,
|
||||||
scale: 2,
|
scale,
|
||||||
dpi: 400,
|
// canvas,
|
||||||
logging: true,
|
|
||||||
width: element.offsetWidth,
|
width: element.offsetWidth,
|
||||||
height: element.offsetHeight,
|
height: element.offsetHeight,
|
||||||
windowWidth: element.offsetWidth,
|
|
||||||
windowHeight: element.offsetHeight,
|
|
||||||
scrollX: 0,
|
|
||||||
scrollY: 0,
|
|
||||||
x: 0,
|
|
||||||
y: 0,
|
|
||||||
})
|
})
|
||||||
.then(canvas => {
|
.then(canvas => {
|
||||||
|
const context = canvas.getContext('2d')
|
||||||
|
// context.scale(2, 2)
|
||||||
|
context.mozImageSmoothingEnabled = false
|
||||||
|
context.webkitImageSmoothingEnabled = false
|
||||||
|
context.msImageSmoothingEnabled = false
|
||||||
|
context.imageSmoothingEnabled = false
|
||||||
const dataUrl = canvas.toDataURL('image/jpeg', 1)
|
const dataUrl = canvas.toDataURL('image/jpeg', 1)
|
||||||
this.$emit('share-generated', dataUrl)
|
this.$emit('share-generated', dataUrl)
|
||||||
resolve()
|
resolve()
|
||||||
|
@ -175,7 +170,8 @@ export default {
|
||||||
.default-share-page {
|
.default-share-page {
|
||||||
position: relative;
|
position: relative;
|
||||||
width: 600rpx;
|
width: 600rpx;
|
||||||
height: 1298rpx;
|
height: 1296rpx;
|
||||||
|
// height: 100%;
|
||||||
display: flex;
|
display: flex;
|
||||||
flex-direction: column;
|
flex-direction: column;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
|
@ -187,23 +183,23 @@ export default {
|
||||||
top: 0;
|
top: 0;
|
||||||
left: 0;
|
left: 0;
|
||||||
width: 600rpx;
|
width: 600rpx;
|
||||||
height: 1298rpx;
|
height: 1296rpx;
|
||||||
|
// height: 100%;
|
||||||
z-index: 1;
|
z-index: 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
.share-wrapper {
|
.share-wrapper {
|
||||||
position: absolute;
|
position: absolute;
|
||||||
z-index: 2;
|
z-index: 2;
|
||||||
top: 320rpx;
|
bottom: 22%;
|
||||||
left: 150rpx;
|
|
||||||
display: flex;
|
display: flex;
|
||||||
flex-direction: column;
|
flex-direction: column;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
}
|
}
|
||||||
|
|
||||||
.portal-frame {
|
.portal-frame {
|
||||||
// padding: 32rpx;
|
padding: 32rpx;
|
||||||
width: 300rpx;
|
width: 520rpx;
|
||||||
border-radius: 40rpx;
|
border-radius: 40rpx;
|
||||||
display: flex;
|
display: flex;
|
||||||
box-sizing: border-box;
|
box-sizing: border-box;
|
||||||
|
@ -222,17 +218,24 @@ export default {
|
||||||
|
|
||||||
/* 二维码样式区域 - 用户自定义样式位置 */
|
/* 二维码样式区域 - 用户自定义样式位置 */
|
||||||
.qr-code-outer {
|
.qr-code-outer {
|
||||||
width: 240rpx;
|
width: 140rpx;
|
||||||
height: 240rpx;
|
height: 140rpx;
|
||||||
// background: rgba(255, 255, 255, 0.98);
|
background: rgba(255, 255, 255, 0.98);
|
||||||
border-radius: 20rpx;
|
border-radius: 20rpx;
|
||||||
// box-shadow: 0px 8rpx 20rpx rgba(50, 50, 90, 0.06);
|
box-shadow: 0px 8rpx 20rpx rgba(50, 50, 90, 0.06);
|
||||||
// border: 1px solid #990;
|
border: 1px solid #f0f0f0;
|
||||||
display: flex;
|
display: flex;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
justify-content: center;
|
justify-content: center;
|
||||||
padding: 12rpx;
|
padding: 12rpx;
|
||||||
box-sizing: border-box;
|
box-sizing: border-box;
|
||||||
|
position: absolute;
|
||||||
|
// bottom: 460rpx;
|
||||||
|
left: 374rpx;
|
||||||
|
top: 708rpx;
|
||||||
|
// right: 130rpx;
|
||||||
|
|
||||||
|
z-index: 10;
|
||||||
}
|
}
|
||||||
|
|
||||||
.qr-code,
|
.qr-code,
|
||||||
|
@ -268,9 +271,47 @@ export default {
|
||||||
|
|
||||||
/* 会员编号样式区域 - 用户自定义样式位置 */
|
/* 会员编号样式区域 - 用户自定义样式位置 */
|
||||||
.member-code-text {
|
.member-code-text {
|
||||||
font-size: 24rpx;
|
/* 用户可以在这里自定义会员编号的样式 */
|
||||||
color: #005bac;
|
}
|
||||||
font-weight: bold;
|
.member-code-outer {
|
||||||
margin-top: 10rpx;
|
position: absolute;
|
||||||
|
top: 1086rpx;
|
||||||
|
left: 246rpx;
|
||||||
|
// width: 300rpx;
|
||||||
|
text-align: center;
|
||||||
|
// background: rgb(217, 24, 25);
|
||||||
|
border-radius: 20rpx;
|
||||||
|
z-index: 10;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* 下载按钮样式 */
|
||||||
|
.share-button {
|
||||||
|
margin-top: 28rpx;
|
||||||
|
width: 280rpx;
|
||||||
|
height: 72rpx;
|
||||||
|
line-height: 72rpx;
|
||||||
|
color: #fff;
|
||||||
|
border-radius: 36rpx;
|
||||||
|
font-size: 26rpx;
|
||||||
|
font-weight: 500;
|
||||||
|
background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
|
||||||
|
box-shadow: 0 5rpx 12rpx 0 rgba(102, 126, 234, 0.2);
|
||||||
|
border: none;
|
||||||
|
padding: 0;
|
||||||
|
text-align: center;
|
||||||
|
transition: all 0.3s ease;
|
||||||
|
letter-spacing: 1rpx;
|
||||||
|
}
|
||||||
|
|
||||||
|
button.share-button {
|
||||||
|
padding: 0;
|
||||||
|
line-height: 72rpx;
|
||||||
|
border: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.share-button:active {
|
||||||
|
transform: translateY(1rpx);
|
||||||
|
box-shadow: 0 4rpx 10rpx rgba(102, 126, 234, 0.4);
|
||||||
|
background: linear-gradient(135deg, #5a67d8 0%, #6b46c1 100%);
|
||||||
}
|
}
|
||||||
</style>
|
</style>
|
||||||
|
|
Binary file not shown.
Before Width: | Height: | Size: 518 KiB After Width: | Height: | Size: 1.7 MiB |
Loading…
Reference in New Issue