Compare commits
6 Commits
9e24edad28
...
8f50f42f8c
Author | SHA1 | Date |
---|---|---|
zcx | 8f50f42f8c | 10 months ago |
zcx | 65149c38cd | 10 months ago |
zcx | c26e306b3a | 10 months ago |
qiushanhe | 6141270437 | 10 months ago |
qsh | 074b53f307 | 10 months ago |
qsh | ab05529015 | 10 months ago |
@ -1,266 +1,280 @@ |
|||||||
<template> |
<template> |
||||||
<view class="scraping-happy" id="container"> |
<view class="scraping-happy" id="container"> |
||||||
<canvas |
<canvas canvas-id="scraping-happy" class="scraping__canvas" :disable-scroll="true" @touchstart="touchstart" |
||||||
canvas-id="scraping-happy" |
@touchmove="touchmove" @touchend="touchend" /> |
||||||
class="scraping__canvas" |
|
||||||
:disable-scroll="true" |
|
||||||
@touchstart="touchstart" |
|
||||||
@touchmove="touchmove" |
|
||||||
@touchend="touchend" |
|
||||||
/> |
|
||||||
<cover-view class="scraping__view"> |
<cover-view class="scraping__view"> |
||||||
{{ showText }} |
{{ showText }} |
||||||
</cover-view> |
</cover-view> |
||||||
|
<slot></slot> |
||||||
</view> |
</view> |
||||||
</template> |
</template> |
||||||
|
|
||||||
<script> |
<script> |
||||||
/** @name 水印配置默认值 **/ |
/** @name 水印配置默认值 **/ |
||||||
const WATERMARK = { |
const WATERMARK = { |
||||||
text: '刮一刮', |
text: '刮一刮', |
||||||
fontSize: 14, |
fontSize: 14, |
||||||
color: '#C5C5C5', |
color: '#C5C5C5', |
||||||
} |
} |
||||||
/** @name 标题配置默认值 **/ |
/** @name 标题配置默认值 **/ |
||||||
const TITLE = { |
const TITLE = { |
||||||
text: '刮一刮', |
text: '刮一刮', |
||||||
fontSize: 16, |
fontSize: 16, |
||||||
color: '#333', |
color: '#333', |
||||||
} |
} |
||||||
/** |
/** |
||||||
* @name 涂层配置默认值 |
* @name 涂层配置默认值 |
||||||
* @property { string } color 涂层颜色 |
* @property { string } color 涂层颜色 |
||||||
* @property { number } drawSize 清除涂层的画笔大小 |
* @property { number } drawSize 清除涂层的画笔大小 |
||||||
*/ |
*/ |
||||||
const MASK = { |
const MASK = { |
||||||
color: '#DDDDDD', |
color: '#DDDDDD', |
||||||
drawSize: 20, |
drawSize: 20, |
||||||
} |
} |
||||||
/** @name 容错值,解决部分机型涂层没有覆盖满的情况,主要原因是由于像素尺寸不同导致的,应尽可能让width与height保持整数 **/ |
/** @name 容错值,解决部分机型涂层没有覆盖满的情况,主要原因是由于像素尺寸不同导致的,应尽可能让width与height保持整数 **/ |
||||||
const TOLERANT = 3; |
const TOLERANT = 3; |
||||||
|
|
||||||
let ctx = null; |
let ctx = null; |
||||||
|
|
||||||
export default { |
export default { |
||||||
props: { |
props: { |
||||||
/** @name 涂层设置 **/ |
/** @name 涂层设置 **/ |
||||||
mask: { |
mask: { |
||||||
type: [String, Object], |
type: [String, Object], |
||||||
}, |
}, |
||||||
/** @name 水印设置 **/ |
/** @name 水印设置 **/ |
||||||
watermark: { |
watermark: { |
||||||
type: [String, Object], |
type: [String, Object], |
||||||
}, |
}, |
||||||
/** @name 提示文字 **/ |
/** @name 提示文字 **/ |
||||||
title: { |
title: { |
||||||
type: [String, Object], |
type: [String, Object], |
||||||
}, |
}, |
||||||
/** @name 刮开百分之多少直接消除图层,为0的时候不消除 **/ |
/** @name 刮开百分之多少直接消除图层,为0的时候不消除 **/ |
||||||
percentage: { |
percentage: { |
||||||
type: Number, |
type: Number, |
||||||
default: 60, |
default: 40, |
||||||
}, |
}, |
||||||
result: { |
result: { |
||||||
type: String, |
type: String, |
||||||
default: '' |
default: '' |
||||||
} |
|
||||||
}, |
|
||||||
data() { |
|
||||||
return { |
|
||||||
width: 0, |
|
||||||
height: 0, |
|
||||||
touchX: 0, |
|
||||||
touchY: 0, |
|
||||||
showText: '' |
|
||||||
} |
|
||||||
}, |
|
||||||
computed: { |
|
||||||
maskSetting() { |
|
||||||
return { |
|
||||||
...MASK, |
|
||||||
...(typeof this.mask === 'object' ? this.mask : { text: this.mask }), |
|
||||||
} |
} |
||||||
}, |
}, |
||||||
watermarkSetting() { |
data() { |
||||||
return { |
return { |
||||||
...WATERMARK, |
width: 0, |
||||||
...(typeof this.watermark === 'object' ? this.watermark : { text: this.watermark }), |
height: 0, |
||||||
}; |
touchX: 0, |
||||||
}, |
touchY: 0, |
||||||
titleSetting() { |
showText: '' |
||||||
return { |
} |
||||||
...TITLE, |
|
||||||
...(typeof this.title === 'object' ? this.title : { text: this.title }), |
|
||||||
}; |
|
||||||
} |
|
||||||
}, |
|
||||||
mounted() { |
|
||||||
// 获取画布实例 |
|
||||||
ctx = uni.createCanvasContext('scraping-happy', this); |
|
||||||
this.init(); |
|
||||||
}, |
|
||||||
methods: { |
|
||||||
/** @name 初始化 **/ |
|
||||||
init() { |
|
||||||
const query = uni.createSelectorQuery().in(this); |
|
||||||
query |
|
||||||
.select('#container') |
|
||||||
.boundingClientRect(({ width, height }) => { |
|
||||||
this.width = width; |
|
||||||
this.height = height; |
|
||||||
setTimeout(() => { |
|
||||||
this.initCanvas(); |
|
||||||
this.showText = this.result |
|
||||||
}, 20) |
|
||||||
}) |
|
||||||
.exec(); |
|
||||||
}, |
|
||||||
/** @name 初始化canvas状态 **/ |
|
||||||
initCanvas() { |
|
||||||
const { width, height } = this; |
|
||||||
// 清空矩形内容 |
|
||||||
ctx.clearRect(0, 0, width, height); |
|
||||||
// 设置画笔颜色 |
|
||||||
ctx.setFillStyle(this.maskSetting.color); |
|
||||||
// 绘制矩形 |
|
||||||
ctx.fillRect(0, 0, width, height + TOLERANT); |
|
||||||
// 绘制水印 |
|
||||||
this.drawWatermark(); |
|
||||||
// 绘制提示文字 |
|
||||||
this.drawTitle(); |
|
||||||
// 绘制到canvas身上 |
|
||||||
ctx.draw(); |
|
||||||
}, |
}, |
||||||
/** @name 绘制水印 **/ |
computed: { |
||||||
drawWatermark() { |
maskSetting() { |
||||||
if (!this.watermarkSetting.text) return; |
return { |
||||||
// 保存当前的绘图上下文 |
...MASK, |
||||||
ctx.save(); |
...(typeof this.mask === 'object' ? this.mask : { |
||||||
// 旋转 |
text: this.mask |
||||||
ctx.rotate((-10 * Math.PI) / 180); |
}), |
||||||
// 水印具体绘制过程 |
|
||||||
const { width, height } = this; |
|
||||||
const watermarkWidth = this.watermarkSetting.text.length * this.watermarkSetting.fontSize; |
|
||||||
let x = 0; |
|
||||||
let y = 0; |
|
||||||
let i = 0; |
|
||||||
while ((x <= width * 5 || y <= height * 5) && i < 300) { |
|
||||||
ctx.setFillStyle(this.watermarkSetting.color); |
|
||||||
ctx.setFontSize(this.watermarkSetting.fontSize); |
|
||||||
ctx.fillText(this.watermarkSetting.text, x, y); |
|
||||||
x += watermarkWidth + watermarkWidth * 1.6; |
|
||||||
if (x > width && y <= height) { |
|
||||||
x = -Math.random() * 100; |
|
||||||
y += this.watermarkSetting.fontSize * 3; |
|
||||||
} |
} |
||||||
i++; |
}, |
||||||
|
watermarkSetting() { |
||||||
|
return { |
||||||
|
...WATERMARK, |
||||||
|
...(typeof this.watermark === 'object' ? this.watermark : { |
||||||
|
text: this.watermark |
||||||
|
}), |
||||||
|
}; |
||||||
|
}, |
||||||
|
titleSetting() { |
||||||
|
return { |
||||||
|
...TITLE, |
||||||
|
...(typeof this.title === 'object' ? this.title : { |
||||||
|
text: this.title |
||||||
|
}), |
||||||
|
}; |
||||||
} |
} |
||||||
ctx.restore(); |
|
||||||
}, |
|
||||||
/** @name 绘制提示文字 **/ |
|
||||||
drawTitle() { |
|
||||||
if (!this.titleSetting.text) return; |
|
||||||
ctx.setTextAlign('center'); |
|
||||||
ctx.setTextBaseline('middle'); |
|
||||||
ctx.setFillStyle(this.titleSetting.color); |
|
||||||
ctx.setFontSize(this.titleSetting.fontSize); |
|
||||||
ctx.fillText(this.titleSetting.text, this.width / 2, this.height / 3); |
|
||||||
}, |
}, |
||||||
/** @name 触摸事件 **/ |
mounted() { |
||||||
touchstart(e) { |
// 获取画布实例 |
||||||
this.touchX = e.touches[0].x; |
ctx = uni.createCanvasContext('scraping-happy', this); |
||||||
this.touchY = e.touches[0].y; |
this.init(); |
||||||
}, |
}, |
||||||
async touchmove(e) { |
methods: { |
||||||
// 把画笔到画布中的指定点 |
/** @name 初始化 **/ |
||||||
ctx.moveTo(this.touchX, this.touchY); |
init() { |
||||||
// 清除涂层 |
const query = uni.createSelectorQuery().in(this); |
||||||
ctx.clearRect(this.touchX, this.touchY, this.maskSetting.drawSize, this.maskSetting.drawSize); |
query |
||||||
ctx.draw(true); |
.select('#container') |
||||||
// 记录移动点位 |
.boundingClientRect(({ |
||||||
this.touchX = e.touches[0].x; |
width, |
||||||
this.touchY = e.touches[0].y; |
height |
||||||
|
}) => { |
||||||
|
this.width = width; |
||||||
|
this.height = height; |
||||||
|
setTimeout(() => { |
||||||
|
this.initCanvas(); |
||||||
|
this.showText = this.result |
||||||
|
}, 20) |
||||||
|
}) |
||||||
|
.exec(); |
||||||
|
}, |
||||||
|
/** @name 初始化canvas状态 **/ |
||||||
|
initCanvas() { |
||||||
|
const { |
||||||
|
width, |
||||||
|
height |
||||||
|
} = this; |
||||||
|
// 清空矩形内容 |
||||||
|
ctx.clearRect(0, 0, width, height); |
||||||
|
// 设置画笔颜色 |
||||||
|
ctx.setFillStyle(this.maskSetting.color); |
||||||
|
// 绘制矩形 |
||||||
|
ctx.fillRect(0, 0, width, height + TOLERANT); |
||||||
|
// 绘制水印 |
||||||
|
this.drawWatermark(); |
||||||
|
// 绘制提示文字 |
||||||
|
this.drawTitle(); |
||||||
|
// 绘制到canvas身上 |
||||||
|
ctx.draw(); |
||||||
|
}, |
||||||
|
/** @name 绘制水印 **/ |
||||||
|
drawWatermark() { |
||||||
|
if (!this.watermarkSetting.text) return; |
||||||
|
// 保存当前的绘图上下文 |
||||||
|
ctx.save(); |
||||||
|
// 旋转 |
||||||
|
ctx.rotate((-10 * Math.PI) / 180); |
||||||
|
// 水印具体绘制过程 |
||||||
|
const { |
||||||
|
width, |
||||||
|
height |
||||||
|
} = this; |
||||||
|
const watermarkWidth = this.watermarkSetting.text.length * this.watermarkSetting.fontSize; |
||||||
|
let x = 0; |
||||||
|
let y = 0; |
||||||
|
let i = 0; |
||||||
|
while ((x <= width * 5 || y <= height * 5) && i < 300) { |
||||||
|
ctx.setFillStyle(this.watermarkSetting.color); |
||||||
|
ctx.setFontSize(this.watermarkSetting.fontSize); |
||||||
|
ctx.fillText(this.watermarkSetting.text, x, y); |
||||||
|
x += watermarkWidth + watermarkWidth * 1.6; |
||||||
|
if (x > width && y <= height) { |
||||||
|
x = -Math.random() * 100; |
||||||
|
y += this.watermarkSetting.fontSize * 3; |
||||||
|
} |
||||||
|
i++; |
||||||
|
} |
||||||
|
ctx.restore(); |
||||||
|
}, |
||||||
|
/** @name 绘制提示文字 **/ |
||||||
|
drawTitle() { |
||||||
|
if (!this.titleSetting.text) return; |
||||||
|
ctx.setTextAlign('center'); |
||||||
|
ctx.setTextBaseline('middle'); |
||||||
|
ctx.setFillStyle(this.titleSetting.color); |
||||||
|
ctx.setFontSize(this.titleSetting.fontSize); |
||||||
|
ctx.fillText(this.titleSetting.text, this.width / 2, this.height / 3); |
||||||
|
}, |
||||||
|
/** @name 触摸事件 **/ |
||||||
|
touchstart(e) { |
||||||
|
this.touchX = e.touches[0].x; |
||||||
|
this.touchY = e.touches[0].y; |
||||||
|
}, |
||||||
|
async touchmove(e) { |
||||||
|
// 把画笔到画布中的指定点 |
||||||
|
ctx.moveTo(this.touchX, this.touchY); |
||||||
|
// 清除涂层 |
||||||
|
ctx.clearRect(this.touchX, this.touchY, this.maskSetting.drawSize, this.maskSetting.drawSize); |
||||||
|
ctx.draw(true); |
||||||
|
// 记录移动点位 |
||||||
|
this.touchX = e.touches[0].x; |
||||||
|
this.touchY = e.touches[0].y; |
||||||
|
|
||||||
// if (this.percentage > 0) { |
// if (this.percentage > 0) { |
||||||
// const clearPercent = await this.getClearMaskPercent(); |
// const clearPercent = await this.getClearMaskPercent(); |
||||||
// } |
// } |
||||||
}, |
}, |
||||||
async touchend() { |
async touchend() { |
||||||
if (this.percentage > 0) { |
if (this.percentage > 0) { |
||||||
const clearPercent = await this.getClearMaskPercent(); |
const clearPercent = await this.getClearMaskPercent(); |
||||||
if (clearPercent >= this.percentage) { |
if (clearPercent >= this.percentage) { |
||||||
ctx.moveTo(0, 0); |
ctx.moveTo(0, 0); |
||||||
ctx.clearRect(0, 0, this.width, this.height); |
ctx.clearRect(0, 0, this.width, this.height); |
||||||
ctx.stroke(); |
ctx.stroke(); |
||||||
ctx.draw(true); |
ctx.draw(true); |
||||||
|
this.$emit('complete') |
||||||
|
} |
||||||
} |
} |
||||||
} |
}, |
||||||
}, |
/** @name 计算被清除的涂层百分比 **/ |
||||||
/** @name 计算被清除的涂层百分比 **/ |
getClearMaskPercent() { |
||||||
getClearMaskPercent() { |
return new Promise(resolve => { |
||||||
return new Promise(resolve => { |
uni.canvasGetImageData({ |
||||||
uni.canvasGetImageData({ |
canvasId: 'scraping-happy', |
||||||
canvasId: 'scraping-happy', |
x: 0, |
||||||
x: 0, |
y: 0, |
||||||
y: 0, |
width: this.width, |
||||||
width: this.width, |
height: this.height, |
||||||
height: this.height, |
success: res => { |
||||||
success: res => { |
// 区域内所有点的像素信息,它是一个数组,数组中每 "4" 项表示一个点的 rgba 值 |
||||||
// 区域内所有点的像素信息,它是一个数组,数组中每 "4" 项表示一个点的 rgba 值 |
const allPointPixels = res.data; |
||||||
const allPointPixels = res.data; |
// 储存被清除的点-点的透明度 |
||||||
// 储存被清除的点-点的透明度 |
const clearPoint = []; |
||||||
const clearPoint = []; |
// 取透明度来判断,如果透明度值小于一半,则判断为该点已经被清除 |
||||||
// 取透明度来判断,如果透明度值小于一半,则判断为该点已经被清除 |
for (let i = 0; i < allPointPixels.length; i += 4) { |
||||||
for (let i = 0; i < allPointPixels.length; i += 4) { |
if (allPointPixels[i + 3] < 128) { |
||||||
if (allPointPixels[i + 3] < 128) { |
clearPoint.push(allPointPixels[i + 3]); |
||||||
clearPoint.push(allPointPixels[i + 3]); |
} |
||||||
} |
} |
||||||
} |
// 已被清除的百分比 = 清除的点 / 全部的点 |
||||||
// 已被清除的百分比 = 清除的点 / 全部的点 |
const percent = ( |
||||||
const percent = ( |
(clearPoint.length / (allPointPixels.length / 4)) * |
||||||
(clearPoint.length / (allPointPixels.length / 4)) * |
100 |
||||||
100 |
).toFixed(2); |
||||||
).toFixed(2); |
resolve(percent); |
||||||
resolve(percent); |
}, |
||||||
}, |
fail: e => { |
||||||
fail: e => { |
console.log('canvasGetImageData', e); |
||||||
console.log('canvasGetImageData', e); |
}, |
||||||
}, |
}, this); |
||||||
}, this); |
}); |
||||||
}); |
}, |
||||||
}, |
/** @name 重置 **/ |
||||||
/** @name 重置 **/ |
reset() { |
||||||
reset() { |
this.initCanvas(); |
||||||
this.initCanvas(); |
this.touchX = 0; |
||||||
this.touchX = 0; |
this.touchY = 0; |
||||||
this.touchY = 0; |
} |
||||||
} |
} |
||||||
} |
}; |
||||||
}; |
|
||||||
</script> |
</script> |
||||||
|
|
||||||
<style> |
<style> |
||||||
.scraping-happy { |
.scraping-happy { |
||||||
width: 100%; |
width: 100%; |
||||||
height: 200rpx; |
height: 200rpx; |
||||||
position: relative; |
position: relative; |
||||||
display: flex; |
display: flex; |
||||||
justify-content: center; |
justify-content: center; |
||||||
align-items: center; |
align-items: center; |
||||||
} |
} |
||||||
.scraping__canvas { |
|
||||||
width: 100%; |
.scraping__canvas { |
||||||
height: 100%; |
width: 100%; |
||||||
position: absolute; |
height: 100%; |
||||||
z-index: 10; |
position: absolute; |
||||||
/* background-color: red; */ |
z-index: 10; |
||||||
display: inline-block; |
/* background-color: red; */ |
||||||
} |
display: inline-block; |
||||||
.scraping__view { |
} |
||||||
position: absolute; |
|
||||||
z-index: 1; |
.scraping__view { |
||||||
color: #f29100; |
position: absolute; |
||||||
font-size: 20px; |
z-index: 1; |
||||||
font-weight: bold; |
color: #f29100; |
||||||
} |
font-size: 20px; |
||||||
</style> |
font-weight: bold; |
||||||
|
letter-spacing: 8px; |
||||||
|
} |
||||||
|
</style> |
@ -0,0 +1,305 @@ |
|||||||
|
<template> |
||||||
|
<view style="padding-bottom: 50px;background-color: #C5121B;"> |
||||||
|
<image class="wp100 img" mode="widthFix" src="https://oss-bq.ahduima.com/%E5%B0%8F%E7%A8%8B%E5%BA%8F/%E5%9B%BE%E7%89%87/%E5%8A%A9%E5%8A%9B%E4%B8%BB%E5%9B%BE.jpg"></image> |
||||||
|
<view class="relative tip">邀请好友帮助你进行助力即可有机会领取奖品</view> |
||||||
|
<view class="relative help_div"> |
||||||
|
<!-- --> |
||||||
|
<view v-if="type == 1" class="relative help_card"> |
||||||
|
<view class="relative help_tip"> |
||||||
|
还差{{diffNum}}位好友助力即可领取奖品: |
||||||
|
</view> |
||||||
|
<view v-if="winnerInfo.awards != undefined" class="relative help_tip" style="font-size: 40rpx;"> |
||||||
|
{{winnerInfo.awards}} |
||||||
|
</view> |
||||||
|
<view class="help_list"> |
||||||
|
<view v-for="item in helpUserList" class="help_item"> |
||||||
|
<u-avatar class="help_item_avatar" :src="item.avatarUrl"></u-avatar> |
||||||
|
|
||||||
|
<!-- <view class="help_item_2_yao"> |
||||||
|
<image :src="item.avatarUrl"></image> |
||||||
|
</view> --> |
||||||
|
</view> |
||||||
|
<view v-for="item in diffNum" class="help_item_2"> |
||||||
|
<view class="help_item_2_yao">邀</view> |
||||||
|
</view> |
||||||
|
</view> |
||||||
|
<view class="help_btn" > |
||||||
|
<button open-type="share" class="help_btn_font"> 邀请好友助力</button> |
||||||
|
</view> |
||||||
|
</view> |
||||||
|
|
||||||
|
<view v-if="type == 2" class="relative help_card"> |
||||||
|
<view class="relative help_list" style="top: 200rpx;"> |
||||||
|
<view v-if="winnerInfo.activityName != undefined" class="help_tip" style="font-size: 40rpx; margin: 25rpx 0rpx;"> |
||||||
|
{{winnerInfo.activityName}} |
||||||
|
</view> |
||||||
|
<view v-if="winnerInfo.schoolName != undefined" class="help_tip"> |
||||||
|
举办单位:{{winnerInfo.schoolName}} |
||||||
|
</view> |
||||||
|
<view v-if="winnerInfo.awards != undefined" class="help_tip" style="font-size: 45rpx;margin: 25rpx 0rpx;"> |
||||||
|
奖品:{{winnerInfo.awards}} |
||||||
|
</view> |
||||||
|
</view> |
||||||
|
|
||||||
|
<view class="help_btn" > |
||||||
|
<button class="help_btn_font" open-type="chooseAvatar" @chooseavatar="handleHelp" :disabled="disBtn">帮好友助力</button> |
||||||
|
</view> |
||||||
|
</view> |
||||||
|
</view> |
||||||
|
</view> |
||||||
|
</template> |
||||||
|
|
||||||
|
<script> |
||||||
|
import useUserStore from '@/jtools/store/user' |
||||||
|
import { queryActivityDetail,queryHelpInfo, saveHelpInfo, queryWinnerInfo } from '@/jtools/api/activity' |
||||||
|
export default { |
||||||
|
data() { |
||||||
|
return { |
||||||
|
winnerId: undefined, |
||||||
|
btnText: '点我刮奖', |
||||||
|
showBtn: true, |
||||||
|
helpUserList: [], |
||||||
|
drawNum: 0, |
||||||
|
diffNum: 3, |
||||||
|
phone: undefined, |
||||||
|
type: 2, |
||||||
|
winnerInfo: undefined, |
||||||
|
disBtn: false |
||||||
|
} |
||||||
|
}, |
||||||
|
onLoad(op) { |
||||||
|
|
||||||
|
this.winnerId = op.id |
||||||
|
// this.type = op.type ? Number(op.type) : 1 |
||||||
|
this.phone = useUserStore().userInfo?.phone || undefined |
||||||
|
console.log(this.phone) |
||||||
|
this.getWinnerInfo() |
||||||
|
this.getHelpInfo() |
||||||
|
this.disBtn = false |
||||||
|
|
||||||
|
}, |
||||||
|
onShareAppMessage(res) { |
||||||
|
if (res.from === 'button') {// 来自页面内分享按钮 |
||||||
|
console.log(res.target) |
||||||
|
} |
||||||
|
return { |
||||||
|
title: '我正在参与领奖活动柜,请帮我助力', |
||||||
|
path: '/pages/me/help?id='+this.winnerId + '&type=2' |
||||||
|
} |
||||||
|
}, |
||||||
|
|
||||||
|
methods: { |
||||||
|
//查询中奖信息 |
||||||
|
getWinnerInfo(){ |
||||||
|
// uni.request({ |
||||||
|
// url: 'http://192.168.1.6:8089/applet/activity/winner/info?winnerId='+this.winnerId |
||||||
|
// }).then(resp => { |
||||||
|
// if(resp.data.code == 200) { |
||||||
|
// console.log(resp) |
||||||
|
// this.winnerInfo = resp.data.data; |
||||||
|
// if(this.phone && this.winnerInfo.phone == this.phone){ |
||||||
|
// this.type == 1 |
||||||
|
// } |
||||||
|
// } |
||||||
|
// }) |
||||||
|
queryWinnerInfo({winnerId : this.winnerId}).then(resp => { |
||||||
|
if(resp.code == 200){ |
||||||
|
console.log(resp) |
||||||
|
this.winnerInfo = resp.data; |
||||||
|
if(this.phone && this.winnerInfo.phone == this.phone){ |
||||||
|
this.type = 1 |
||||||
|
} else { |
||||||
|
this.type = 2 |
||||||
|
} |
||||||
|
} |
||||||
|
}) |
||||||
|
|
||||||
|
}, |
||||||
|
//查询助力信息 |
||||||
|
getHelpInfo(){ |
||||||
|
// uni.request({ |
||||||
|
// url: 'http://192.168.1.6:8089/applet/activity/help/info?winnerId='+this.winnerId |
||||||
|
// }).then(resp => { |
||||||
|
// if(resp.data.code == 200) { |
||||||
|
// console.log(resp) |
||||||
|
// this.drawNum = resp.data.data.helpNum; |
||||||
|
// this.helpUserList = resp.data.data.helpUsers |
||||||
|
// this.diffNum = (this.drawNum - this.helpUserList.length) < 0 ? 0 : (this.drawNum - this.helpUserList.length); |
||||||
|
// console.log(this.drawNum) |
||||||
|
// console.log(this.diffNum) |
||||||
|
// } |
||||||
|
// }) |
||||||
|
queryHelpInfo({winnerId : this.winnerId}).then(resp => { |
||||||
|
if(resp.code == 200){ |
||||||
|
console.log(resp) |
||||||
|
this.drawNum = resp.data.helpNum; |
||||||
|
this.helpUserList = resp.data.helpUsers.map(item => ({ |
||||||
|
...item, |
||||||
|
avatarUrl: 'https://jwl.ahduima.com' + item.avatarUrl |
||||||
|
})); |
||||||
|
this.diffNum = (this.drawNum - this.helpUserList.length) < 0 ? 0 : (this.drawNum - this.helpUserList.length); |
||||||
|
} |
||||||
|
}) |
||||||
|
}, |
||||||
|
//点击助力 |
||||||
|
handleHelp(e){ |
||||||
|
this.disBtn = false |
||||||
|
console.log(e) |
||||||
|
uni.login({ |
||||||
|
provider: 'weixin', //使用微信登录 |
||||||
|
success: (loginRes) => { |
||||||
|
console.log(loginRes); |
||||||
|
uni.uploadFile({ |
||||||
|
url: 'https://jwl.ahduima.com/activity/applet/activity/help/save', |
||||||
|
// url: 'http://192.168.1.6:8089/applet/activity/help/save', |
||||||
|
filePath: e.detail.avatarUrl, |
||||||
|
name: 'file', |
||||||
|
formData: { |
||||||
|
'code': loginRes.code, |
||||||
|
'winnerId': this.winnerId, |
||||||
|
}, |
||||||
|
success: (uploadFileRes) => { |
||||||
|
console.log(uploadFileRes.data); |
||||||
|
let resp = JSON.parse(uploadFileRes.data); |
||||||
|
console.log(resp); |
||||||
|
|
||||||
|
if(resp.code == 200){ |
||||||
|
uni.showToast({ |
||||||
|
icon: 'none', |
||||||
|
title: `助力成功` |
||||||
|
}) |
||||||
|
this.disBtn = true |
||||||
|
} else { |
||||||
|
uni.showToast({ |
||||||
|
icon: 'error', |
||||||
|
title: resp.msg |
||||||
|
}) |
||||||
|
this.disBtn = true |
||||||
|
} |
||||||
|
} |
||||||
|
}); |
||||||
|
|
||||||
|
} |
||||||
|
}); |
||||||
|
}, |
||||||
|
|
||||||
|
}, |
||||||
|
} |
||||||
|
</script> |
||||||
|
|
||||||
|
<style scoped lang="scss"> |
||||||
|
.img{ |
||||||
|
top: -130rpx !important; |
||||||
|
} |
||||||
|
.tip { |
||||||
|
height: 75px; |
||||||
|
font-family: PingFang SC; |
||||||
|
font-weight: 400; |
||||||
|
color: #FEFEFE; |
||||||
|
line-height: 48px; |
||||||
|
top: -520rpx; |
||||||
|
text-align: center; |
||||||
|
font-size: 35rpx; |
||||||
|
} |
||||||
|
.help_div{ |
||||||
|
width: 710rpx; |
||||||
|
height: 996rpx; |
||||||
|
top: -560rpx; |
||||||
|
margin-left: 20rpx; |
||||||
|
margin-right: 20rpx; |
||||||
|
background: linear-gradient(0deg, #F33D2F 100%, rgba(197,18,27,0.01) 0%); |
||||||
|
border-radius: 40rpx; |
||||||
|
|
||||||
|
|
||||||
|
.help_card{ |
||||||
|
width: 630rpx; |
||||||
|
height: 886rpx; |
||||||
|
margin: 0rpx 39rpx; |
||||||
|
top: 55rpx; |
||||||
|
background: #FFFFFF; |
||||||
|
border-radius: 24rpx; |
||||||
|
|
||||||
|
.help_tip{ |
||||||
|
text-align: center; |
||||||
|
font-size: 32rpx; |
||||||
|
font-family: PingFang SC; |
||||||
|
font-weight: 400; |
||||||
|
color: #010101; |
||||||
|
line-height: 55rpx; |
||||||
|
top: 15rpx; |
||||||
|
} |
||||||
|
|
||||||
|
.help_list{ |
||||||
|
margin: 68rpx 25rpx 25rpx 20rpx; |
||||||
|
height: 580rpx; |
||||||
|
|
||||||
|
.help_item{ |
||||||
|
display: inline-block; |
||||||
|
padding: 35rpx; |
||||||
|
width: 194rpx; |
||||||
|
height: 194rpx; |
||||||
|
|
||||||
|
border-radius: 50%; |
||||||
|
|
||||||
|
.help_item_avatar{ |
||||||
|
margin: auto; |
||||||
|
width: 56rpx; |
||||||
|
height: 56rpx; |
||||||
|
color: #CCCCCC; |
||||||
|
background: #C42E13; |
||||||
|
border: 4px solid #C42E13; |
||||||
|
|
||||||
|
image{ |
||||||
|
height: 45px; |
||||||
|
width: 45px; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
.help_item_2{ |
||||||
|
display: inline-block; |
||||||
|
margin: 35rpx; |
||||||
|
width: 124rpx; |
||||||
|
height: 124rpx; |
||||||
|
border: 2px dotted #CCCCCC; |
||||||
|
border-radius: 50%; |
||||||
|
|
||||||
|
.help_item_2_yao{ |
||||||
|
margin: 34rpx 33rpx; |
||||||
|
width: 56rpx; |
||||||
|
height: 56rpx; |
||||||
|
font-size: 60rpx; |
||||||
|
font-family: PingFang SC; |
||||||
|
font-weight: 400; |
||||||
|
color: #CCCCCC; |
||||||
|
line-height: 48rpx; |
||||||
|
} |
||||||
|
|
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
} |
||||||
|
|
||||||
|
.help_btn{ |
||||||
|
text-align: center; |
||||||
|
margin: 0 75rpx; |
||||||
|
margin-bottom: 30rpx; |
||||||
|
width: 500rpx; |
||||||
|
height: 86rpx; |
||||||
|
background: linear-gradient(0deg, #DE4224 0%, #B81706 100%); |
||||||
|
border-radius: 43rpx; |
||||||
|
|
||||||
|
.help_btn_font{ |
||||||
|
font-size: 32rpx; |
||||||
|
font-family: PingFang SC; |
||||||
|
font-weight: 400; |
||||||
|
color: #FFFFFF; |
||||||
|
line-height: 86rpx; |
||||||
|
background: center; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
} |
||||||
|
</style> |
Loading…
Reference in new issue