activityInfo.vue 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469
  1. <template>
  2. <view>
  3. <view class="swiperDom">
  4. <swiper :autoplay="true" :interval="3000" :duration="1000">
  5. <swiper-item>
  6. <view class="swiper-item">
  7. <image :src="info.show_image" mode=""></image>
  8. </view>
  9. </swiper-item>
  10. </swiper>
  11. <view class="u-flex u-row-between title">
  12. <text>{{info.title}}</text>
  13. <image src="../../static/activity/share@2x.png" mode="" @click="showShare=true"></image>
  14. </view>
  15. <view class="info">
  16. <view class="u-flex item">
  17. <text class="left">报名时间</text>
  18. <text class="right">{{info.sig_statime}}-{{info.sig_endtime}}</text>
  19. </view>
  20. <view class="u-flex item">
  21. <text class="left">活动时间</text>
  22. <text class="right">{{info.av_statime}}-{{info.av_endtime}}</text>
  23. </view>
  24. <view class="u-flex item">
  25. <text class="left">活动地址</text>
  26. <text class="right">{{info.av_address}}</text>
  27. </view>
  28. <view class="u-flex item">
  29. <text class="left">参与人数</text>
  30. <text class="right">{{info.av_number}}</text>
  31. </view>
  32. <view class="u-flex item">
  33. <text class="left">参与单位</text>
  34. <text class="right">{{info.in_company}}</text>
  35. </view>
  36. <view class="u-flex item">
  37. <text class="left">合作单位</text>
  38. <text class="right">{{info.co_company}}</text>
  39. </view>
  40. <view class="u-flex item">
  41. <text class="left">活动门槛</text>
  42. <text class="right">{{info.age}}/{{info.education}}/{{info.nature}}</text>
  43. </view>
  44. <view class="u-flex " v-if="info.status==6">
  45. <text class="left">牵手人数</text>
  46. <text class="right">{{info.qianshou}}</text>
  47. </view>
  48. </view>
  49. <view class="content">
  50. <view class="content_title">
  51. 活动内容
  52. </view>
  53. <view class="content_info">
  54. <rich-text :nodes="info.content"></rich-text>
  55. </view>
  56. <view class="btn">
  57. <u-button text="立即报名" shape="circle" color="linear-gradient(270deg, #A890FE 0%, #FFAEAE 100%)"
  58. @click="baoming" v-if="info.is_sing!=1&&info.status==2"></u-button>
  59. <u-button :text="'已报名(报名号:'+info.sin_number+')'" shape="circle"
  60. color="linear-gradient(270deg, #A890FE 0%, #FFAEAE 100%)" v-if="info.is_sing==1&&info.status!=6"></u-button>
  61. <u-button text="报名结束" :disabled="true" shape="circle" color="black" v-if="info.status==4&&info.is_sing==2"></u-button>
  62. <u-button text="报名已满" :disabled="true" shape="circle" color="black" v-if="info.status==3&&info.is_sing==2"></u-button>
  63. <u-button text="活动未开始" :disabled="true" shape="circle" color="black" v-if="info.status==1&&info.is_sing==2"></u-button>
  64. <u-button text="活动进行中" :disabled="true" shape="circle" color="black" v-if="info.status==5&&info.is_sing==2"></u-button>
  65. <u-button text="活动已结束" :disabled="true" shape="circle" color="black" v-if="info.status==6"></u-button>
  66. </view>
  67. </view>
  68. </view>
  69. <u-popup :show="show1" @close="close" mode="center" :round="40">
  70. <view style="width: 650rpx;
  71. height: 640rpx;
  72. background: #FFFFFF;
  73. border-radius: 20rpx;padding: 80rpx 86rpx;color: #222;box-sizing: border-box;" class="u-flex-col">
  74. <image src="../../static/activity/success.png" mode="" style="width: 64rpx;height: 64rpx;"></image>
  75. <text style="margin: 24rpx 0 32rpx 0;font-size: 44rpx;">报名成功</text>
  76. <view class="" style="width: 310rpx;
  77. height: 64rpx;line-height: 64rpx;text-align: center;font-size: 26rpx;
  78. border-radius: 8rpx;
  79. border: 2rpx solid;
  80. border-image: linear-gradient(270deg, rgba(178, 148, 246, 1), rgba(248, 172, 182, 1)) 2 2;">
  81. 报名号 {{num}}
  82. </view>
  83. <text
  84. style="font-size: 24rpx;color: #888888;margin: 24rpx 0 60rpx 0;">恭喜您,报名成功,可在个人中心-我的活动中查看具体详情</text>
  85. <u-button text="我知道了" shape="circle" color="linear-gradient(270deg, #A890FE 0%, #FFAEAE 100%)"
  86. @click="closeShow"></u-button>
  87. </view>
  88. </u-popup>
  89. <u-popup :show="showShare" @close="close" bgColor='transparent' mode="center" :round="40">
  90. <view style="width: 650rpx;
  91. height: 972rpx;
  92. border-radius: 28rpx;color: #222;box-sizing: border-box;overflow: hidden;" class="u-flex-col">
  93. <view class="" style="width: 650rpx;height: 368rpx;">
  94. <image :src="info.show_image" mode="" style="width: 650rpx;height: 368rpx;"></image>
  95. </view>
  96. <view class="" style="width: 650rpx;height: 432rpx;border-radius: 0 0 28rpx 28rpx;background-color: #fff;padding: 32rpx 40rpx;box-sizing: border-box;">
  97. <view class="" style="font-size: 32rpx;color: #222;font-weight: 600;margin-bottom: 180rpx;">
  98. {{info.title}}
  99. </view>
  100. <view class="u-flex u-row-between">
  101. <image :src="userInfo.headimg" mode="" style="width: 96rpx;height: 96rpx;border-radius: 50%;"></image>
  102. <view class="u-flex u-row-right">
  103. <view class="" style="font-size: 20rpx;color: #666;margin-right: 20rpx;">
  104. 扫码参加<br> 遇见更多美好
  105. </view>
  106. <image :src="info.sing_img" mode="" style="width: 136rpx;height: 136rpx;"></image>
  107. <!-- <image src="../../static/test.png" mode="" style="width: 136rpx;height: 136rpx;"></image> -->
  108. </view>
  109. </view>
  110. </view>
  111. <view class="u-flex u-row-between" style="margin-top: 80rpx;width: 100%;">
  112. <view class="" style="width: 230rpx;">
  113. <u-button text="保存图片" :plain="true" shape="circle" color="linear-gradient(270deg, #A890FE 0%, #FFAEAE 100%)"
  114. @click="storageImg"></u-button>
  115. </view>
  116. <view class="" style="width: 390rpx;">
  117. <u-button text="马上邀请好友" open-type="share" shape="circle" color="linear-gradient(270deg, #A890FE 0%, #FFAEAE 100%)"
  118. @click="showShare=false"></u-button>
  119. </view>
  120. </view>
  121. </view>
  122. </u-popup>
  123. <u-popup :show="showrenzheng" @close="close" mode="center" :round="40">
  124. <view style="width: 650rpx;
  125. height: 560rpx;
  126. background: #FFFFFF;
  127. border-radius: 20rpx;padding: 0 146rpx;color: #222;box-sizing: border-box;" class="u-flex-col">
  128. <image src="../../static/activity/weirenzheng.png" mode="" style="width: 320rpx;height: 320rpx;margin-top: -90rpx;"></image>
  129. <text style="margin: 24rpx 0 52rpx 0;font-size: 32rpx;font-weight: 600;">您还未认证成为正式会员 请先认证后再参与</text>
  130. <u-button text="立即认证" @click="gorenzheng" shape="circle" color="linear-gradient(270deg, #A890FE 0%, #FFAEAE 100%)"
  131. ></u-button>
  132. </view>
  133. </u-popup>
  134. <u-popup :show="showmanzu" @close="close" mode="center" :round="40">
  135. <view style="width: 650rpx;
  136. height: 560rpx;
  137. background: #FFFFFF;
  138. border-radius: 20rpx;padding: 0 146rpx;color: #222;box-sizing: border-box;" class="u-flex-col">
  139. <image src="../../static/activity/weirenzheng.png" mode="" style="width: 320rpx;height: 320rpx;margin-top: -90rpx;"></image>
  140. <text style="margin: 24rpx 0 52rpx 0;font-size: 32rpx;font-weight: 600;">您未满足报名条件
  141. 不可报名活动</text>
  142. <u-button text="我知道了" shape="circle" color="linear-gradient(270deg, #A890FE 0%, #FFAEAE 100%)"
  143. @click="showmanzu=false"></u-button>
  144. </view>
  145. </u-popup>
  146. <canvas canvas-id="shareCanvas" style="width: 650px;height: 800px;position: fixed;top: -1000px;left: 1000px;z-index: 99;"></canvas>
  147. </view>
  148. </template>
  149. <script>
  150. export default {
  151. onLoad(option) {
  152. uni.$u.mpShare.path='/pages/index/index'
  153. this.id=option.id
  154. this.getInfo(option.id)
  155. },
  156. data() {
  157. return {
  158. info:{},
  159. id:'',
  160. showrenzheng:false,
  161. show1: false,
  162. showShare: false,
  163. showmanzu:false,
  164. num:'',
  165. userInfo:JSON.parse(uni.getStorageSync('userInfo')),
  166. canvas: null,
  167. }
  168. },
  169. methods: {
  170. storageImg(){
  171. this.drawCanvas()
  172. },
  173. // 封装的下载图片函数
  174. downLoadImage(url) {
  175. return new Promise((resolve, reject) => {
  176. wx.getImageInfo({
  177. src: url,
  178. success(res) {
  179. resolve(res.path)
  180. },
  181. fail(err) {
  182. reject(err)
  183. },
  184. complete() {
  185. console.log('complete')
  186. }
  187. })
  188. })
  189. },
  190. drawCircular(ctx,width, height, x, y, url) {
  191. var avatarurl_width = width;
  192. var avatarurl_heigth = height;
  193. var avatarurl_x = x;
  194. var avatarurl_y = y;
  195. ctx.save();
  196. ctx.beginPath();
  197. ctx.arc(avatarurl_width / 2 + avatarurl_x, avatarurl_heigth / 2 + avatarurl_y, avatarurl_width / 2, 0, Math.PI * 2, false);
  198. ctx.clip();
  199. ctx.drawImage(url, avatarurl_x, avatarurl_y, avatarurl_width, avatarurl_heigth);
  200. ctx.restore();
  201. },
  202. //第一个参数:创建的画布对象
  203. //第二个参数:矩形的宽
  204. //第三个参数:矩形的高
  205. //第四个参数:矩形左上角x轴坐标点,
  206. //第五个参数:矩形左上角y轴坐标点,
  207. //第六个参数:绘制的图片的URL
  208. drawCanvas(){
  209. uni.showLoading({
  210. })
  211. var that=this
  212. let ctx = wx.createCanvasContext('shareCanvas', this)
  213. // let titleImage = this.downLoadImage('https://dhy.danheyou.com/image/main/haibaoy.png');
  214. // let productImage = this.downLoadImage('https://dhy.danheyou.com/image/main/haibaoy.png');
  215. // let erCodeImage = this.downLoadImage('https://dhy.danheyou.com/image/main/haibaoy.png');
  216. let titleImage = this.downLoadImage(this.userInfo.headimg);
  217. let productImage = this.downLoadImage(this.info.show_image);
  218. let erCodeImage = this.downLoadImage(this.info.sing_image);
  219. Promise.all([titleImage, productImage, erCodeImage]).then(imgs => {
  220. console.log('imgs', imgs)
  221. // 全部图片下载成功
  222. let bgWidth = 650;
  223. let bgHeight = 800;
  224. // 绘制白底背景
  225. ctx.setFillStyle('#fff')
  226. ctx.fillRect(0, 0, bgWidth, bgHeight)
  227. console.log('全部图片下载成功')
  228. // 绘制产品图片
  229. let productOffLeft = 0;
  230. let productOffTop = 0;
  231. let productWidth = 650;
  232. let productHeight = 368;
  233. ctx.drawImage(imgs[1], productOffLeft, productOffTop, productWidth, productHeight)
  234. console.log('imgs', imgs[2])
  235. ctx.drawImage(imgs[2], 474 , 616, 136, 136)
  236. ctx.setFillStyle('#333')
  237. ctx.setFontSize(32)
  238. ctx.fillText(this.info.title, 40, 420)
  239. ctx.setFillStyle('#666')
  240. ctx.setFontSize(20)
  241. ctx.fillText('扫码参加', 352, 732)
  242. ctx.fillText('遇见更多美好', 315, 752)
  243. // ctx.drawImage(imgs[0], 40 , 656, 96, 96)
  244. that.drawCircular(ctx,96, 96,40 , 656,imgs[0])
  245. ctx.draw(true, () => {
  246. wx.hideLoading();
  247. // wx.showLoading({
  248. // title: '保存中',
  249. // icon: 'none'
  250. // })
  251. let _this = this;
  252. wx.canvasToTempFilePath({
  253. x: 0,
  254. y: 0,
  255. canvasId: 'shareCanvas',
  256. quality: 1.0,
  257. fileType: 'jpg',
  258. success(res) {
  259. console.log('生成图片成功')
  260. console.log('res', res.tempFilePath)
  261. that.saveImage(res.tempFilePath)
  262. wx.hideLoading()
  263. },
  264. fail(err) {
  265. console.log('err', err)
  266. wx.showToast({
  267. title: '图片生成失败',
  268. icon: 'none',
  269. })
  270. },
  271. complete() {
  272. }
  273. }, _this)
  274. })
  275. }).catch(err => {
  276. console.log(err)
  277. })
  278. },
  279. // 保存图片
  280. saveImage(url) {
  281. let _this = this;
  282. // let tempFilePath = this.data.tempFilePath;
  283. if (!url) {
  284. wx.showToast({
  285. title: '图片生成失败',
  286. icon: 'none',
  287. })
  288. return;
  289. }
  290. wx.saveImageToPhotosAlbum({
  291. filePath: url,
  292. success() {
  293. _this.showShare=false
  294. wx.showToast({
  295. title: '已保存到相册,您可将图片分享到朋友圈',
  296. icon: 'none'
  297. })
  298. },
  299. fail() {
  300. wx.showToast({
  301. title: '图片保存失败',
  302. icon: 'none',
  303. })
  304. },
  305. complete() {
  306. // wx.hideLoading();
  307. }
  308. })
  309. },
  310. closeShow(){
  311. this.show1=false
  312. },
  313. gorenzheng(){
  314. uni.switchTab({
  315. url:'../auth/auth'
  316. })
  317. },
  318. getInfo(id){
  319. uni.$u.http.post('/api/Activity/activity',{id:id}).then(res => {
  320. this.info=res.data
  321. })
  322. },
  323. baoming() {
  324. if(this.userInfo.vip_level==0){
  325. this.$u.toast('您暂未认证')
  326. return
  327. }
  328. if(this.userInfo.vip_level==2){
  329. this.$u.toast('经用户反馈,您账户存在违规行为,暂不支持使用该功能')
  330. return
  331. }
  332. if(this.userInfo.vip_level==3){
  333. this.$u.toast('您的账户已注销,暂不支持使用该功能')
  334. return
  335. }
  336. uni.$u.http.post('/api/Activity/sign_up',{aid:this.info.id}).then(res => {
  337. if(res.code==1){
  338. if(res.data.status==3){
  339. this.num=res.data.number
  340. this.show1=true
  341. this.getInfo(this.id)
  342. }
  343. else if(res.data.status==2){
  344. this.showmanzu=true
  345. }else if(res.data.status==1){
  346. this.showrenzheng=true
  347. }
  348. }
  349. })
  350. // this.showmanzu = true
  351. },
  352. close() {
  353. this.show1 = false
  354. this.showShare = false
  355. this.showrenzheng = false
  356. this.showmanzu = false
  357. // console.log('close');
  358. },
  359. }
  360. }
  361. </script>
  362. <style lang="scss">
  363. .btn {
  364. width: 650rpx;
  365. position: fixed;
  366. bottom: 58rpx;
  367. }
  368. .content {
  369. padding: 30rpx;
  370. background-color: #fff;
  371. .content_title {
  372. font-size: 28rpx;
  373. color: #222222;
  374. font-weight: 600;
  375. }
  376. .content_info {
  377. margin-top: 24rpx;
  378. font-size: 24rpx;
  379. font-family: PingFangSC-Regular, PingFang SC;
  380. font-weight: 400;
  381. color: #666666;
  382. line-height: 34rpx;
  383. padding-bottom: 200rpx;
  384. }
  385. }
  386. .item {
  387. margin-bottom: 36rpx;
  388. }
  389. .item:nth-child(8) {
  390. margin-bottom: 0;
  391. }
  392. .info {
  393. background-color: #fff;
  394. padding: 30rpx;
  395. margin: 20rpx 0;
  396. .left {
  397. font-size: 24rpx;
  398. color: #888888;
  399. margin-right: 52rpx;
  400. }
  401. .right {
  402. font-size: 24rpx;
  403. color: #222;
  404. }
  405. }
  406. .title {
  407. background-color: #fff;
  408. height: 108rpx;
  409. line-height: 108rpx;
  410. padding: 0 30rpx;
  411. text {
  412. font-size: 32rpx;
  413. color: #222222;
  414. font-weight: 600;
  415. }
  416. image {
  417. width: 44rpx;
  418. height: 72rpx;
  419. vertical-align: middle;
  420. }
  421. }
  422. page {
  423. background-color: #F6F2FD;
  424. }
  425. swiper {
  426. width: 750rpx;
  427. height: 400rpx;
  428. }
  429. .swiper-item {
  430. overflow: hidden;
  431. width: 750rpx;
  432. height: 400rpx;
  433. image {
  434. width: 750rpx;
  435. height: 400rpx;
  436. }
  437. }
  438. </style>