新增canvas绘制图片、保存、分享
|
@ -0,0 +1,11 @@
|
|||
//app.js
|
||||
var urlPath = require('./config.js');
|
||||
App({
|
||||
globalData: {
|
||||
isLogin : false
|
||||
},
|
||||
onLaunch: function () {
|
||||
var that = this;
|
||||
wx.setStorageSync('urlPath', urlPath);
|
||||
},
|
||||
})
|
|
@ -0,0 +1,53 @@
|
|||
{
|
||||
"pages": [
|
||||
"pages/canvasposter/canvasposter",
|
||||
"pages/index/index",
|
||||
"pages/again/again",
|
||||
"pages/sign/sign",
|
||||
"pages/user/user",
|
||||
"pages/rule/rule",
|
||||
"pages/ranking/ranking",
|
||||
"pages/picture/picture",
|
||||
"pages/personal/personal",
|
||||
"pages/auth/auth"
|
||||
],
|
||||
"tabBar": {
|
||||
"custom": true,
|
||||
"color": "#7A7E83",
|
||||
"selectedColor": "#3cc51f",
|
||||
"borderStyle": "black",
|
||||
"backgroundColor": "#ffffff",
|
||||
"list": [{
|
||||
"pagePath": "pages/canvasposter/canvasposter",
|
||||
"iconPath": "img/bg_w.png",
|
||||
"selectedIconPath": "img/bg_b.png",
|
||||
"text": "首页"
|
||||
},{
|
||||
"pagePath": "pages/index/index",
|
||||
"iconPath": "img/bg_w.png",
|
||||
"selectedIconPath": "img/bg_b.png",
|
||||
"text": "产品"
|
||||
},
|
||||
{
|
||||
"pagePath": "pages/ranking/ranking",
|
||||
"iconPath": "img/bg_w.png",
|
||||
"selectedIconPath": "img/bg_b.png",
|
||||
"text": "排行榜"
|
||||
},
|
||||
{
|
||||
"pagePath": "pages/user/user",
|
||||
"iconPath": "img/bg_w.png",
|
||||
"selectedIconPath": "img/bg_b.png",
|
||||
"text": "个人中心"
|
||||
}
|
||||
]
|
||||
},
|
||||
"window": {
|
||||
"backgroundTextStyle": "light",
|
||||
"navigationBarBackgroundColor": "#fff",
|
||||
"navigationBarTitleText": "丰谷酒业",
|
||||
"navigationBarTextStyle": "black"
|
||||
},
|
||||
"style": "v2",
|
||||
"sitemapLocation": "sitemap.json"
|
||||
}
|
|
@ -0,0 +1,120 @@
|
|||
.container{
|
||||
background: #eeeeee;
|
||||
min-height: 100vh;
|
||||
padding-bottom: 40rpx;
|
||||
}
|
||||
view,text,input,button,scroll-view,textarea{
|
||||
box-sizing: border-box;
|
||||
}
|
||||
.container button[disabled],.container button[disabled]:not([type]) {
|
||||
background-color: #ccc;
|
||||
color: #fff;
|
||||
}
|
||||
.top10{
|
||||
margin-top: 10rpx;
|
||||
}
|
||||
.top20{
|
||||
margin-top: 20rpx;
|
||||
}
|
||||
.top30{
|
||||
margin-top: 30rpx;
|
||||
}
|
||||
.top40{
|
||||
margin-top: 40rpx;
|
||||
}
|
||||
/**通用css**/
|
||||
view{
|
||||
box-sizing: border-box;
|
||||
}
|
||||
.view-bg{
|
||||
width: 690rpx;
|
||||
position: relative;
|
||||
background: #fff;
|
||||
margin-left:auto;
|
||||
margin-right: auto;
|
||||
border-radius: 10rpx;
|
||||
overflow: hidden;
|
||||
padding-bottom: 40rpx;
|
||||
}
|
||||
/**/
|
||||
.countdown{
|
||||
width: 100%;
|
||||
text-align: center;
|
||||
padding: 40rpx 0;
|
||||
}
|
||||
.countdown .names{
|
||||
font-size: 30rpx;
|
||||
}
|
||||
.countdown .names text{
|
||||
background: url("") no-repeat center;
|
||||
background-size:499rpx 10rpx;
|
||||
display: inline-block;
|
||||
width: 100%;
|
||||
}
|
||||
.countdown .time{
|
||||
color: #666666;
|
||||
font-size: 32rpx;
|
||||
height: 50rpx;
|
||||
line-height: 50rpx;
|
||||
margin-top: 30rpx;
|
||||
}
|
||||
.countdown .time text{
|
||||
height: 50rpx;
|
||||
width: 50rpx;
|
||||
display: inline-block;
|
||||
background:#2a8de9;
|
||||
border-radius: 4rpx;
|
||||
color: #fff;
|
||||
margin:0 6rpx;
|
||||
}
|
||||
.countdown .tab{
|
||||
display: inline-block;
|
||||
width: 100%;
|
||||
margin-top: 40rpx;
|
||||
}
|
||||
.countdown .tab .list{
|
||||
width: 33.33%;
|
||||
float: left;
|
||||
display: inline-block;
|
||||
font-size: 50rpx;
|
||||
border-right: 1rpx solid #ebebeb;
|
||||
font-weight: bold;
|
||||
}
|
||||
.countdown .tab .list text{
|
||||
font-size: 24rpx;
|
||||
color: #333333;
|
||||
font-weight: 400;
|
||||
}
|
||||
.countdown .tab .list text:nth-child(2){
|
||||
display: block;
|
||||
margin-top: 10rpx;
|
||||
}
|
||||
/**/
|
||||
.signup{
|
||||
width: 130rpx;
|
||||
height: 50rpx;
|
||||
line-height: 50rpx;
|
||||
background: #ffc103;
|
||||
color: #fff;
|
||||
font-size: 26rpx;
|
||||
border-radius: 15rpx 0 0 15rpx;
|
||||
text-align: center;
|
||||
position: fixed;
|
||||
top: 460rpx;
|
||||
right: 0;
|
||||
box-shadow: 0 6rpx 6rpx rgba(0,0,0,.2);
|
||||
}
|
||||
.sign-rule{
|
||||
width: 130rpx;
|
||||
height: 50rpx;
|
||||
line-height: 50rpx;
|
||||
background: #2A8DEB;
|
||||
color: #fff;
|
||||
font-size: 26rpx;
|
||||
border-radius: 15rpx 0 0 15rpx;
|
||||
text-align: center;
|
||||
position: fixed;
|
||||
top: 540rpx;
|
||||
right: 0;
|
||||
box-shadow: 0 6rpx 6rpx rgba(0,0,0,.2);
|
||||
}
|
|
@ -0,0 +1,23 @@
|
|||
var host = "https://vote.daiguanyun.com";
|
||||
var host = "http://192.168.2.15:8810";
|
||||
var config = {
|
||||
host:host,
|
||||
getopenid: host + "/index/getOpenId",
|
||||
getVoteList: host + '/index/rankList',
|
||||
getSlideList: host + '/index/getSlideList',
|
||||
getDetail: host + '/index/getOneById',
|
||||
getImgs: host + '/index/getImgs',
|
||||
getBaseInfo: host + '/index/getBaseInfo',
|
||||
upload: host + '/index/upload',
|
||||
saveProduction: host + '/index/saveProduction',
|
||||
getUser: host + '/index/getUser',
|
||||
vote : host + '/index/vote',
|
||||
getUserById:host + '/index/getUserById',
|
||||
getUserProduction: host + '/index/getUserProduction',
|
||||
saveVisit: host + '/index/saveVisit',
|
||||
search: host + '/index/search',
|
||||
getBottleCategories: host + '/index/getBottleCategories',//酒瓶标题
|
||||
composeBottle: host + '/index/composeBottle',//保存图片
|
||||
getBottleWidgets: host + '/index/getBottleWidgets',//查询作品
|
||||
}
|
||||
module.exports = config;
|
|
@ -0,0 +1,38 @@
|
|||
Component({
|
||||
data: {
|
||||
selected: '-1',
|
||||
color: "#7A7E83",
|
||||
selectedColor: "#fff",
|
||||
list: [{
|
||||
pagePath: "/pages/canvasposter/canvasposter",
|
||||
iconPath: "/img/bg_w.png",
|
||||
selectedIconPath: "/img/bg_b.png",
|
||||
text: "首页"
|
||||
},{
|
||||
pagePath: "/pages/index/index",
|
||||
iconPath: "/img/bg_w.png",
|
||||
selectedIconPath: "/img/bg_b.png",
|
||||
text: "产品"
|
||||
}, {
|
||||
pagePath: "/pages/ranking/ranking",
|
||||
iconPath: "/img/bg_w.png",
|
||||
selectedIconPath: "/img/bg_b.png",
|
||||
text: "排行榜"
|
||||
}, {
|
||||
pagePath: "/pages/user/user",
|
||||
iconPath: "/img/bg_w.png",
|
||||
selectedIconPath: "/img/bg_b.png",
|
||||
text: "个人中心"
|
||||
}]
|
||||
},
|
||||
attached() {},
|
||||
methods: {
|
||||
switchTab(e) {
|
||||
const data = e.currentTarget.dataset
|
||||
const url = data.path
|
||||
wx.switchTab({
|
||||
url
|
||||
}) //可能是改变样式的原因
|
||||
}
|
||||
}
|
||||
})
|
|
@ -0,0 +1,3 @@
|
|||
{
|
||||
"component": true
|
||||
}
|
|
@ -0,0 +1,8 @@
|
|||
<!--miniprogram/custom-tab-bar/index.wxml-->
|
||||
<cover-view class="tab-bar">
|
||||
<cover-view wx:for="{{list}}" wx:key="index" class="tab-bar-item" data-path="{{item.pagePath}}"
|
||||
data-index="{{index}}" bindtap="switchTab">
|
||||
<cover-image src="{{selected === index ? item.selectedIconPath : item.iconPath}}"></cover-image>
|
||||
<cover-view style="color: {{selected === index ? selectedColor : color}}">{{item.text}}</cover-view>
|
||||
</cover-view>
|
||||
</cover-view>
|
|
@ -0,0 +1,37 @@
|
|||
.tab-bar {
|
||||
position: fixed;
|
||||
bottom: 0;
|
||||
left: 0;
|
||||
right: 0;
|
||||
height: 89rpx;
|
||||
background: white;
|
||||
display: flex;
|
||||
box-shadow: 0 -10rpx 10rpx rgba(0,0,0,.1);
|
||||
}
|
||||
|
||||
|
||||
.tab-bar-item {
|
||||
flex: 1;
|
||||
text-align: center;
|
||||
display: flex;
|
||||
justify-content: center;
|
||||
align-items: center;
|
||||
flex-direction: column;
|
||||
}
|
||||
|
||||
.tab-bar-item cover-image {
|
||||
width: 100%;
|
||||
height: 91rpx;
|
||||
}
|
||||
|
||||
.tab-bar-item cover-view {
|
||||
position: relative;
|
||||
top: 0;
|
||||
width: 100%;
|
||||
left: 0;
|
||||
height: 90rpx;
|
||||
line-height: 90rpx;
|
||||
font-size: 30rpx;
|
||||
z-index: 99;
|
||||
margin-top: -90rpx;
|
||||
}
|
After Width: | Height: | Size: 914 KiB |
After Width: | Height: | Size: 891 KiB |
After Width: | Height: | Size: 2.0 KiB |
After Width: | Height: | Size: 1.1 KiB |
After Width: | Height: | Size: 1.8 KiB |
After Width: | Height: | Size: 42 KiB |
After Width: | Height: | Size: 36 KiB |
After Width: | Height: | Size: 3.5 KiB |
After Width: | Height: | Size: 70 KiB |
After Width: | Height: | Size: 20 KiB |
After Width: | Height: | Size: 90 KiB |
After Width: | Height: | Size: 2.2 KiB |
After Width: | Height: | Size: 319 KiB |
After Width: | Height: | Size: 304 KiB |
After Width: | Height: | Size: 1.2 KiB |
After Width: | Height: | Size: 37 KiB |
After Width: | Height: | Size: 2.3 KiB |
After Width: | Height: | Size: 2.2 KiB |
After Width: | Height: | Size: 2.1 KiB |
After Width: | Height: | Size: 1.1 KiB |
After Width: | Height: | Size: 1.2 KiB |
After Width: | Height: | Size: 141 KiB |
After Width: | Height: | Size: 392 KiB |
After Width: | Height: | Size: 319 KiB |
After Width: | Height: | Size: 304 KiB |
After Width: | Height: | Size: 245 KiB |
After Width: | Height: | Size: 58 KiB |
After Width: | Height: | Size: 179 KiB |
After Width: | Height: | Size: 135 KiB |
After Width: | Height: | Size: 2.8 KiB |
After Width: | Height: | Size: 2.3 KiB |
After Width: | Height: | Size: 24 KiB |
After Width: | Height: | Size: 46 KiB |
After Width: | Height: | Size: 77 KiB |
After Width: | Height: | Size: 2.2 KiB |
|
@ -0,0 +1,154 @@
|
|||
// pages/sign/sign.js
|
||||
Page({
|
||||
|
||||
/**
|
||||
* 页面的初始数据
|
||||
*/
|
||||
data: {
|
||||
img_url:wx.getStorageSync('img_url'),
|
||||
swiperCurrent:0,
|
||||
autoplay: false,
|
||||
interval: 3000,
|
||||
duration: 800,
|
||||
//倒计时数据
|
||||
endTime: '2020/11/22 10:40:30',
|
||||
//
|
||||
tab_number:31,//参与者
|
||||
tab_vote:2375,//投票数
|
||||
tab_visit:55,//访问次数
|
||||
//上传图
|
||||
source:'',
|
||||
is_upload:'0',
|
||||
},
|
||||
/**
|
||||
* 上传图片
|
||||
*/
|
||||
uploadimg:function(){
|
||||
var that = this;
|
||||
wx.chooseImage({ //从本地相册选择图片或使用相机拍照
|
||||
count: 1, // 默认9
|
||||
sizeType: ['original', 'compressed'], // 可以指定是原图还是压缩图,默认二者都有
|
||||
sourceType: ['album', 'camera'], // 可以指定来源是相册还是相机,默认二者都有
|
||||
success:function(res){
|
||||
//前台显示
|
||||
that.setData({
|
||||
source: res.tempFilePaths,
|
||||
is_upload:'1'
|
||||
})
|
||||
// 返回选定照片的本地文件路径列表,tempFilePath可以作为img标签的src属性显示图片
|
||||
var tempFilePaths = res.tempFilePaths
|
||||
wx.uploadFile({
|
||||
url: '#',
|
||||
filePath: tempFilePaths[0],
|
||||
name: 'file',
|
||||
success:function(res){
|
||||
//打印
|
||||
}
|
||||
})
|
||||
}
|
||||
})
|
||||
//https://www.jb51.net/article/132557.htm 后端源码
|
||||
},
|
||||
//上传图片
|
||||
swiperChange: function (e) {
|
||||
this.setData({
|
||||
swiperCurrent: e.detail.current
|
||||
})
|
||||
},
|
||||
/**
|
||||
* 生命周期函数--监听页面加载
|
||||
*/
|
||||
onLoad: function (options) {
|
||||
var that = this;
|
||||
that.countDown()
|
||||
},
|
||||
// 倒计时
|
||||
countDown:function(){
|
||||
var that=this;
|
||||
var nowTime = new Date().getTime();//现在时间(时间戳)
|
||||
var endTime = new Date(that.data.endTime).getTime();//结束时间(时间戳)
|
||||
var time = (endTime-nowTime)/1000;//距离结束的毫秒数
|
||||
// 获取天、时、分、秒
|
||||
let day = parseInt(time / (60 * 60 * 24));
|
||||
let hou = parseInt(time % (60 * 60 * 24) / 3600);
|
||||
let min = parseInt(time % (60 * 60 * 24) % 3600 / 60);
|
||||
let sec = parseInt(time % (60 * 60 * 24) % 3600 % 60);
|
||||
day = that.timeFormin(day),
|
||||
hou = that.timeFormin(hou),
|
||||
min = that.timeFormin(min),
|
||||
sec = that.timeFormin(sec)
|
||||
that.setData({
|
||||
day: that.timeFormat(day),
|
||||
hou: that.timeFormat(hou),
|
||||
min: that.timeFormat(min),
|
||||
sec: that.timeFormat(sec)
|
||||
})
|
||||
// 每1000ms刷新一次
|
||||
if (time>0){
|
||||
that.setData({
|
||||
countDown: true
|
||||
})
|
||||
setTimeout(this.countDown, 1000);
|
||||
}else{
|
||||
that.setData({
|
||||
countDown:false
|
||||
})
|
||||
}
|
||||
},
|
||||
//小于10的格式化函数(2变成02)
|
||||
timeFormat(param) {
|
||||
return param < 10 ? '0' + param : param;
|
||||
},
|
||||
//小于0的格式化函数(不会出现负数)
|
||||
timeFormin(param) {
|
||||
return param < 0 ? 0: param;
|
||||
},
|
||||
/**
|
||||
* 生命周期函数--监听页面初次渲染完成
|
||||
*/
|
||||
onReady: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 生命周期函数--监听页面显示
|
||||
*/
|
||||
onShow: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 生命周期函数--监听页面隐藏
|
||||
*/
|
||||
onHide: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 生命周期函数--监听页面卸载
|
||||
*/
|
||||
onUnload: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 页面相关事件处理函数--监听用户下拉动作
|
||||
*/
|
||||
onPullDownRefresh: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 页面上拉触底事件的处理函数
|
||||
*/
|
||||
onReachBottom: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 用户点击右上角分享
|
||||
*/
|
||||
onShareAppMessage: function () {
|
||||
|
||||
}
|
||||
})
|
|
@ -0,0 +1,3 @@
|
|||
{
|
||||
"usingComponents": {}
|
||||
}
|
|
@ -0,0 +1,66 @@
|
|||
<!--pages/sign.wxml-->
|
||||
<view class="container">
|
||||
<view class="page-body">
|
||||
<view class="page-section page-section-spacing swiper">
|
||||
<swiper autoplay="true" interval="{{interval}}" duration="{{duration}}"
|
||||
circular="true" current="{{swiperCurrent}}" bindchange="swiperChange">
|
||||
<block wx:for="{{img_url}}" >
|
||||
<swiper-item>
|
||||
<view class="swiper-item">
|
||||
<image src="{{item}}" ></image>
|
||||
</view>
|
||||
</swiper-item>
|
||||
</block>
|
||||
</swiper>
|
||||
</view>
|
||||
<view class="dots">
|
||||
<block wx:for="{{img_url}}" wx:key="unique">
|
||||
<view class="dot{{index == swiperCurrent ? ' active' : ''}}"></view>
|
||||
</block>
|
||||
</view>
|
||||
</view>
|
||||
<!--内容-->
|
||||
<view class="view-bg top40">
|
||||
<view class="countdown">
|
||||
<view class="names">
|
||||
<text>距离投票结束还有</text>
|
||||
</view>
|
||||
<view class="time" >
|
||||
<text>{{day}}</text>天 <text>{{hou}}</text>时<text>{{min}}</text>分<text>{{sec}}</text>秒
|
||||
</view>
|
||||
<view class="tab">
|
||||
<view class="list">
|
||||
{{tab_number}}<text>人</text>
|
||||
<text>参与者</text>
|
||||
</view>
|
||||
<view class="list">
|
||||
{{tab_vote}}<text>票</text>
|
||||
<text>投票数</text>
|
||||
</view>
|
||||
<view class="list">
|
||||
{{tab_visit}}<text>次</text>
|
||||
<text>访问量</text>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
<!--表单-->
|
||||
<view class="sign">
|
||||
<form>
|
||||
<view class="list">
|
||||
<text>描述</text>
|
||||
<textarea placeholder="请介绍一下自己" maxlength="100" adjust-position="true" />
|
||||
</view>
|
||||
<view class="list">
|
||||
<text>上传作品</text>
|
||||
<view class="img">
|
||||
<image src='{{source}}'/>
|
||||
<view class="{{is_upload=='1'?'uploadopacity':''}} uploadimg" bindtap="uploadimg"></view>
|
||||
</view>
|
||||
</view>
|
||||
<view class="list">
|
||||
<button>提交报名</button>
|
||||
</view>
|
||||
</form>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
|
@ -0,0 +1,102 @@
|
|||
/* pages/sign/sign.wxss */
|
||||
.page-body{
|
||||
height: 300rpx;
|
||||
position: relative;
|
||||
}
|
||||
.swiper-item image{
|
||||
width: 100%;
|
||||
height: 300rpx;
|
||||
}
|
||||
.dots{
|
||||
display: inline-block;
|
||||
position: absolute;
|
||||
bottom: 20rpx;
|
||||
right: 0;
|
||||
padding: 0 20rpx;
|
||||
}
|
||||
.dots .dot{
|
||||
width: 8rpx;
|
||||
height: 8rpx;
|
||||
background: #fff;
|
||||
float: left;
|
||||
margin:0 4rpx;
|
||||
border-radius: 50%;
|
||||
}
|
||||
.dots .dot.active{
|
||||
background: #2a8de9;
|
||||
}
|
||||
.sign{
|
||||
padding: 0 40rpx;
|
||||
width: 100%;
|
||||
}
|
||||
.sign .list{
|
||||
margin-top: 40rpx;
|
||||
width: 100%;
|
||||
}
|
||||
.sign .list text{
|
||||
font-size: 30rpx;
|
||||
}
|
||||
.sign .list input,.sign .list textarea{
|
||||
width: 610rpx;
|
||||
height: 70rpx;
|
||||
border: none;
|
||||
background-color: #eeeeee;
|
||||
border-radius: 5rpx;
|
||||
margin-top: 10rpx;
|
||||
padding: 0 20rpx;
|
||||
font-size: 26rpx;
|
||||
}
|
||||
.sign .list textarea{
|
||||
height: 173rpx;
|
||||
padding-top: 20rpx;
|
||||
}
|
||||
.sign .list button:not([size='mini']){
|
||||
width: 570rpx;
|
||||
border-radius: 8rpx;
|
||||
background-color: #2a8de9;
|
||||
color: #fff;
|
||||
font-size: 30rpx;
|
||||
height: 74rpx;
|
||||
}
|
||||
.sign .list .img{
|
||||
margin-top:20rpx;
|
||||
display: inline-block;
|
||||
width: 100%;
|
||||
position: relative;
|
||||
}
|
||||
.sign .list image{
|
||||
width: 160rpx;
|
||||
height: 160rpx;
|
||||
float: left;
|
||||
}
|
||||
.sign .list .uploadimg{
|
||||
width: 160rpx;
|
||||
height: 160rpx;
|
||||
border: 2rpx solid #cacaca;
|
||||
position: relative;
|
||||
}
|
||||
.uploadopacity{
|
||||
opacity:0
|
||||
}
|
||||
.sign .list .uploadimg::after{
|
||||
width: 112rpx;
|
||||
height: 6rpx;
|
||||
background: #cacaca;
|
||||
content: "";
|
||||
position: absolute;
|
||||
left: 50%;
|
||||
margin-left: -56rpx;
|
||||
top: 50%;
|
||||
margin-top: -3rpx;
|
||||
}
|
||||
.sign .list .uploadimg::before{
|
||||
width: 6rpx;
|
||||
height: 112rpx;
|
||||
background: #cacaca;
|
||||
content: "";
|
||||
position: absolute;
|
||||
left: 50%;
|
||||
margin-left: -3rpx;
|
||||
top: 50%;
|
||||
margin-top: -56rpx;
|
||||
}
|
|
@ -0,0 +1,17 @@
|
|||
var app = getApp();
|
||||
Page({
|
||||
data: {
|
||||
canIUse: wx.canIUse('button.open-type.getUserInfo')
|
||||
},
|
||||
onAuth() {
|
||||
wx.getSetting({
|
||||
success: (res) => {
|
||||
if (res.authSetting['scope.userInfo']) {
|
||||
wx.reLaunch({
|
||||
url: '../index/index',
|
||||
})
|
||||
}
|
||||
}
|
||||
})
|
||||
}
|
||||
})
|
|
@ -0,0 +1,3 @@
|
|||
{
|
||||
"usingComponents": {}
|
||||
}
|
|
@ -0,0 +1,7 @@
|
|||
<view class="auth">
|
||||
<image src="https://res.wx.qq.com/wxopenres/htmledition/images/favicon32f740.ico" class="img" mode="aspectFill"></image>
|
||||
<view class="title">微信授权页面</view>
|
||||
<view class="describe">此页面是微信授权页面,点击下方按钮弹出授权或跳转页面</view>
|
||||
<button class="btn" open-type='getUserInfo' wx:if="{{canIUse}}" bindgetuserinfo='onAuth'>点击微信授权</button>
|
||||
<navigator wx:if="{{!canIUse}}" class="btn" url="/pages/auth/auth" open-type="reLaunch" hover-class="other-navigator-hover">已经授权点击调转</navigator>
|
||||
</view>
|
|
@ -0,0 +1,68 @@
|
|||
/* 开始 */
|
||||
page {
|
||||
height: 100%;
|
||||
display: table;
|
||||
}
|
||||
|
||||
.auth {
|
||||
margin-top: 0;
|
||||
text-align: center;
|
||||
display: table-cell;
|
||||
flex-direction: column;
|
||||
flex-wrap: wrap;
|
||||
justify-content: center;
|
||||
align-items: flex-start;
|
||||
padding: 100rpx;
|
||||
vertical-align: middle;
|
||||
}
|
||||
|
||||
.img {
|
||||
border-radius: 50%;
|
||||
border: 1px solid #fff;
|
||||
background-color: #fff;
|
||||
margin: 0 0 60rpx;
|
||||
display: inline-block;
|
||||
width: 200rpx;
|
||||
height: 200rpx;
|
||||
line-height: 0;
|
||||
}
|
||||
|
||||
.title {
|
||||
display: inline-block;
|
||||
width: 100%;
|
||||
margin: 0 0 60rpx;
|
||||
}
|
||||
|
||||
.describe {
|
||||
color: #a7aaa9;
|
||||
font-size: 26rpx;
|
||||
margin: 0 0 60rpx;
|
||||
border-radius: 50%;
|
||||
text-align: center;
|
||||
display: inline-block;
|
||||
width: 100%;
|
||||
}
|
||||
|
||||
.btn {
|
||||
padding: 0 60rpx;
|
||||
background-color: #19be6b;
|
||||
margin: 20rpx 0 200rpx;
|
||||
text-align: center;
|
||||
vertical-align: middle;
|
||||
touch-action: manipulation;
|
||||
cursor: pointer;
|
||||
background-image: none;
|
||||
white-space: nowrap;
|
||||
user-select: none;
|
||||
font-size: 14px;
|
||||
border: 0 !important;
|
||||
position: relative;
|
||||
text-decoration: none;
|
||||
height: 44px;
|
||||
line-height: 44px;
|
||||
box-shadow: inset 0 0 0 1px #19be6b;
|
||||
background: #fff !important;
|
||||
color: #19be6b !important;
|
||||
display: inline-block;
|
||||
border-radius: 10rpx;
|
||||
}
|
|
@ -0,0 +1,570 @@
|
|||
// index.js
|
||||
// 获取应用实例
|
||||
let index = 0, // 当前点击图片的index
|
||||
items = [], // 图片数组信息
|
||||
itemId = 1, // 图片id,用于识别点击图片
|
||||
fliter = 'init', // 默认过滤类型(原图)
|
||||
shape = 'init'; // 默认形状(原图)
|
||||
const hCw = 1.62; // 图片宽高比
|
||||
const canvasPre = 1; // 展示的canvas占mask的百分比
|
||||
const maskCanvas = wx.createCanvasContext('maskCanvas', this); // 创建 canvas 的绘图上下文 CanvasContext 对象
|
||||
|
||||
const util = require('../../utils/util.js');
|
||||
var urlPath = require('../../config.js');
|
||||
Page({
|
||||
/**
|
||||
* 页面的初始数据
|
||||
*/
|
||||
data: {
|
||||
isLogin: false, //是否授权
|
||||
funBox:true,//功能框
|
||||
itemList: [],
|
||||
showBtn: false, //按钮
|
||||
showBox: false, //弹框
|
||||
titlelist: ['脸谱', '背景', '按钮', '川剧', '人物', '文字', '装饰'],
|
||||
titleIndex: '-1',
|
||||
allList: [
|
||||
'../../img/background/3.png',
|
||||
'../../img/background/3.png',
|
||||
'../../img/background/3.png',
|
||||
'../../img/background/3.png',
|
||||
'../../img/background/3.png',
|
||||
'../../img/background/3.png',
|
||||
'../../img/background/3.png',
|
||||
'../../img/background/3.png',
|
||||
],
|
||||
allIndex: '-1',
|
||||
faceImg: [
|
||||
'../../img/face/3.png',
|
||||
'../../img/face/4.png',
|
||||
'../../img/face/3.png',
|
||||
'../../img/face/3.png',
|
||||
],
|
||||
operaImg: [
|
||||
'../../img/opera/3.png',
|
||||
'../../img/opera/4.png',
|
||||
'../../img/opera/5.png',
|
||||
'../../img/opera/5.png',
|
||||
'../../img/opera/4.png',
|
||||
'../../img/opera/3.png',
|
||||
],
|
||||
backgroundImg: [
|
||||
'../../img/background/2.png',
|
||||
'../../img/background/3.png',
|
||||
'../../img/background/2.png',
|
||||
'../../img/background/3.png',
|
||||
],
|
||||
buttonImg: [
|
||||
'../../img/button/2.png',
|
||||
'../../img/button/1.png',
|
||||
'../../img/button/2.png',
|
||||
'../../img/button/1.png',
|
||||
],
|
||||
personageImg: [
|
||||
'../../img/personage/1.png',
|
||||
'../../img/personage/2.png',
|
||||
'../../img/personage/3.png',
|
||||
],
|
||||
wordImg: [
|
||||
'../../img/word/1.png',
|
||||
'../../img/word/2.png',
|
||||
'../../img/word/3.png',
|
||||
],
|
||||
decorateImg: [
|
||||
'../../img/decorate/1.png',
|
||||
'../../img/decorate/2.png',
|
||||
'../../img/decorate/3.png',
|
||||
],
|
||||
isOk:false,
|
||||
isNo:false
|
||||
},
|
||||
chooseTitle(e) {
|
||||
let that = this;
|
||||
if (that.data.titleIndex != e.currentTarget.dataset.index) {
|
||||
that.setData({
|
||||
allIndex: '-1'
|
||||
})
|
||||
}
|
||||
that.setData({
|
||||
titleIndex: e.currentTarget.dataset.index,
|
||||
showBox: true,
|
||||
showBtn: true
|
||||
})
|
||||
if (that.data.titlelist[that.data.titleIndex] == "脸谱") {
|
||||
that.setData({
|
||||
allList: that.data.faceImg
|
||||
})
|
||||
}
|
||||
if (that.data.titlelist[that.data.titleIndex] == "川剧") {
|
||||
that.setData({
|
||||
allList: that.data.operaImg
|
||||
})
|
||||
}
|
||||
if (that.data.titlelist[that.data.titleIndex] == "背景") {
|
||||
that.setData({
|
||||
allList: that.data.backgroundImg
|
||||
})
|
||||
}
|
||||
if (that.data.titlelist[that.data.titleIndex] == "按钮") {
|
||||
that.setData({
|
||||
allList: that.data.buttonImg
|
||||
})
|
||||
}
|
||||
if (that.data.titlelist[that.data.titleIndex] == "人物") {
|
||||
that.setData({
|
||||
allList: that.data.personageImg
|
||||
})
|
||||
}
|
||||
if (that.data.titlelist[that.data.titleIndex] == "文字") {
|
||||
that.setData({
|
||||
allList: that.data.wordImg
|
||||
})
|
||||
}
|
||||
if (that.data.titlelist[that.data.titleIndex] == "装饰") {
|
||||
that.setData({
|
||||
allList: that.data.decorateImg
|
||||
})
|
||||
}
|
||||
},
|
||||
chooseImg(e) {
|
||||
let that = this;
|
||||
that.setData({
|
||||
allIndex: e.currentTarget.dataset.index,
|
||||
showBox: false,
|
||||
showBtn: false
|
||||
})
|
||||
if (that.data.titleIndex == 1) {
|
||||
this.setBackGroundImg({
|
||||
url: that.data.backgroundImg[that.data.allIndex]
|
||||
});
|
||||
} else {
|
||||
that.setDropItem({
|
||||
url: that.data.allList[that.data.allIndex]
|
||||
});
|
||||
}
|
||||
},
|
||||
onShow: function() {
|
||||
if (typeof this.getTabBar === 'function' &&
|
||||
this.getTabBar()) {
|
||||
this.getTabBar().setData({
|
||||
selected: 0
|
||||
})
|
||||
}
|
||||
},
|
||||
/**
|
||||
* 生命周期函数--监听页面加载
|
||||
*/
|
||||
onLoad: function(options) {
|
||||
items = this.data.itemList;
|
||||
wx.getSystemInfo({ // 获取系统信息
|
||||
success: sysData => {
|
||||
this.sysData = sysData;
|
||||
// 设置画布宽高,this.sysData.windowWidth为屏幕的宽度
|
||||
this.setData({
|
||||
canvasWidth: this.sysData.windowWidth *canvasPre, // 如果觉得不清晰的话,可以把所有组件、宽高放大一倍
|
||||
canvasHeight: this.sysData.windowWidth * canvasPre * hCw,
|
||||
backGroundWidth: this.sysData.windowWidth,
|
||||
backGroundHeight: this.sysData.screenHeight
|
||||
})
|
||||
|
||||
}
|
||||
})
|
||||
this.setBackGroundImg({
|
||||
url: this.data.backgroundImg[0]
|
||||
});
|
||||
this.getBottleCategories();
|
||||
},
|
||||
// 上传图片
|
||||
uploadImg() {
|
||||
let that = this;
|
||||
wx.chooseImage({
|
||||
count: 1,
|
||||
sizeType: ['original', 'compressed'],
|
||||
sourceType: ['album', 'camera'],
|
||||
success(res) {
|
||||
// tempFilePath可以作为img标签的src属性显示图片
|
||||
that.setDropItem({
|
||||
url: res.tempFilePaths[0]
|
||||
});
|
||||
}
|
||||
})
|
||||
},
|
||||
// 设置背景图片
|
||||
setBackGroundImg(imgData) {
|
||||
console.log(imgData);
|
||||
let data = {}; // 存储图片信息
|
||||
// 获取图片信息,网络图片需先配置download域名才能生效
|
||||
wx.getImageInfo({
|
||||
src: imgData.url,
|
||||
success: res => {
|
||||
// 初始化数据
|
||||
let maxWidth = this.data.backGroundWidth,
|
||||
maxHeight = this.data.backGroundHeight; // 设置最大宽高
|
||||
console.log(maxWidth, maxHeight);
|
||||
if (res.width > maxWidth || res.height > maxHeight) { // 原图宽或高大于最大值就执行
|
||||
if (res.width / res.height > maxWidth / maxHeight) { // 判断比例使用最大值的宽或高作为基数计算
|
||||
data.width = maxWidth;
|
||||
data.height = Math.round(maxWidth * (res.height / res.width));
|
||||
} else {
|
||||
data.height = maxHeight;
|
||||
data.width = Math.round(maxHeight * (res.width / res.height));
|
||||
}
|
||||
}
|
||||
data.image = imgData.url; // 显示地址
|
||||
data.initImage = imgData.url; // 原始地址
|
||||
// data.id = ++itemId; // id
|
||||
data.id = 2; // id
|
||||
data.top = 0; // top定位
|
||||
data.left = 0; // left定位
|
||||
// 圆心坐标
|
||||
data.x = data.left + data.width / 2;
|
||||
data.y = data.top + data.height / 2;
|
||||
data.scale = 1; // scale缩放
|
||||
data.rotate = 1; // 旋转角度
|
||||
data.active = false; // 选中状态
|
||||
items[0] = data; // 每增加一张图片数据增加一条信息
|
||||
this.setData({
|
||||
itemList: items
|
||||
})
|
||||
}
|
||||
})
|
||||
},
|
||||
// 设置图片的信息
|
||||
setDropItem(imgData) {
|
||||
let data = {}; // 存储图片信息
|
||||
// 获取图片信息,网络图片需先配置download域名才能生效
|
||||
wx.getImageInfo({
|
||||
src: imgData.url,
|
||||
success: res => {
|
||||
// 初始化数据
|
||||
let maxWidth = 150,
|
||||
maxHeight = 150; // 设置最大宽高
|
||||
if (res.width > maxWidth || res.height > maxHeight) { // 原图宽或高大于最大值就执行
|
||||
if (res.width / res.height > maxWidth / maxHeight) { // 判断比例使用最大值的宽或高作为基数计算
|
||||
data.width = maxWidth;
|
||||
data.height = Math.round(maxWidth * (res.height / res.width));
|
||||
} else {
|
||||
data.height = maxHeight;
|
||||
data.width = Math.round(maxHeight * (res.width / res.height));
|
||||
}
|
||||
}
|
||||
data.image = imgData.url; // 显示地址
|
||||
data.initImage = imgData.url; // 原始地址
|
||||
data.id = ++itemId + 1; // id
|
||||
data.top = 10; // top定位
|
||||
data.left = 10; // left定位
|
||||
// 圆心坐标
|
||||
data.x = data.left + data.width / 2;
|
||||
data.y = data.top + data.height / 2;
|
||||
data.scale = 1; // scale缩放
|
||||
data.rotate = 1; // 旋转角度
|
||||
data.active = false; // 选中状态
|
||||
console.log(data);
|
||||
items[items.length] = data; // 每增加一张图片数据增加一条信息
|
||||
this.setData({
|
||||
itemList: items
|
||||
})
|
||||
}
|
||||
})
|
||||
},
|
||||
// 点击图片
|
||||
WraptouchStart: function(e) {
|
||||
if (e.currentTarget.dataset.id != 2) {
|
||||
// 循环图片数组获取点击的图片信息
|
||||
for (let i = 0; i < items.length; i++) {
|
||||
items[i].active = false;
|
||||
if (e.currentTarget.dataset.id == items[i].id) {
|
||||
index = i;
|
||||
items[index].active = true;
|
||||
}
|
||||
}
|
||||
this.setData({
|
||||
itemList: items
|
||||
})
|
||||
// 获取点击的坐标值
|
||||
items[index].lx = e.touches[0].clientX;
|
||||
items[index].ly = e.touches[0].clientY;
|
||||
}
|
||||
this.setData({
|
||||
showBox: false,
|
||||
funBox:false
|
||||
})
|
||||
},
|
||||
// 拖动图片
|
||||
WraptouchMove(e) {
|
||||
if (e.currentTarget.dataset.id != 2) {
|
||||
items[index]._lx = e.touches[0].clientX;
|
||||
items[index]._ly = e.touches[0].clientY;
|
||||
|
||||
items[index].left += items[index]._lx - items[index].lx;
|
||||
items[index].top += items[index]._ly - items[index].ly;
|
||||
items[index].x += items[index]._lx - items[index].lx;
|
||||
items[index].y += items[index]._ly - items[index].ly;
|
||||
|
||||
items[index].lx = e.touches[0].clientX;
|
||||
items[index].ly = e.touches[0].clientY;
|
||||
|
||||
this.setData({
|
||||
itemList: items,
|
||||
showBtn: true,
|
||||
funBox:false
|
||||
})
|
||||
}
|
||||
},
|
||||
// 放开图片
|
||||
WraptouchEnd() {
|
||||
this.synthesis(); // 调用合成图方法
|
||||
this.setData({
|
||||
showBtn: false,
|
||||
funBox:true
|
||||
})
|
||||
},
|
||||
// 点击伸缩图标
|
||||
oTouchStart(e) {
|
||||
//找到点击的那个图片对象,并记录
|
||||
for (let i = 0; i < items.length; i++) {
|
||||
items[i].active = false;
|
||||
if (e.currentTarget.dataset.id == items[i].id) {
|
||||
index = i;
|
||||
items[index].active = true;
|
||||
}
|
||||
}
|
||||
//获取作为移动前角度的坐标
|
||||
items[index].tx = e.touches[0].clientX;
|
||||
items[index].ty = e.touches[0].clientY;
|
||||
//移动前的角度
|
||||
items[index].anglePre = this.countDeg(items[index].x, items[index].y, items[index].tx, items[index].ty);
|
||||
//获取图片半径
|
||||
items[index].r = this.getDistancs(items[index].x, items[index].y, items[index].left, items[index].top);
|
||||
},
|
||||
oTouchMove: function(e) {
|
||||
//记录移动后的位置
|
||||
items[index]._tx = e.touches[0].clientX;
|
||||
items[index]._ty = e.touches[0].clientY;
|
||||
//移动的点到圆心的距离
|
||||
items[index].disPtoO = this.getDistancs(items[index].x, items[index].y, items[index]._tx, items[index]._ty - 10)
|
||||
|
||||
items[index].scale = items[index].disPtoO / items[index].r;
|
||||
|
||||
//移动后位置的角度
|
||||
items[index].angleNext = this.countDeg(items[index].x, items[index].y, items[index]._tx, items[index]._ty)
|
||||
//角度差
|
||||
items[index].new_rotate = items[index].angleNext - items[index].anglePre;
|
||||
|
||||
//叠加的角度差
|
||||
items[index].rotate += items[index].new_rotate;
|
||||
items[index].angle = items[index].rotate; //赋值
|
||||
|
||||
//用过移动后的坐标赋值为移动前坐标
|
||||
items[index].tx = e.touches[0].clientX;
|
||||
items[index].ty = e.touches[0].clientY;
|
||||
items[index].anglePre = this.countDeg(items[index].x, items[index].y, items[index].tx, items[index].ty)
|
||||
|
||||
//赋值setData渲染
|
||||
this.setData({
|
||||
itemList: items
|
||||
})
|
||||
},
|
||||
// 计算坐标点到圆心的距离
|
||||
getDistancs(cx, cy, pointer_x, pointer_y) {
|
||||
this.setData({
|
||||
showBtn: true,
|
||||
funBox:false
|
||||
})
|
||||
var ox = pointer_x - cx;
|
||||
var oy = pointer_y - cy;
|
||||
return Math.sqrt(
|
||||
ox * ox + oy * oy
|
||||
);
|
||||
},
|
||||
/*
|
||||
*参数cx和cy为图片圆心坐标
|
||||
*参数pointer_x和pointer_y为手点击的坐标
|
||||
*返回值为手点击的坐标到圆心的角度
|
||||
*/
|
||||
countDeg: function(cx, cy, pointer_x, pointer_y) {
|
||||
var ox = pointer_x - cx;
|
||||
var oy = pointer_y - cy;
|
||||
var to = Math.abs(ox / oy);
|
||||
var angle = Math.atan(to) / (2 * Math.PI) * 360;
|
||||
if (ox < 0 && oy < 0) //相对在左上角,第四象限,js中坐标系是从左上角开始的,这里的象限是正常坐标系
|
||||
{
|
||||
angle = -angle;
|
||||
} else if (ox <= 0 && oy >= 0) //左下角,3象限
|
||||
{
|
||||
angle = -(180 - angle)
|
||||
} else if (ox > 0 && oy < 0) //右上角,1象限
|
||||
{
|
||||
angle = angle;
|
||||
} else if (ox > 0 && oy > 0) //右下角,2象限
|
||||
{
|
||||
angle = 180 - angle;
|
||||
}
|
||||
return angle;
|
||||
},
|
||||
// 删除
|
||||
deleteItem: function(e) {
|
||||
let newList = [];
|
||||
for (let i = 0; i < items.length; i++) {
|
||||
if (e.currentTarget.dataset.id != items[i].id) {
|
||||
newList.push(items[i])
|
||||
}
|
||||
}
|
||||
if (newList.length > 1) { //大于0背景图可被删除,大于1背景图不能被删除
|
||||
newList[newList.length - 1].active = true; // 剩下图片组最后一个选中
|
||||
}
|
||||
items = newList;
|
||||
this.setData({
|
||||
itemList: items
|
||||
})
|
||||
},
|
||||
// 打开遮罩层
|
||||
openMask() {
|
||||
this.synthesis();
|
||||
this.setData({
|
||||
showCanvas: true
|
||||
})
|
||||
},
|
||||
synthesis() { // 合成图片
|
||||
maskCanvas.save();
|
||||
maskCanvas.beginPath();
|
||||
// 画背景色(白色)
|
||||
maskCanvas.setFillStyle('#fff');
|
||||
maskCanvas.fillRect(0, 0, this.data.canvasWidth, this.data.backGroundHeight);
|
||||
console.log(this.data.canvasWidth, this.data.backGroundHeight);
|
||||
items.forEach((currentValue, index) => {
|
||||
maskCanvas.save();
|
||||
maskCanvas.translate(0, 0);
|
||||
maskCanvas.beginPath();
|
||||
maskCanvas.translate(currentValue.x, currentValue.y); // 圆心坐标
|
||||
maskCanvas.rotate(currentValue.angle * Math.PI / 180);
|
||||
maskCanvas.translate(-(currentValue.width * currentValue.scale / 2), -(currentValue.height *currentValue.scale / 2))
|
||||
maskCanvas.drawImage(currentValue.image, 0, 0, currentValue.width * currentValue.scale,currentValue.height * currentValue.scale);
|
||||
maskCanvas.restore();
|
||||
})
|
||||
// reserve 参数为 false,则在本次调用绘制之前 native 层会先清空画布再继续绘制
|
||||
maskCanvas.draw(false, (e) => {
|
||||
wx.canvasToTempFilePath({
|
||||
canvasId: 'maskCanvas',
|
||||
success: res => {
|
||||
this.setData({
|
||||
canvasTemImg: res.tempFilePath
|
||||
})
|
||||
}
|
||||
}, this);
|
||||
})
|
||||
},
|
||||
// 关闭遮罩层
|
||||
disappearCanvas() {
|
||||
this.setData({
|
||||
showCanvas: false
|
||||
})
|
||||
},
|
||||
// 保存图片到系统相册
|
||||
saveImg: function() {
|
||||
if (wx.getStorageSync('token')) {
|
||||
wx.saveImageToPhotosAlbum({
|
||||
filePath: this.data.canvasTemImg,
|
||||
success: res => {
|
||||
wx.showToast({
|
||||
title: '保存成功',
|
||||
icon: "success"
|
||||
})
|
||||
},
|
||||
fail: res => {
|
||||
wx.openSetting({
|
||||
success: settingdata => {
|
||||
if (settingdata.authSetting['scope.writePhotosAlbum']) {
|
||||
console.log('获取权限成功,给出再次点击图片保存到相册的提示。')
|
||||
} else {
|
||||
console.log('获取权限失败,给出不给权限就无法正常使用的提示')
|
||||
}
|
||||
},
|
||||
fail: error => {
|
||||
console.log(error)
|
||||
}
|
||||
})
|
||||
wx.showModal({
|
||||
title: '提示',
|
||||
content: '保存失败,请确保相册权限已打开',
|
||||
})
|
||||
}
|
||||
})
|
||||
} else {
|
||||
this.setData({
|
||||
isLogin: true
|
||||
})
|
||||
}
|
||||
},
|
||||
shareImg() {
|
||||
if (wx.getStorageSync('token')) {
|
||||
wx.downloadFile({
|
||||
url: this.data.canvasTemImg,
|
||||
success: (res) => {
|
||||
wx.showShareImageMenu({
|
||||
path: res.tempFilePath
|
||||
})
|
||||
}
|
||||
})
|
||||
} else {
|
||||
this.setData({
|
||||
isLogin: true
|
||||
})
|
||||
}
|
||||
},
|
||||
chooseBtn(e) {
|
||||
let loginIndex = e.currentTarget.dataset.index;
|
||||
this.setData({
|
||||
isOk:false,
|
||||
isNo:false
|
||||
})
|
||||
loginIndex==1 ? this.setData({isOk:true}) : this.setData({isNo:true})
|
||||
},
|
||||
shouq(e) {
|
||||
wx.getUserProfile({ //获取用户昵称
|
||||
desc: '用于完善会员资料',
|
||||
success: (res) => {
|
||||
this.setData({
|
||||
userInfo: res.userInfo,
|
||||
isLogin: false
|
||||
})
|
||||
wx.showToast({title:'授权成功',icon:'none'})
|
||||
this.setData({isOk:false})
|
||||
wx.login({//调用授权登录
|
||||
success: res => {
|
||||
wx.request({
|
||||
url: urlPath.getopenid,
|
||||
method:'post',
|
||||
data: {
|
||||
code: res.code,
|
||||
wx_ame:this.data.userInfo.nickName,
|
||||
avater:this.data.userInfo.avatarUrl,
|
||||
},
|
||||
success(res) {
|
||||
console.log(res,1234);
|
||||
if (res.data.code == 0) {
|
||||
wx.setStorageSync('token', res.data.data.token);
|
||||
wx.setStorageSync('openid', res.data.data.openid);
|
||||
wx.setStorageSync('user', res.data.data.user);
|
||||
}
|
||||
}
|
||||
});
|
||||
}
|
||||
})
|
||||
},
|
||||
fail:(res)=>{
|
||||
wx.showToast({title:'授权失败',icon:'none'})
|
||||
this.setData({isOk:false})
|
||||
}
|
||||
})
|
||||
},
|
||||
getBottleCategories(){
|
||||
wx.request({
|
||||
url: urlPath.getBottleCategories,
|
||||
data: {},
|
||||
success(res) {
|
||||
console.log(res);
|
||||
}
|
||||
});
|
||||
}
|
||||
})
|
|
@ -0,0 +1,3 @@
|
|||
{
|
||||
"usingComponents": {}
|
||||
}
|
|
@ -0,0 +1,75 @@
|
|||
<!--index.wxml-->
|
||||
<view class='contentWarp'>
|
||||
<block wx:for="{{itemList}}" wx:key="id">
|
||||
<view class='touchWrap'
|
||||
style='transform: scale({{item.scale}});top:{{item.top}}px;left:{{item.left}}px; z-index:{{item.active?100:1}}'>
|
||||
<view class='imgWrap {{item.active? "touchActive":""}}'
|
||||
style="transform: rotate({{item.angle}}deg); border: {{item.active?4*item.oScale:0}}rpx #fff dashed;">
|
||||
<image src='{{item.image}}' data-id='{{item.id}}'
|
||||
style='width:{{item.width}}px;height:{{item.height}}px;' bindtouchstart='WraptouchStart'
|
||||
bindtouchmove='WraptouchMove' bindtouchend='WraptouchEnd' mode="widthFix"></image>
|
||||
<image class='x' src='../../img/close-icon.png'
|
||||
style='transform: scale({{item.oScale}});transform-origin:center;' data-id='{{item.id}}'
|
||||
bindtap='deleteItem'></image>
|
||||
<image class='o' src='../../img/zoom-icon.png'
|
||||
style='transform: scale({{item.oScale}});transform-origin:center;' data-id='{{item.id}}'
|
||||
bindtouchstart='oTouchStart' bindtouchmove='oTouchMove' bindtouchend='WraptouchEnd'></image>
|
||||
</view>
|
||||
</view>
|
||||
</block>
|
||||
</view>
|
||||
<!-- 保存显示效果图 -->
|
||||
<view class='canvasWrap' hidden="{{!showCanvas}}">
|
||||
<image class="resImg" bindlongtap="saveImg" src="{{canvasTemImg}}" mode="widthFix"></image>
|
||||
<view class='btn_view'>
|
||||
<button bindtap='saveImg'>保存到手机</button>
|
||||
<button bindtap='shareImg'>分享</button>
|
||||
<button bindtap='disappearCanvas'>关闭</button>
|
||||
</view>
|
||||
</view>
|
||||
<!-- 画布 -->
|
||||
<canvas class='maskCanvas' canvas-id="maskCanvas" style='width:{{canvasWidth}}px; height:{{canvasHeight}}px;'></canvas>
|
||||
<!-- 右下角操作按钮 -->
|
||||
<view class="operation-buttons {{showBtn?'closeSave':''}}">
|
||||
<!-- <image src="../../img/share-icon.png" bindtap="shareEv"></image> -->
|
||||
<image src="../../img/download-icon.png" bindtap="openMask"></image>
|
||||
</view>
|
||||
<!-- 我的作品 -->
|
||||
|
||||
<view wx:if="{{funBox}}" class="choose-box {{showBox?'showBox':''}}">
|
||||
<view>
|
||||
<scroll-view scroll-x="true">
|
||||
<view class="scrollView title-box">
|
||||
<view wx:for="{{titlelist}}" class="{{titleIndex==index?'titleActive':''}}" data-index="{{index}}" bindtap="chooseTitle" wx:key="index">{{item}}</view>
|
||||
</view>
|
||||
</scroll-view>
|
||||
</view>
|
||||
<view>
|
||||
<scroll-view scroll-x="true">
|
||||
<view class="scrollView img-box">
|
||||
<view wx:for="{{allList}}" data-index="{{index}}" bindtap="chooseImg" wx:key="index"><image class="{{allIndex==index?'allActive':''}}" mode="widthFix" src="{{item}}" lazy-load></image></view>
|
||||
</view>
|
||||
</scroll-view>
|
||||
</view>
|
||||
</view>
|
||||
<!-- 登录授权弹框 -->
|
||||
<view wx:if="{{isLogin}}" class="{{isAnimation==2?'card-box-userinfo':''}} auth-box">
|
||||
<view class="{{isAnimation==1?'card-box-userinfo':''}}">
|
||||
<view class="auth-top">
|
||||
<image src="../../img/robot.png" mode=""></image>
|
||||
<view class="auth-top-content">
|
||||
<view>提示:</view>
|
||||
<view>您当前是游客身份</view>
|
||||
<view>请授权登录后再进行保存、分享操作</view>
|
||||
</view>
|
||||
</view>
|
||||
<view class="auth-center">申请 获取你的昵称、头像、地区及性别</view>
|
||||
<view class="auth-bottom">
|
||||
<view bindtap="chooseBtn" data-index="0" class="{{isNo?'isNyin':'noyin'}} btn btn-no">暂不授权</view>
|
||||
<view bindtap="chooseBtn" data-index="1" class="{{isOk?'isOyin':'noyin'}} btn btn-yes">
|
||||
<text>立即授权</text>
|
||||
<button open-type="getUserInfo" bindtap="shouq" class="auth-btn">立即授权</button>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
|
@ -0,0 +1,256 @@
|
|||
/**index.wxss**/
|
||||
.contentWarp {
|
||||
position: absolute;
|
||||
width: 100%;
|
||||
height: 100%;
|
||||
top: 0;
|
||||
left: 0;
|
||||
bottom: 0;
|
||||
right: 0;
|
||||
margin: auto;
|
||||
overflow: hidden;
|
||||
}
|
||||
|
||||
.touchWrap {
|
||||
transform-origin: center;
|
||||
position: absolute;
|
||||
z-index: 100;
|
||||
}
|
||||
|
||||
.imgWrap {
|
||||
box-sizing: border-box;
|
||||
width: 100%;
|
||||
transform-origin: center;
|
||||
float: left;
|
||||
border: 5rpx transparent dashed;
|
||||
}
|
||||
|
||||
.imgWrap image {
|
||||
float: left;
|
||||
}
|
||||
|
||||
.touchActive .x {
|
||||
display: block;
|
||||
}
|
||||
|
||||
.touchActive .o {
|
||||
display: block;
|
||||
}
|
||||
|
||||
.x {
|
||||
position: absolute;
|
||||
top: -25rpx;
|
||||
left: -25rpx;
|
||||
z-index: 500;
|
||||
display: none;
|
||||
width: 50rpx;
|
||||
height: 50rpx;
|
||||
overflow: hidden;
|
||||
font-weight: bold;
|
||||
color: #d1e3f1;
|
||||
}
|
||||
|
||||
.o {
|
||||
position: absolute;
|
||||
bottom: -25rpx;
|
||||
right: -25rpx;
|
||||
width: 50rpx;
|
||||
height: 50rpx;
|
||||
text-align: center;
|
||||
display: none;
|
||||
overflow: hidden;
|
||||
font-weight: bold;
|
||||
color: #d1e3f1;
|
||||
}
|
||||
|
||||
.active {
|
||||
background-color: rgb(78, 114, 151);
|
||||
}
|
||||
|
||||
.active view {
|
||||
border: none;
|
||||
}
|
||||
|
||||
.touchActive {
|
||||
z-index: 400;
|
||||
}
|
||||
|
||||
.operation-buttons {
|
||||
position: absolute;
|
||||
bottom: 220rpx;
|
||||
right: 15rpx;
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
z-index: 101;
|
||||
transition: all .5s ease-in-out;
|
||||
}
|
||||
|
||||
.operation-buttons image {
|
||||
width: 74rpx;
|
||||
height: 80rpx;
|
||||
margin-top: 20rpx;
|
||||
}
|
||||
.closeSave {
|
||||
transform: scale(0);
|
||||
}
|
||||
.canvasWrap {
|
||||
position: absolute;
|
||||
width: 100%;
|
||||
height: 100%;
|
||||
top: 0;
|
||||
left: 0;
|
||||
background-color: rgba(0, 0, 0, 0.6);
|
||||
z-index: 999;
|
||||
text-align: center;
|
||||
}
|
||||
|
||||
.maskCanvas {
|
||||
position: absolute;
|
||||
left: -200%;
|
||||
top: 0;
|
||||
}
|
||||
|
||||
.btnView view {
|
||||
padding-bottom: 20rpx;
|
||||
}
|
||||
|
||||
.hand {
|
||||
position: absolute;
|
||||
left: 100rpx;
|
||||
right: 0;
|
||||
margin: auto;
|
||||
z-index: 100;
|
||||
}
|
||||
|
||||
.getUserInfoBtn {
|
||||
position: initial;
|
||||
border: none;
|
||||
background-color: none;
|
||||
}
|
||||
|
||||
.getUserInfoBtn::after {
|
||||
border: none;
|
||||
}
|
||||
|
||||
.btn_view {
|
||||
display: flex;
|
||||
padding: 20rpx;
|
||||
}
|
||||
|
||||
.btn_view button {
|
||||
width: 30%!important;
|
||||
padding: 16rpx 20rpx;
|
||||
font-size: 26rpx;
|
||||
background-color: #2a7be9;
|
||||
color: #fff;
|
||||
}
|
||||
/* 点击下载按钮时的图片样式 */
|
||||
.resImg {
|
||||
width: 80%;
|
||||
margin-top: 20rpx;
|
||||
}
|
||||
|
||||
/* 特效样式 */
|
||||
.fliters {
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
position: absolute;
|
||||
bottom: 382rpx;
|
||||
right: 120rpx;
|
||||
z-index: 201;
|
||||
}
|
||||
|
||||
.shapes {
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
position: absolute;
|
||||
bottom: 242rpx;
|
||||
right: 120rpx;
|
||||
z-index: 201;
|
||||
}
|
||||
|
||||
.fliters image,
|
||||
.shapes image {
|
||||
width: 60rpx;
|
||||
height: 60rpx;
|
||||
border: 2rpx solid #eb4985;
|
||||
}
|
||||
|
||||
|
||||
.choose-box {
|
||||
position: fixed;
|
||||
bottom: -250rpx;
|
||||
left: 0;
|
||||
right: 0;
|
||||
z-index: 998;
|
||||
background-color: rgba(0, 0, 0, .8);
|
||||
padding: 20rpx;
|
||||
transition: all .5s ease-in-out;
|
||||
}
|
||||
|
||||
.showBox {
|
||||
bottom: 88rpx;
|
||||
}
|
||||
|
||||
.scrollView {
|
||||
display: flex;
|
||||
}
|
||||
|
||||
.title-box view {
|
||||
background-color: rgba(0, 0, 0, 1);
|
||||
display: inline-block;
|
||||
padding: 15rpx 30rpx;
|
||||
border-radius: 10rpx;
|
||||
margin-bottom: 20rpx;
|
||||
margin-right: 20rpx;
|
||||
flex-shrink: 0;
|
||||
color: #fff;
|
||||
}
|
||||
|
||||
.title-box .titleActive {
|
||||
color: #000;
|
||||
background-color: rgba(255, 255, 255, 1);
|
||||
box-shadow: 0rpx 0rpx 20rpx rgba(255, 255, 255, .5);
|
||||
}
|
||||
|
||||
.img-box view {
|
||||
width: 25%;
|
||||
height: 320rpx;
|
||||
flex-shrink: 0;
|
||||
margin-right: 20rpx;
|
||||
background-color: rgba(0,0,0,.8);
|
||||
display: flex;
|
||||
align-items: center;
|
||||
}
|
||||
|
||||
.img-box view:last-child {
|
||||
margin-right: 0rpx;
|
||||
}
|
||||
|
||||
.img-box image {
|
||||
width: 100%;
|
||||
height: 320rpx;
|
||||
object-fit: contain;
|
||||
}
|
||||
|
||||
.img-box .allActive {
|
||||
transform: scale(.9);
|
||||
border: 4rpx dashed rgba(255, 255, 255, .4);
|
||||
box-shadow: 0rpx 0rpx 20rpx rgba(0, 0, 0, .8);
|
||||
}
|
||||
.auth-box {position: fixed;top: 0;right: 0;left: 0;bottom: 0;display: flex;justify-content: center;align-items: center;z-index: 1000;}
|
||||
.auth-box > view {background-color: #FFFFFF;border-radius: 10rpx;padding: 30rpx;box-shadow: 0rpx 0rpx 20rpx rgba(0,0,0,.5);margin: 0 100rpx;}
|
||||
.auth-top {display: flex;}
|
||||
.auth-top image {width: 96rpx;height: 96rpx;flex-shrink: 0;}
|
||||
.auth-top-content {margin-left: 20rpx;}
|
||||
.auth-top-content view {font-size: 28rpx;margin-top: 20rpx;color: #999999;}
|
||||
.auth-top-content view:nth-child(1) {font-size: 30rpx;font-weight: bold;margin-top: 0;}
|
||||
.auth-center {font-size: 28rpx;margin: 30rpx 0;border-bottom: 1rpx solid #F5F5F5;border-top: 1rpx solid #F5F5F5;padding: 20rpx 0;}
|
||||
.auth-bottom {display: flex;justify-content: center;align-items: center;font-size: 24rpx;}
|
||||
.btn {padding: 12rpx 40rpx;border-radius: 4rpx;}
|
||||
.btn-no {color: #2a7be9;background-color: #FFFFFF;border: 1rpx solid #2a7be9;}
|
||||
.btn-yes {color: #FFFFFF;background-color: #2a7be9;border: 1rpx solid #2a7be9;position: relative;margin-left: 20rpx;}
|
||||
.auth-btn {position: absolute;top: 0;left: 0;right: 0;bottom: 0;opacity: 0;}
|
||||
.isNyin{box-shadow: 0rpx 3rpx 6rpx rgba(0,0,0,.5);}
|
||||
.isOyin{box-shadow: 0rpx 3rpx 6rpx rgba(0,0,0,1);}
|
||||
.card-box-userinfo {transform: rotate(360deg) scale(0);transition: all 1s ease-in-out;}
|
|
@ -0,0 +1,438 @@
|
|||
// pages/index.js
|
||||
var urlPath = require('../../config.js');
|
||||
const app = getApp();
|
||||
Page({
|
||||
// 前往下一页
|
||||
picture(e) {
|
||||
wx.navigateTo({
|
||||
url: '../picture/picture?id=' + e.currentTarget.dataset.id
|
||||
});
|
||||
},
|
||||
rule() {
|
||||
wx.navigateTo({
|
||||
url: '../rule/rule'
|
||||
});
|
||||
},
|
||||
vote(e){
|
||||
var that = this;
|
||||
var id = e.currentTarget.dataset.id;
|
||||
if(id > 0){
|
||||
wx.request({
|
||||
url: urlPath.vote,
|
||||
header:{
|
||||
'token' : wx.getStorageSync('token')
|
||||
},
|
||||
data:{
|
||||
id : id
|
||||
},
|
||||
success(res){
|
||||
if(res.data.code == 0){
|
||||
wx.showToast({
|
||||
title: '投票成功'
|
||||
});
|
||||
that.onLoad();
|
||||
}else{
|
||||
wx.showToast({
|
||||
title:res.data.msg,
|
||||
icon:'none'
|
||||
});
|
||||
}
|
||||
}
|
||||
})
|
||||
}
|
||||
},
|
||||
personal(e) {
|
||||
wx.navigateTo({
|
||||
url: '../personal/personal?id=' + e.currentTarget.dataset.uid
|
||||
});
|
||||
},
|
||||
sign() {
|
||||
wx.navigateTo({ url: '../sign/sign' });
|
||||
},
|
||||
/**
|
||||
* 页面的初始数据
|
||||
*/
|
||||
data: {
|
||||
loadHidden : true, //
|
||||
img_url: wx.getStorageSync('img_url'),
|
||||
swiperCurrent:0,
|
||||
autoplay: false,
|
||||
interval: 3000,
|
||||
duration: 800,
|
||||
//倒计时数据
|
||||
endTime: '',
|
||||
tab_number: 0 ,//参与者
|
||||
tab_vote: 0,//投票数
|
||||
tab_visit: 0,//访问次数
|
||||
rule_text:['1、本次活动不收任何费用,不退稿。2、参赛作品需附有作品介绍,字数限100字以内。3、每位参赛者仅限提交不超过5幅3、每位参赛者仅限提交不超过5幅'],//活动规则
|
||||
//列表
|
||||
works_list: [],
|
||||
page : 1,
|
||||
pageSize : 6,
|
||||
rule:'',
|
||||
search_page:1,
|
||||
for_search:false,
|
||||
keyword:'',
|
||||
forMore:true,
|
||||
},
|
||||
swiperChange: function (e) {
|
||||
this.setData({
|
||||
swiperCurrent: e.detail.current
|
||||
})
|
||||
},
|
||||
/**
|
||||
* 生命周期函数--监听页面加载
|
||||
*/
|
||||
onLoad: function (options) {
|
||||
var that = this;
|
||||
that.setData({
|
||||
//倒计时数据
|
||||
endTime: '',
|
||||
tab_number: 0 ,//参与者
|
||||
tab_vote: 0,//投票数
|
||||
tab_visit: 0,//访问次数
|
||||
rule_text:['1、本次活动不收任何费用,不退稿。2、参赛作品需附有作品介绍,字数限100字以内。3、每位参赛者仅限提交不超过5幅3、每位参赛者仅限提交不超过5幅'],//活动规则
|
||||
//列表
|
||||
works_list: [],
|
||||
page : 1,
|
||||
pageSize : 20,
|
||||
});
|
||||
//登录状态
|
||||
wx.checkSession({
|
||||
success: function (res) {
|
||||
console.log("DDDDDDD");
|
||||
that.getVoteList();
|
||||
that.getSlideList();
|
||||
that.saveVisit();
|
||||
that.getBaseInfo();
|
||||
//var user = wx.getStorageSync('user') || [];
|
||||
},
|
||||
fail: function(){
|
||||
wx.login({
|
||||
success: res => {
|
||||
console.log(res);
|
||||
wx.request({
|
||||
url: urlPath.getopenid,
|
||||
data: {
|
||||
code: res.code
|
||||
},
|
||||
success(res) {
|
||||
console.log(res);
|
||||
if(res.data.code == 0){
|
||||
wx.setStorageSync('token', res.data.data.token);
|
||||
wx.setStorageSync('openid', res.data.data.openid);
|
||||
wx.setStorageSync('user', res.data.data.user);
|
||||
that.onLoad();
|
||||
}else{
|
||||
console.log(res.data.msg);
|
||||
}
|
||||
}
|
||||
});
|
||||
}
|
||||
})
|
||||
}
|
||||
});
|
||||
|
||||
|
||||
//that.countDown()//倒计时监听
|
||||
},
|
||||
saveVisit:function(){
|
||||
wx.request({
|
||||
url: urlPath.saveVisit,
|
||||
header:{
|
||||
'token': wx.getStorageSync('token')
|
||||
},
|
||||
method:'post',
|
||||
success(res){
|
||||
console.log(res);
|
||||
}
|
||||
});
|
||||
},
|
||||
// 倒计时
|
||||
countDown:function(){
|
||||
var that=this;
|
||||
var nowTime = new Date().getTime();//现在时间(时间戳)
|
||||
var endTime = new Date(that.data.endTime).getTime();//结束时间(时间戳)
|
||||
var time = (endTime-nowTime)/1000;//距离结束的毫秒数
|
||||
// 获取天、时、分、秒
|
||||
let day = parseInt(time / (60 * 60 * 24));
|
||||
let hou = parseInt(time % (60 * 60 * 24) / 3600);
|
||||
let min = parseInt(time % (60 * 60 * 24) % 3600 / 60);
|
||||
let sec = parseInt(time % (60 * 60 * 24) % 3600 % 60);
|
||||
day = that.timeFormin(day),
|
||||
hou = that.timeFormin(hou),
|
||||
min = that.timeFormin(min),
|
||||
sec = that.timeFormin(sec)
|
||||
that.setData({
|
||||
day: that.timeFormat(day),
|
||||
hou: that.timeFormat(hou),
|
||||
min: that.timeFormat(min),
|
||||
sec: that.timeFormat(sec)
|
||||
})
|
||||
// 每1000ms刷新一次
|
||||
if (time>0){
|
||||
that.setData({
|
||||
countDown: true
|
||||
})
|
||||
setTimeout(this.countDown, 1000);
|
||||
}else{
|
||||
that.setData({
|
||||
countDown:false
|
||||
})
|
||||
}
|
||||
},
|
||||
getSlideList:function(){
|
||||
var that = this;
|
||||
var slide_list = [];
|
||||
wx.request({
|
||||
url: urlPath.getSlideList,
|
||||
header:{
|
||||
'token': wx.getStorageSync('token')
|
||||
},
|
||||
success(res){
|
||||
if(res.data.code == 0){
|
||||
if(res.data.data.length > 0){
|
||||
res.data.data.forEach(function(item){
|
||||
slide_list.push(urlPath.host + item.src);
|
||||
});
|
||||
that.setData({
|
||||
img_url:slide_list
|
||||
});
|
||||
wx.setStorageSync('img_url', that.data.img_url);
|
||||
}
|
||||
}else{
|
||||
console.log(res.data.msg); //失败
|
||||
}
|
||||
}
|
||||
});
|
||||
},
|
||||
getVoteList:function(){
|
||||
var that = this;
|
||||
if(!that.data.forMore){
|
||||
return;
|
||||
}
|
||||
var vote_list = [];
|
||||
wx.request({
|
||||
url: urlPath.getVoteList,
|
||||
header:{
|
||||
'token' : wx.getStorageSync('token')
|
||||
},
|
||||
data:{
|
||||
page:that.data.page,
|
||||
page_size:that.data.pageSize
|
||||
},
|
||||
success(res){
|
||||
if(res.data.code == 0){
|
||||
if(res.data.data.length > 0){
|
||||
res.data.data.forEach(function(item){
|
||||
vote_list.push({
|
||||
ids: item.id,
|
||||
img: urlPath.host + item.pic,
|
||||
text: item.explain,
|
||||
name: item.user_name,
|
||||
number: item.votes,
|
||||
uid:item.uid
|
||||
});
|
||||
});
|
||||
that.setData({
|
||||
works_list:that.data.works_list.concat(vote_list)
|
||||
});
|
||||
that.setData({
|
||||
page : that.data.page + 1
|
||||
})
|
||||
}else{
|
||||
that.setData({
|
||||
forMore:false
|
||||
});
|
||||
}
|
||||
}else{
|
||||
console.log(res.data.msg); //失败
|
||||
}
|
||||
}
|
||||
})
|
||||
},
|
||||
loadChange:function(){
|
||||
var that = this;
|
||||
if(that.data.for_search){
|
||||
that.search();
|
||||
}else{
|
||||
that.getVoteList();
|
||||
}
|
||||
},
|
||||
//小于10的格式化函数(2变成02)
|
||||
timeFormat(param) {
|
||||
return param < 10 ? '0' + param : param;
|
||||
},
|
||||
//小于0的格式化函数(不会出现负数)
|
||||
timeFormin(param) {
|
||||
return param < 0 ? 0: param;
|
||||
},
|
||||
/**
|
||||
* 生命周期函数--监听页面初次渲染完成
|
||||
*/
|
||||
onReady: function () {
|
||||
},
|
||||
|
||||
/**
|
||||
* 生命周期函数--监听页面显示
|
||||
*/
|
||||
onShow: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 生命周期函数--监听页面隐藏
|
||||
*/
|
||||
onHide: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 生命周期函数--监听页面卸载
|
||||
*/
|
||||
onUnload: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 页面相关事件处理函数--监听用户下拉动作
|
||||
*/
|
||||
onPullDownRefresh: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 页面上拉触底事件的处理函数
|
||||
*/
|
||||
onReachBottom: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 用户点击右上角分享
|
||||
*/
|
||||
onShareAppMessage: function () {
|
||||
|
||||
},
|
||||
onShow:function(){
|
||||
if (typeof this.getTabBar === 'function' &&
|
||||
this.getTabBar()) {
|
||||
this.getTabBar().setData({
|
||||
selected: 1
|
||||
})
|
||||
}
|
||||
},
|
||||
getBaseInfo:function(){
|
||||
var that = this;
|
||||
wx.request({
|
||||
url: urlPath.getBaseInfo,
|
||||
header:{
|
||||
'token' : wx.getStorageSync('token')
|
||||
},
|
||||
success(res){
|
||||
if(res.data.code == 0){
|
||||
var voteNumber = res.data.data.voteNumber;
|
||||
var numberOfPeople = res.data.data.numberOfPeople;
|
||||
var vote = res.data.data.vote;
|
||||
that.setData({
|
||||
tab_number: numberOfPeople,
|
||||
tab_vote: voteNumber,
|
||||
endTime: vote.time,
|
||||
rule_text: vote.rule_text,
|
||||
tab_visit:vote.visits,
|
||||
rule: vote.rule
|
||||
});
|
||||
wx.setStorageSync('baseInfo', res.data.data);
|
||||
that.countDown()
|
||||
}else{
|
||||
console.log(res.data.msg); //失败
|
||||
}
|
||||
}
|
||||
})
|
||||
},
|
||||
search:function(){
|
||||
var that = this;
|
||||
if(that.data.keyword == ''){
|
||||
return;
|
||||
}
|
||||
if(!that.data.forMore){
|
||||
return;
|
||||
}
|
||||
wx.request({
|
||||
url: urlPath.search,
|
||||
data: {
|
||||
keyword: that.data.keyword,
|
||||
page:that.data.search_page,
|
||||
page_size:that.data.pageSize
|
||||
},
|
||||
header:{
|
||||
'token' : wx.getStorageSync('token')
|
||||
},
|
||||
success: function(res) {
|
||||
if(res.data.code == 0){
|
||||
var type = res.data.data.type;
|
||||
var items = res.data.data.items;
|
||||
if(type== 'int'){
|
||||
wx.navigateTo({
|
||||
url: '../picture/picture?id=' + items.id
|
||||
});
|
||||
}else if(type == 'string'){
|
||||
var vote_list = [];
|
||||
items.forEach(function(item){
|
||||
vote_list.push({
|
||||
ids: item.id,
|
||||
img: urlPath.host + item.pic,
|
||||
text: item.explain,
|
||||
name: item.user_name,
|
||||
number: item.votes,
|
||||
uid:item.uid
|
||||
});
|
||||
});
|
||||
if(that.data.search_page == 1){
|
||||
that.setData({
|
||||
works_list:vote_list,
|
||||
forMore:true
|
||||
});
|
||||
}else{
|
||||
that.setData({
|
||||
works_list:that.data.works_list.concat(vote_list)
|
||||
});
|
||||
}
|
||||
if(items.length < that.data.pageSize){
|
||||
that.setData({
|
||||
forMore: false
|
||||
});
|
||||
}
|
||||
that.setData({
|
||||
search_page : that.data.search_page + 1,
|
||||
for_search:true
|
||||
})
|
||||
}
|
||||
}else{
|
||||
wx.showToast({
|
||||
title: res.data.msg,
|
||||
icon: 'none',
|
||||
duration: 1500
|
||||
});
|
||||
}
|
||||
}
|
||||
});
|
||||
},
|
||||
goSearch:function(e){
|
||||
var that = this;
|
||||
var formData = e.detail.value;
|
||||
if (formData) {
|
||||
that.setData({
|
||||
keyword:formData,
|
||||
forMore: true
|
||||
});
|
||||
that.search();
|
||||
} else {
|
||||
wx.showToast({
|
||||
title: '输入不能为空',
|
||||
icon: 'none',
|
||||
duration: 1500
|
||||
});
|
||||
}
|
||||
}
|
||||
})
|
|
@ -0,0 +1,3 @@
|
|||
{
|
||||
"usingComponents": {}
|
||||
}
|
|
@ -0,0 +1,84 @@
|
|||
<!--pages/index.wxml-->
|
||||
<view class="container">
|
||||
<scroll-view class="scroll-height" scroll-y='true' bindscrolltolower='loadChange' lower-threshold="1">
|
||||
<view class="page-body">
|
||||
<view class="page-section page-section-spacing swiper">
|
||||
<swiper autoplay="true" interval="{{interval}}" duration="{{duration}}" circular="true"
|
||||
current="{{swiperCurrent}}" bindchange="swiperChange">
|
||||
<block wx:for="{{img_url}}" wx:key="index">
|
||||
<swiper-item>
|
||||
<view class="swiper-item">
|
||||
<image src="{{item}}"></image>
|
||||
</view>
|
||||
</swiper-item>
|
||||
</block>
|
||||
</swiper>
|
||||
</view>
|
||||
<view class="dots">
|
||||
<block wx:for="{{img_url}}" wx:key="unique">
|
||||
<view class="dot{{index == swiperCurrent ? ' active' : ''}}"></view>
|
||||
</block>
|
||||
</view>
|
||||
</view>
|
||||
<!--内容-->
|
||||
<view class="view-bg top40">
|
||||
<view class="countdown">
|
||||
<view class="names">
|
||||
<text>距离投票结束还有</text>
|
||||
</view>
|
||||
<view class="time">
|
||||
<text>{{day}}</text>天 <text>{{hou}}</text>时<text>{{min}}</text>分<text>{{sec}}</text>秒
|
||||
</view>
|
||||
<view class="tab">
|
||||
<view class="list">
|
||||
{{tab_number}}<text>人</text>
|
||||
<text>参与者</text>
|
||||
</view>
|
||||
<view class="list">
|
||||
{{tab_vote}}<text>票</text>
|
||||
<text>投票数</text>
|
||||
</view>
|
||||
<view class="list">
|
||||
{{tab_visit}}<text>次</text>
|
||||
<text>访问量</text>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
<!--规则-->
|
||||
<view class="search">
|
||||
<input type="text" class="search-int" bindconfirm='goSearch' placeholder="请输入选手姓名或作品编号" />
|
||||
</view>
|
||||
|
||||
<!--作品列表-->
|
||||
<view class="works">
|
||||
<block wx:for="{{works_list}}" wx:key="index">
|
||||
<view class="list">
|
||||
<view class="img" bindtap='picture' data-id="{{item.ids}}">
|
||||
<view class="id">{{item.ids}}<text>号</text></view>
|
||||
<image mode="aspectFill" src="{{item.img}}"></image>
|
||||
</view>
|
||||
<view class="text">
|
||||
简介:{{item.text}}
|
||||
</view>
|
||||
<view class="name" bindtap="personal" data-uid="{{item.uid}}">
|
||||
{{item.name}} <text>{{item.number}}</text>
|
||||
</view>
|
||||
<button class="add" bindtap='vote' data-id="{{item.ids}}">
|
||||
投票
|
||||
</button>
|
||||
</view>
|
||||
</block>
|
||||
</view>
|
||||
</view>
|
||||
<view style="padding:40rpx;text-align:center;font-size:24rpx;" wx:if="{{!forMore}}">没有更多内容</view>
|
||||
<!--报名-->
|
||||
|
||||
<!--view class="signup" bindtap="sign">
|
||||
我要报名
|
||||
</view-->
|
||||
<view class=" sign-rule" bindtap="rule">
|
||||
活动规则
|
||||
</view>
|
||||
<!---->
|
||||
</scroll-view>
|
||||
</view>
|
|
@ -0,0 +1,136 @@
|
|||
/* pages/index.wxss */
|
||||
.container{
|
||||
padding-bottom: 120rpx;
|
||||
}
|
||||
.page-body{
|
||||
height: 300rpx;
|
||||
position: relative;
|
||||
}
|
||||
.swiper-item image{
|
||||
width: 100%;
|
||||
height: 300rpx;
|
||||
}
|
||||
.dots{
|
||||
display: inline-block;
|
||||
position: absolute;
|
||||
bottom: 20rpx;
|
||||
right: 0;
|
||||
padding: 0 20rpx;
|
||||
}
|
||||
.dots .dot{
|
||||
width: 8rpx;
|
||||
height: 8rpx;
|
||||
background: #fff;
|
||||
float: left;
|
||||
margin:0 4rpx;
|
||||
border-radius: 50%;
|
||||
}
|
||||
.dots .dot.active{
|
||||
background: #2a8de9;
|
||||
}
|
||||
.rule{
|
||||
padding: 40rpx 90rpx 0;
|
||||
font-size: 23rpx;
|
||||
text-align: left;
|
||||
color: #8c8c8c;
|
||||
line-height: 32rpx;
|
||||
}
|
||||
.rule text:first-child{
|
||||
display: -webkit-box;
|
||||
overflow: hidden;
|
||||
text-overflow: ellipsis;
|
||||
word-wrap: break-word;
|
||||
white-space: normal !important;
|
||||
-webkit-line-clamp: 3;
|
||||
-webkit-box-orient: vertical;
|
||||
}
|
||||
.rule .rule-more{
|
||||
color: #2a8de9;
|
||||
}
|
||||
/**/
|
||||
.scroll-height{
|
||||
height: 100vh;
|
||||
}
|
||||
.works{
|
||||
padding: 0 24rpx;
|
||||
}
|
||||
.works .list{
|
||||
width:calc((100% - 20rpx) / 2);
|
||||
float: left;
|
||||
margin-top: 30rpx;
|
||||
}
|
||||
.works .list:nth-child(2n){
|
||||
float: right;
|
||||
}
|
||||
.works .list .img{
|
||||
padding: 16rpx;
|
||||
width: 100%;
|
||||
position: relative;
|
||||
}
|
||||
.works .list .img .id{
|
||||
width: 61rpx;
|
||||
height: 72rpx;
|
||||
position: absolute;
|
||||
left: 0;
|
||||
top: 0;
|
||||
font-size: 24rpx;
|
||||
color: #fff;
|
||||
text-align: center;
|
||||
background: url() no-repeat top center;
|
||||
background-size:61rpx 72rpx ;
|
||||
}
|
||||
.works .list .img .id text{
|
||||
display: block;
|
||||
margin-top: -5rpx;
|
||||
}
|
||||
.works .list .img image{
|
||||
width: 277rpx;
|
||||
height: 256rpx;
|
||||
}
|
||||
.works .list .text{
|
||||
display: -webkit-box;
|
||||
overflow: hidden;
|
||||
text-overflow: ellipsis;
|
||||
word-wrap: break-word;
|
||||
white-space: normal !important;
|
||||
-webkit-line-clamp: 1;
|
||||
-webkit-box-orient: vertical;
|
||||
font-size: 22rpx;
|
||||
color: #8c8c8c;
|
||||
padding:0 16rpx;
|
||||
}
|
||||
.works .list .name{
|
||||
font-size: 30rpx;
|
||||
color: #333333;
|
||||
display: inline-block;
|
||||
width: 100%;
|
||||
padding: 16rpx;
|
||||
vertical-align: top;
|
||||
}
|
||||
.works .list .name text{
|
||||
float: right;
|
||||
color: #ff1a1a;
|
||||
}
|
||||
.works .list .add{
|
||||
width: 100%;
|
||||
height: 58rpx;
|
||||
line-height: 58rpx;
|
||||
background:#ffc103;
|
||||
padding: 0;
|
||||
border-radius: 0;
|
||||
color: #fff;
|
||||
font-size: 30rpx;
|
||||
}
|
||||
.search{
|
||||
padding: 20rpx 24rpx;
|
||||
}
|
||||
.search .search-int{
|
||||
background: url() #ebebeb no-repeat;
|
||||
background-size: 34rpx 36rpx;
|
||||
background-position: 580rpx center;
|
||||
height: 60rpx;
|
||||
border-radius: 30rpx;
|
||||
padding-right: 80rpx;
|
||||
padding-left: 30rpx;
|
||||
font-size: 24rpx;
|
||||
}
|
|
@ -0,0 +1,217 @@
|
|||
// pages/picture/picture.js
|
||||
Page({
|
||||
|
||||
// 前往下一页
|
||||
picture() {
|
||||
wx.navigateTo({ url: '../picture/picture' });
|
||||
},
|
||||
/**
|
||||
* 页面的初始数据
|
||||
*/
|
||||
data: {
|
||||
img_url:wx.getStorageSync('img_url'),
|
||||
swiperCurrent:0,
|
||||
autoplay: false,
|
||||
interval: 3000,
|
||||
duration: 800,
|
||||
//数据
|
||||
name:"王凯杰",
|
||||
nm_number:"237",
|
||||
//列表
|
||||
works_list:[],
|
||||
user_id:''
|
||||
},
|
||||
swiperChange: function (e) {
|
||||
// console.log(e);
|
||||
this.setData({
|
||||
swiperCurrent: e.detail.current
|
||||
})
|
||||
},
|
||||
|
||||
/**
|
||||
* 生命周期函数--监听页面加载
|
||||
*/
|
||||
onLoad: function (options) {
|
||||
var that = this;
|
||||
that.countDown()
|
||||
var userId = options.id;
|
||||
that.setData({
|
||||
user_id: userId,
|
||||
img_url:wx.getStorageSync('img_url'),
|
||||
});
|
||||
that.getUserInfo(userId);
|
||||
that.getUserProduction(userId);
|
||||
},
|
||||
getUserProduction:function(userId){
|
||||
var that = this;
|
||||
wx.request({
|
||||
url: wx.getStorageSync('urlPath').getUserProduction,
|
||||
header:{
|
||||
'token' : wx.getStorageSync('token')
|
||||
},
|
||||
data:{
|
||||
user_id: userId
|
||||
},
|
||||
success(res){
|
||||
if(res.data.code == 0){
|
||||
if(res.data.data.length > 0){
|
||||
var vote_list = [];
|
||||
var urlPath = wx.getStorageSync('urlPath');
|
||||
res.data.data.forEach(function(item){
|
||||
vote_list.push({
|
||||
ids: item.id,
|
||||
img: urlPath.host + item.pic,
|
||||
text: item.explain,
|
||||
name: item.user_name,
|
||||
number: item.votes,
|
||||
uid:item.uid
|
||||
});
|
||||
});
|
||||
that.setData({
|
||||
works_list:vote_list
|
||||
});
|
||||
}
|
||||
}
|
||||
}
|
||||
})
|
||||
},
|
||||
getUserInfo:function(userId){
|
||||
var that = this;
|
||||
wx.request({
|
||||
url: wx.getStorageSync('urlPath').getUserById,
|
||||
header:{
|
||||
'token' : wx.getStorageSync('token')
|
||||
},
|
||||
data:{
|
||||
user_id: userId
|
||||
},
|
||||
success(res){
|
||||
if(res.data.code == 0){
|
||||
console.log(res.data.data);
|
||||
that.setData({
|
||||
name:res.data.data.name,
|
||||
nm_number:res.data.data.allVoteNumber
|
||||
});
|
||||
}
|
||||
}
|
||||
})
|
||||
},
|
||||
// 倒计时
|
||||
countDown:function(){
|
||||
var that=this;
|
||||
var nowTime = new Date().getTime();//现在时间(时间戳)
|
||||
var endTime = new Date(that.data.endTime).getTime();//结束时间(时间戳)
|
||||
var time = (endTime-nowTime)/1000;//距离结束的毫秒数
|
||||
// 获取天、时、分、秒
|
||||
let day = parseInt(time / (60 * 60 * 24));
|
||||
let hou = parseInt(time % (60 * 60 * 24) / 3600);
|
||||
let min = parseInt(time % (60 * 60 * 24) % 3600 / 60);
|
||||
let sec = parseInt(time % (60 * 60 * 24) % 3600 % 60);
|
||||
// console.log(day + "," + hou + "," + min + "," + sec)
|
||||
day = that.timeFormin(day),
|
||||
hou = that.timeFormin(hou),
|
||||
min = that.timeFormin(min),
|
||||
sec = that.timeFormin(sec)
|
||||
that.setData({
|
||||
day: that.timeFormat(day),
|
||||
hou: that.timeFormat(hou),
|
||||
min: that.timeFormat(min),
|
||||
sec: that.timeFormat(sec)
|
||||
})
|
||||
// 每1000ms刷新一次
|
||||
if (time>0){
|
||||
that.setData({
|
||||
countDown: true
|
||||
})
|
||||
setTimeout(this.countDown, 1000);
|
||||
}else{
|
||||
that.setData({
|
||||
countDown:false
|
||||
})
|
||||
}
|
||||
},
|
||||
//小于10的格式化函数(2变成02)
|
||||
timeFormat(param) {
|
||||
return param < 10 ? '0' + param : param;
|
||||
},
|
||||
//小于0的格式化函数(不会出现负数)
|
||||
timeFormin(param) {
|
||||
return param < 0 ? 0: param;
|
||||
},
|
||||
/**
|
||||
* 生命周期函数--监听页面初次渲染完成
|
||||
*/
|
||||
onReady: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 生命周期函数--监听页面显示
|
||||
*/
|
||||
onShow: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 生命周期函数--监听页面隐藏
|
||||
*/
|
||||
onHide: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 生命周期函数--监听页面卸载
|
||||
*/
|
||||
onUnload: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 页面相关事件处理函数--监听用户下拉动作
|
||||
*/
|
||||
onPullDownRefresh: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 页面上拉触底事件的处理函数
|
||||
*/
|
||||
onReachBottom: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 用户点击右上角分享
|
||||
*/
|
||||
onShareAppMessage: function () {
|
||||
|
||||
},
|
||||
vote(e){
|
||||
var that = this;
|
||||
var id = e.currentTarget.dataset.id;
|
||||
if(id > 0){
|
||||
wx.request({
|
||||
url: wx.getStorageSync('urlPath').vote,
|
||||
header:{
|
||||
'token' : wx.getStorageSync('token')
|
||||
},
|
||||
data:{
|
||||
id : id
|
||||
},
|
||||
success(res){
|
||||
if(res.data.code == 0){
|
||||
wx.showToast({
|
||||
title: '投票成功'
|
||||
});
|
||||
that.onLoad({id:that.data.user_id});
|
||||
}else{
|
||||
wx.showToast({
|
||||
title:res.data.msg,
|
||||
icon:'none'
|
||||
});
|
||||
}
|
||||
}
|
||||
})
|
||||
}
|
||||
},
|
||||
})
|
|
@ -0,0 +1,3 @@
|
|||
{
|
||||
"usingComponents": {}
|
||||
}
|
|
@ -0,0 +1,52 @@
|
|||
<!--pages/personal/personal.wxml-->
|
||||
<view class="container">
|
||||
<view class="page-body">
|
||||
<view class="page-section page-section-spacing swiper">
|
||||
<swiper autoplay="true" interval="{{interval}}" duration="{{duration}}"
|
||||
circular="true" current="{{swiperCurrent}}" bindchange="swiperChange">
|
||||
<block wx:for="{{img_url}}" >
|
||||
<swiper-item>
|
||||
<view class="swiper-item">
|
||||
<image src="{{item}}"></image>
|
||||
</view>
|
||||
</swiper-item>
|
||||
</block>
|
||||
</swiper>
|
||||
</view>
|
||||
<view class="dots">
|
||||
<block wx:for="{{img_url}}" wx:key="unique">
|
||||
<view class="dot{{index == swiperCurrent ? ' active' : ''}}"></view>
|
||||
</block>
|
||||
</view>
|
||||
</view>
|
||||
<!--内容-->
|
||||
|
||||
<view class="view-bg top40">
|
||||
<view class="personal-name">
|
||||
{{name}} <text>{{nm_number}}票</text>
|
||||
</view>
|
||||
<!--作品列表-->
|
||||
<view class="works">
|
||||
<block wx:for="{{works_list}}" >
|
||||
<view class="list">
|
||||
<view class="img" bindtap='picture'>
|
||||
<view class="id">{{item.ids}}<text>号</text></view>
|
||||
<image mode="aspectFill" src="{{item.img}}"></image>
|
||||
</view>
|
||||
<view class="personal-right">
|
||||
<view class="text">
|
||||
简介:{{item.text}}
|
||||
</view>
|
||||
<view class="name">
|
||||
<text>{{item.number}}</text>
|
||||
</view>
|
||||
<button class="add" bindtap="vote" data-id="{{item.ids}}">
|
||||
投票
|
||||
</button>
|
||||
</view>
|
||||
</view>
|
||||
</block>
|
||||
</view>
|
||||
</view>
|
||||
|
||||
</view>
|
|
@ -0,0 +1,117 @@
|
|||
/* pages/personal/personal.wxss */
|
||||
.page-body{
|
||||
height: 300rpx;
|
||||
position: relative;
|
||||
}
|
||||
.swiper-item image{
|
||||
width: 100%;
|
||||
height: 300rpx;
|
||||
}
|
||||
.dots{
|
||||
display: inline-block;
|
||||
position: absolute;
|
||||
bottom: 20rpx;
|
||||
right: 0;
|
||||
padding: 0 20rpx;
|
||||
}
|
||||
.dots .dot{
|
||||
width: 8rpx;
|
||||
height: 8rpx;
|
||||
background: #fff;
|
||||
float: left;
|
||||
margin:0 4rpx;
|
||||
border-radius: 50%;
|
||||
}
|
||||
.dots .dot.active{
|
||||
background: #2a8de9;
|
||||
}
|
||||
/**/
|
||||
.personal-name{
|
||||
font-size: 40rpx;
|
||||
width: 100%;
|
||||
text-align: center;
|
||||
background-color: #2a8de9;
|
||||
color: #fff;
|
||||
padding: 30rpx 0;
|
||||
}
|
||||
.personal-name text{
|
||||
position: relative;
|
||||
margin-left: 10px;
|
||||
padding-left: 10px;
|
||||
font-size: 28rpx;
|
||||
}
|
||||
.personal-name text::after{
|
||||
position: absolute;
|
||||
width: 1px;
|
||||
height: 33rpx;
|
||||
content: '';
|
||||
left: 0;
|
||||
top: 50%;
|
||||
margin-top: -15rpx;
|
||||
background-color: #fff;
|
||||
}
|
||||
/**/
|
||||
.works{
|
||||
padding: 0 24rpx;
|
||||
}
|
||||
.works .list{
|
||||
width:100% ;
|
||||
float: left;
|
||||
display: inline-block;
|
||||
margin-top: 30rpx;
|
||||
padding: 0 30rpx;
|
||||
}
|
||||
.works .list .img{
|
||||
padding: 16rpx;
|
||||
width: 50%;
|
||||
position: relative;
|
||||
float: left;
|
||||
}
|
||||
.works .list .img image{
|
||||
width: 277rpx;
|
||||
height: 256rpx;
|
||||
}
|
||||
.works .list .img .id{
|
||||
width: 61rpx;
|
||||
height: 72rpx;
|
||||
position: absolute;
|
||||
left: 0;
|
||||
top: 0;
|
||||
font-size: 24rpx;
|
||||
color: #fff;
|
||||
text-align: center;
|
||||
background: url() no-repeat top center;
|
||||
background-size:61rpx 72rpx ;
|
||||
}
|
||||
.personal-right{
|
||||
float: left;
|
||||
width: 50%;
|
||||
padding: 16rpx 0 0 20rpx;
|
||||
}
|
||||
.personal-right .text{
|
||||
font-size: 28rpx;
|
||||
display: -webkit-box;
|
||||
overflow: hidden;
|
||||
text-overflow: ellipsis;
|
||||
word-wrap: break-word;
|
||||
white-space: normal !important;
|
||||
-webkit-line-clamp: 2;
|
||||
-webkit-box-orient: vertical;
|
||||
color: #8c8c8c;
|
||||
}
|
||||
.personal-right .name{
|
||||
padding: 20rpx 0;
|
||||
font-size: 30rpx;
|
||||
color: #ff1a1a;
|
||||
margin-bottom: 30rpx;
|
||||
}
|
||||
.personal-right .add{
|
||||
width: 100%;
|
||||
height: 58rpx;
|
||||
line-height: 58rpx;
|
||||
background:#ffc103;
|
||||
padding: 0;
|
||||
border-radius: 0;
|
||||
color: #fff;
|
||||
font-size: 30rpx;
|
||||
}
|
|
@ -0,0 +1,202 @@
|
|||
// pages/picture/picture.js
|
||||
var urlPath = require('../../config.js');
|
||||
Page({
|
||||
// 前往下一页
|
||||
personal() {
|
||||
wx.navigateTo({ url: '../personal/personal' });
|
||||
},
|
||||
sign() {
|
||||
wx.navigateTo({ url: '../sign/sign' });
|
||||
},
|
||||
/**
|
||||
* 页面的初始数据
|
||||
*/
|
||||
data: {
|
||||
img_url:wx.getStorageSync('img_url'),
|
||||
swiperCurrent:0,
|
||||
autoplay: false,
|
||||
interval: 3000,
|
||||
duration: 800,
|
||||
//倒计时数据
|
||||
endTime: '2020/11/22 10:40:30',
|
||||
//
|
||||
tab_number:31,//参与者
|
||||
tab_vote:2375,//投票数
|
||||
tab_visit:55,//访问次数
|
||||
//
|
||||
ids:'22',
|
||||
img:'../../img/img_03.png',
|
||||
text:'擅长记录身边的人与事!',
|
||||
name:'王凯杰',
|
||||
number:'78',
|
||||
},
|
||||
swiperChange: function (e) {
|
||||
// console.log(e);
|
||||
this.setData({
|
||||
swiperCurrent: e.detail.current
|
||||
})
|
||||
},
|
||||
|
||||
/**
|
||||
* 生命周期函数--监听页面加载
|
||||
*/
|
||||
onLoad: function (options) {
|
||||
var that = this;
|
||||
var baseInfo = wx.getStorageSync('baseInfo');
|
||||
that.setData({
|
||||
tab_number: baseInfo.numberOfPeople,
|
||||
tab_vote: baseInfo.voteNumber,
|
||||
endTime: baseInfo.vote.time,
|
||||
rule_text: baseInfo.vote.rule_text,
|
||||
tab_visit:baseInfo.vote.visits,
|
||||
img_url:wx.getStorageSync('img_url'),
|
||||
});
|
||||
that.countDown();
|
||||
console.log(options);
|
||||
that.getDetail(options.id);
|
||||
},
|
||||
// 倒计时
|
||||
countDown:function(){
|
||||
var that=this;
|
||||
var nowTime = new Date().getTime();//现在时间(时间戳)
|
||||
var endTime = new Date(that.data.endTime).getTime();//结束时间(时间戳)
|
||||
var time = (endTime-nowTime)/1000;//距离结束的毫秒数
|
||||
// 获取天、时、分、秒
|
||||
let day = parseInt(time / (60 * 60 * 24));
|
||||
let hou = parseInt(time % (60 * 60 * 24) / 3600);
|
||||
let min = parseInt(time % (60 * 60 * 24) % 3600 / 60);
|
||||
let sec = parseInt(time % (60 * 60 * 24) % 3600 % 60);
|
||||
// console.log(day + "," + hou + "," + min + "," + sec)
|
||||
day = that.timeFormin(day),
|
||||
hou = that.timeFormin(hou),
|
||||
min = that.timeFormin(min),
|
||||
sec = that.timeFormin(sec)
|
||||
that.setData({
|
||||
day: that.timeFormat(day),
|
||||
hou: that.timeFormat(hou),
|
||||
min: that.timeFormat(min),
|
||||
sec: that.timeFormat(sec)
|
||||
})
|
||||
// 每1000ms刷新一次
|
||||
if (time>0){
|
||||
that.setData({
|
||||
countDown: true
|
||||
})
|
||||
setTimeout(this.countDown, 1000);
|
||||
}else{
|
||||
that.setData({
|
||||
countDown:false
|
||||
})
|
||||
}
|
||||
},
|
||||
getDetail:function(id){
|
||||
var that = this;
|
||||
wx.request({
|
||||
url: urlPath.getDetail,
|
||||
header:{
|
||||
'token': wx.getStorageSync('token')
|
||||
},
|
||||
data:{
|
||||
'id' : id
|
||||
},
|
||||
success(res){
|
||||
if(res.data.code == 0){
|
||||
var item = res.data.data;
|
||||
that.setData({
|
||||
ids:item.id,
|
||||
img:urlPath.host + item.pic,
|
||||
text:item.explain,
|
||||
name:item.user_name,
|
||||
number:item.votes
|
||||
});
|
||||
}else{
|
||||
console.log(res.data.msg); //失败
|
||||
}
|
||||
}
|
||||
});
|
||||
},
|
||||
//小于10的格式化函数(2变成02)
|
||||
timeFormat(param) {
|
||||
return param < 10 ? '0' + param : param;
|
||||
},
|
||||
//小于0的格式化函数(不会出现负数)
|
||||
timeFormin(param) {
|
||||
return param < 0 ? 0: param;
|
||||
},
|
||||
/**
|
||||
* 生命周期函数--监听页面初次渲染完成
|
||||
*/
|
||||
onReady: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 生命周期函数--监听页面显示
|
||||
*/
|
||||
onShow: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 生命周期函数--监听页面隐藏
|
||||
*/
|
||||
onHide: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 生命周期函数--监听页面卸载
|
||||
*/
|
||||
onUnload: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 页面相关事件处理函数--监听用户下拉动作
|
||||
*/
|
||||
onPullDownRefresh: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 页面上拉触底事件的处理函数
|
||||
*/
|
||||
onReachBottom: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 用户点击右上角分享
|
||||
*/
|
||||
onShareAppMessage: function () {
|
||||
|
||||
},
|
||||
vote(e){
|
||||
var that = this;
|
||||
var id = e.currentTarget.dataset.id;
|
||||
if(id > 0){
|
||||
wx.request({
|
||||
url: urlPath.vote,
|
||||
header:{
|
||||
'token' : wx.getStorageSync('token')
|
||||
},
|
||||
data:{
|
||||
id : id
|
||||
},
|
||||
success(res){
|
||||
if(res.data.code == 0){
|
||||
wx.showToast({
|
||||
title: '投票成功'
|
||||
});
|
||||
that.onLoad({id:that.data.ids});
|
||||
}else{
|
||||
wx.showToast({
|
||||
title:res.data.msg,
|
||||
icon:'none'
|
||||
});
|
||||
}
|
||||
}
|
||||
})
|
||||
}
|
||||
}
|
||||
})
|
|
@ -0,0 +1,5 @@
|
|||
{
|
||||
"usingComponents": {
|
||||
"mp-tabbar": "../../custom-tab-bar/index"
|
||||
}
|
||||
}
|
|
@ -0,0 +1,72 @@
|
|||
<!--pages/picture/picture.wxml-->
|
||||
<view class="container">
|
||||
<view class="page-body">
|
||||
<view class="page-section page-section-spacing swiper">
|
||||
<swiper autoplay="true" interval="{{interval}}" duration="{{duration}}"
|
||||
circular="true" current="{{swiperCurrent}}" bindchange="swiperChange">
|
||||
<block wx:for="{{img_url}}" >
|
||||
<swiper-item>
|
||||
<view class="swiper-item">
|
||||
<image src="{{item}}"></image>
|
||||
</view>
|
||||
</swiper-item>
|
||||
</block>
|
||||
</swiper>
|
||||
</view>
|
||||
<view class="dots">
|
||||
<block wx:for="{{img_url}}" wx:key="unique">
|
||||
<view class="dot{{index == swiperCurrent ? ' active' : ''}}"></view>
|
||||
</block>
|
||||
</view>
|
||||
</view>
|
||||
<!--内容-->
|
||||
<view class="view-bg top40">
|
||||
<view class="countdown">
|
||||
<view class="names">
|
||||
<text>距离投票结束还有</text>
|
||||
</view>
|
||||
<view class="time" >
|
||||
<text>{{day}}</text>天 <text>{{hou}}</text>时<text>{{min}}</text>分<text>{{sec}}</text>秒
|
||||
</view>
|
||||
<view class="tab">
|
||||
<view class="list">
|
||||
{{tab_number}}<text>人</text>
|
||||
<text>参与者</text>
|
||||
</view>
|
||||
<view class="list">
|
||||
{{tab_vote}}<text>票</text>
|
||||
<text>投票数</text>
|
||||
</view>
|
||||
<view class="list">
|
||||
{{tab_visit}}<text>次</text>
|
||||
<text>访问量</text>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
<!--投票内容-->
|
||||
<view class="picture_conter">
|
||||
<view class="img">
|
||||
<view class="id">{{ids}}<text>号</text></view>
|
||||
<image mode="aspectFill" src="{{img}}"></image>
|
||||
</view>
|
||||
<rich-text class="rule-center" nodes="{{text}}"></rich-text>
|
||||
<!--view class="text">
|
||||
简介:{{text}}
|
||||
</view-->
|
||||
<view class="name" bindtap="personal">
|
||||
{{name}} <text>{{number}}</text>
|
||||
</view>
|
||||
<button class="add" bindtap="vote" data-id="{{ids}}">
|
||||
投票
|
||||
</button>
|
||||
</view>
|
||||
</view>
|
||||
<!--报名-->
|
||||
<!--view class="signup" bindtap="sign">
|
||||
我要报名
|
||||
</view-->
|
||||
<view class=" sign-rule" bindtap="rule">
|
||||
活动规则
|
||||
</view>
|
||||
<!---->
|
||||
</view>
|
|
@ -0,0 +1,91 @@
|
|||
/* pages/picture/picture.wxss */
|
||||
.page-body{
|
||||
height: 300rpx;
|
||||
position: relative;
|
||||
}
|
||||
.swiper-item image{
|
||||
width: 100%;
|
||||
height: 300rpx;
|
||||
}
|
||||
.dots{
|
||||
display: inline-block;
|
||||
position: absolute;
|
||||
bottom: 20rpx;
|
||||
right: 0;
|
||||
padding: 0 20rpx;
|
||||
}
|
||||
.dots .dot{
|
||||
width: 8rpx;
|
||||
height: 8rpx;
|
||||
background: #fff;
|
||||
float: left;
|
||||
margin:0 4rpx;
|
||||
border-radius: 50%;
|
||||
}
|
||||
.dots .dot.active{
|
||||
background: #2a8de9;
|
||||
}
|
||||
/**/
|
||||
.picture_conter {
|
||||
padding:0 24rpx;
|
||||
}
|
||||
.picture_conter .img{
|
||||
padding: 16rpx;
|
||||
width: 100%;
|
||||
position: relative;
|
||||
}
|
||||
.picture_conter .img .id{
|
||||
width: 61rpx;
|
||||
height: 72rpx;
|
||||
position: absolute;
|
||||
left: 0;
|
||||
top: 0;
|
||||
font-size: 24rpx;
|
||||
color: #fff;
|
||||
text-align: center;
|
||||
background: url() no-repeat top center;
|
||||
background-size:61rpx 72rpx ;
|
||||
}
|
||||
.picture_conter .img .id text{
|
||||
display: block;
|
||||
margin-bottom: -3rpx;
|
||||
}
|
||||
.picture_conter .img image{
|
||||
width: 629rpx;
|
||||
height: 394rpx;
|
||||
border-radius: 5rpx;
|
||||
}
|
||||
.picture_conter .text{
|
||||
display: -webkit-box;
|
||||
overflow: hidden;
|
||||
text-overflow: ellipsis;
|
||||
word-wrap: break-word;
|
||||
white-space: normal !important;
|
||||
-webkit-line-clamp: 1;
|
||||
-webkit-box-orient: vertical;
|
||||
font-size: 28rpx;
|
||||
color: #8c8c8c;
|
||||
padding:0 16rpx;
|
||||
}
|
||||
.picture_conter .name{
|
||||
font-size: 30rpx;
|
||||
color: #333333;
|
||||
width: 100%;
|
||||
padding: 40rpx 0;
|
||||
max-width: 240rpx;
|
||||
margin: 0 auto;
|
||||
}
|
||||
.picture_conter .name text{
|
||||
float: right;
|
||||
color: #ff1a1a;
|
||||
}
|
||||
.picture_conter .add{
|
||||
width: 310rpx;
|
||||
height: 58rpx;
|
||||
line-height: 58rpx;
|
||||
background:#ffc103;
|
||||
padding: 0;
|
||||
border-radius: 0;
|
||||
color: #fff;
|
||||
font-size: 30rpx;
|
||||
}
|
|
@ -0,0 +1,107 @@
|
|||
// pages/ranking/ranking.js
|
||||
var urlPath = require('../../config.js');
|
||||
Page({
|
||||
/**
|
||||
* 页面的初始数据
|
||||
*/
|
||||
data: {
|
||||
//列表
|
||||
ranking_list:[]
|
||||
},
|
||||
|
||||
/**
|
||||
* 生命周期函数--监听页面加载
|
||||
*/
|
||||
onLoad: function (options) {
|
||||
var that = this;
|
||||
that.getList();
|
||||
},
|
||||
|
||||
/**
|
||||
* 生命周期函数--监听页面初次渲染完成
|
||||
*/
|
||||
onReady: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 生命周期函数--监听页面显示
|
||||
*/
|
||||
onShow: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 生命周期函数--监听页面隐藏
|
||||
*/
|
||||
onHide: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 生命周期函数--监听页面卸载
|
||||
*/
|
||||
onUnload: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 页面相关事件处理函数--监听用户下拉动作
|
||||
*/
|
||||
onPullDownRefresh: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 页面上拉触底事件的处理函数
|
||||
*/
|
||||
onReachBottom: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 用户点击右上角分享
|
||||
*/
|
||||
onShareAppMessage: function () {
|
||||
|
||||
},
|
||||
onShow:function(){
|
||||
if (typeof this.getTabBar === 'function' &&
|
||||
this.getTabBar()) {
|
||||
this.getTabBar().setData({
|
||||
selected: 2
|
||||
})
|
||||
}
|
||||
},
|
||||
getList:function(){
|
||||
var that = this;
|
||||
wx.request({
|
||||
url: urlPath.getVoteList,
|
||||
header:{
|
||||
'token': wx.getStorageSync('token')
|
||||
},
|
||||
success(res){
|
||||
if(res.data.code == 0){
|
||||
if(res.data.data.length > 0){
|
||||
var ranking_list = [];
|
||||
res.data.data.forEach(function(item, index){
|
||||
console.log(index);
|
||||
ranking_list.push({
|
||||
ranks: index + 1,
|
||||
name: item.user_name,
|
||||
ids: item.id,
|
||||
img: urlPath.host + item.pic,
|
||||
number: item.votes,
|
||||
});
|
||||
});
|
||||
that.setData({
|
||||
ranking_list:ranking_list
|
||||
});
|
||||
}
|
||||
}else{
|
||||
console.log(res.data.msg); //失败
|
||||
}
|
||||
}
|
||||
});
|
||||
}
|
||||
})
|
|
@ -0,0 +1,3 @@
|
|||
{
|
||||
"usingComponents": {}
|
||||
}
|
|
@ -0,0 +1,33 @@
|
|||
<!--pages/ranking/ranking.wxml-->
|
||||
<view class="container">
|
||||
<view class="banner">
|
||||
<view class="banner-conter">
|
||||
<view class="text">投票排行榜</view>
|
||||
<view class="img">
|
||||
<image src="../../img/icon_02.png"></image>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
<!--排行榜列表-->
|
||||
<view class="ranking top40">
|
||||
<view class="ranking-th">
|
||||
<view>排名</view>
|
||||
<view>姓名</view>
|
||||
<view>作品序号</view>
|
||||
<view>票数</view>
|
||||
</view>
|
||||
<view class="list">
|
||||
<block wx:for="{{ranking_list}}" wx:key="index">
|
||||
<view class="ranking-list">
|
||||
<view class="ranks"><text>{{item.ranks}}</text></view>
|
||||
<view class="name">{{item.name}}</view>
|
||||
<view class="img">
|
||||
<view class="id">{{item.ids}}<text>号</text></view>
|
||||
<image mode="aspectFill" src="{{item.img}}"></image>
|
||||
</view>
|
||||
<view class="number">{{item.number}}</view>
|
||||
</view>
|
||||
</block>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
|
@ -0,0 +1,151 @@
|
|||
/* pages/ranking/ranking.wxss */
|
||||
.container{
|
||||
background: #fff;
|
||||
padding-bottom: 120rpx;
|
||||
}
|
||||
.banner{
|
||||
width: 100%;
|
||||
position: relative;
|
||||
min-height: 390rpx;
|
||||
padding: 30rpx 30rpx 0;
|
||||
}
|
||||
.banner::after{
|
||||
background: #2a7be9;
|
||||
height: 300rpx;
|
||||
width: 100%;
|
||||
position: absolute;
|
||||
left: 0;
|
||||
top: 0;
|
||||
content: "";
|
||||
}
|
||||
.banner-conter{
|
||||
background: #fff;
|
||||
width: 100%;
|
||||
z-index: 1;
|
||||
position: relative;
|
||||
padding: 50rpx 30rpx;
|
||||
display: inline-block;
|
||||
box-shadow: 10rpx 10rpx 10rpx rgba(0,0,0,.1);
|
||||
}
|
||||
.banner-conter .text{
|
||||
height: 262rpx;
|
||||
line-height: 262rpx;
|
||||
font-size: 63rpx;
|
||||
color: #2a7be9;
|
||||
font-weight: bold;
|
||||
float: left;
|
||||
width: 50%;
|
||||
}
|
||||
.banner-conter .img{
|
||||
float: left;
|
||||
width: 50%;
|
||||
}
|
||||
.banner-conter .img image{
|
||||
width:289rpx;
|
||||
height: 262rpx;
|
||||
}
|
||||
.ranking{
|
||||
width: 100%;
|
||||
}
|
||||
.ranking .ranking-th{
|
||||
background: #f7f7f7;
|
||||
width: 100%;
|
||||
display: inline-block;
|
||||
vertical-align:top;
|
||||
}
|
||||
.ranking .ranking-th view{
|
||||
float: left;
|
||||
display: inline-block;
|
||||
font-size: 28rpx;
|
||||
padding: 20rpx 0 20rpx 20rpx ;
|
||||
color: #a8a8a8;
|
||||
}
|
||||
.ranking .ranking-list {
|
||||
display: inline-block;
|
||||
vertical-align:top;
|
||||
width: 100%;
|
||||
border-bottom: 1rpx solid #dddddd;
|
||||
}
|
||||
.ranking .ranking-th view:nth-child(1),.ranking .ranking-list view:nth-child(1){
|
||||
width: 200rpx;
|
||||
}
|
||||
.ranking .ranking-th view:nth-child(2),.ranking .ranking-list view:nth-child(2){
|
||||
width: 180rpx;
|
||||
}
|
||||
.ranking .ranking-th view:nth-child(3),.ranking .ranking-list view:nth-child(3){
|
||||
width: 270rpx;
|
||||
}
|
||||
.ranking .ranking-th view:nth-child(4),.ranking .ranking-list view:nth-child(4){
|
||||
width: 100rpx;
|
||||
text-align: center;
|
||||
padding-left: 0rpx;
|
||||
}
|
||||
.ranking .ranking-list .ranks text{
|
||||
font-size: 40rpx;
|
||||
color: #fc7e21;
|
||||
width: 40rpx;
|
||||
height: 94rpx;
|
||||
text-align: center;
|
||||
display: block;
|
||||
margin-left: 20rpx;
|
||||
}
|
||||
.ranking .ranking-list:nth-child(1) .ranks text{
|
||||
background: url() no-repeat center;
|
||||
background-size: 40rpx 50rpx;
|
||||
font-size: 26rpx;
|
||||
color: #fff;
|
||||
line-height: 88rpx;
|
||||
}
|
||||
.ranking .ranking-list:nth-child(2) .ranks text{
|
||||
background: url() no-repeat center;
|
||||
background-size: 40rpx 50rpx;
|
||||
font-size: 26rpx;
|
||||
color: #fff;
|
||||
line-height: 88rpx;
|
||||
}
|
||||
.ranking .ranking-list:nth-child(3) .ranks text{
|
||||
background: url() no-repeat center;
|
||||
background-size: 40rpx 50rpx;
|
||||
font-size: 26rpx;
|
||||
color: #fff;
|
||||
line-height: 88rpx;
|
||||
}
|
||||
.ranking .ranking-list view{
|
||||
float: left;
|
||||
display: inline-block;
|
||||
padding: 0;
|
||||
height: 94rpx;
|
||||
line-height: 94rpx;
|
||||
}
|
||||
.ranking .ranking-list .name{
|
||||
font-size: 28rpx;
|
||||
}
|
||||
.ranking .ranking-list .img{
|
||||
position: relative;
|
||||
padding: 10rpx 10rpx;
|
||||
}
|
||||
.ranking .ranking-list .img .id{
|
||||
line-height: initial;
|
||||
width:35rpx;
|
||||
height: 41rpx;
|
||||
position: absolute;
|
||||
left: 0;
|
||||
top: 0;
|
||||
font-size: 13rpx;
|
||||
color: #fff;
|
||||
text-align: center;
|
||||
background: url() no-repeat top center;
|
||||
background-size:35rpx 41rpx ;
|
||||
}
|
||||
.ranking .ranking-list .img text{
|
||||
display: block;
|
||||
}
|
||||
.ranking .ranking-list .img image{
|
||||
width: 124rpx;
|
||||
height: 75rpx;
|
||||
}
|
||||
.ranking .ranking-list .number{
|
||||
font-size: 28rpx;
|
||||
color: #f83f3c;
|
||||
font-weight: bold;
|
||||
}
|
|
@ -0,0 +1,138 @@
|
|||
// pages/index.js
|
||||
Page({
|
||||
|
||||
sign() {
|
||||
wx.navigateTo({ url: '../sign/sign' });
|
||||
},
|
||||
/**
|
||||
* 页面的初始数据
|
||||
*/
|
||||
data: {
|
||||
img_url:wx.getStorageSync('img_url'),
|
||||
swiperCurrent:0,
|
||||
autoplay: false,
|
||||
interval: 3000,
|
||||
duration: 800,
|
||||
//倒计时数据
|
||||
endTime: '2020/11/22 10:40:30',
|
||||
//
|
||||
tab_number:31,//参与者
|
||||
tab_vote:2375,//投票数
|
||||
tab_visit:55,//访问次数
|
||||
//活动规则
|
||||
rule:'我是活动规则'
|
||||
},
|
||||
swiperChange: function (e) {
|
||||
// console.log(e);
|
||||
this.setData({
|
||||
swiperCurrent: e.detail.current
|
||||
})
|
||||
},
|
||||
/**
|
||||
* 生命周期函数--监听页面加载
|
||||
*/
|
||||
onLoad: function (options) {
|
||||
var that = this;
|
||||
var baseInfo = wx.getStorageSync('baseInfo');
|
||||
that.setData({
|
||||
tab_number: baseInfo.numberOfPeople,
|
||||
tab_vote: baseInfo.voteNumber,
|
||||
endTime: baseInfo.vote.time,
|
||||
rule_text: baseInfo.vote.rule_text,
|
||||
tab_visit:baseInfo.vote.visits,
|
||||
rule:baseInfo.vote.rule,
|
||||
img_url:wx.getStorageSync('img_url'),
|
||||
});
|
||||
that.countDown()
|
||||
},
|
||||
// 倒计时
|
||||
countDown:function(){
|
||||
var that=this;
|
||||
var nowTime = new Date().getTime();//现在时间(时间戳)
|
||||
var endTime = new Date(that.data.endTime).getTime();//结束时间(时间戳)
|
||||
var time = (endTime-nowTime)/1000;//距离结束的毫秒数
|
||||
// 获取天、时、分、秒
|
||||
let day = parseInt(time / (60 * 60 * 24));
|
||||
let hou = parseInt(time % (60 * 60 * 24) / 3600);
|
||||
let min = parseInt(time % (60 * 60 * 24) % 3600 / 60);
|
||||
let sec = parseInt(time % (60 * 60 * 24) % 3600 % 60);
|
||||
// console.log(day + "," + hou + "," + min + "," + sec)
|
||||
day = that.timeFormin(day),
|
||||
hou = that.timeFormin(hou),
|
||||
min = that.timeFormin(min),
|
||||
sec = that.timeFormin(sec)
|
||||
that.setData({
|
||||
day: that.timeFormat(day),
|
||||
hou: that.timeFormat(hou),
|
||||
min: that.timeFormat(min),
|
||||
sec: that.timeFormat(sec)
|
||||
})
|
||||
// 每1000ms刷新一次
|
||||
if (time>0){
|
||||
that.setData({
|
||||
countDown: true
|
||||
})
|
||||
setTimeout(this.countDown, 1000);
|
||||
}else{
|
||||
that.setData({
|
||||
countDown:false
|
||||
})
|
||||
}
|
||||
},
|
||||
//小于10的格式化函数(2变成02)
|
||||
timeFormat(param) {
|
||||
return param < 10 ? '0' + param : param;
|
||||
},
|
||||
//小于0的格式化函数(不会出现负数)
|
||||
timeFormin(param) {
|
||||
return param < 0 ? 0: param;
|
||||
},
|
||||
/**
|
||||
* 生命周期函数--监听页面初次渲染完成
|
||||
*/
|
||||
onReady: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 生命周期函数--监听页面显示
|
||||
*/
|
||||
onShow: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 生命周期函数--监听页面隐藏
|
||||
*/
|
||||
onHide: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 生命周期函数--监听页面卸载
|
||||
*/
|
||||
onUnload: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 页面相关事件处理函数--监听用户下拉动作
|
||||
*/
|
||||
onPullDownRefresh: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 页面上拉触底事件的处理函数
|
||||
*/
|
||||
onReachBottom: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 用户点击右上角分享
|
||||
*/
|
||||
onShareAppMessage: function () {
|
||||
|
||||
}
|
||||
})
|
|
@ -0,0 +1,3 @@
|
|||
{
|
||||
"usingComponents": {}
|
||||
}
|
|
@ -0,0 +1,59 @@
|
|||
<!--pages/index.wxml-->
|
||||
<view class="container">
|
||||
<view class="page-body">
|
||||
<view class="page-section page-section-spacing swiper">
|
||||
<swiper autoplay="true" interval="{{interval}}" duration="{{duration}}"
|
||||
circular="true" current="{{swiperCurrent}}" bindchange="swiperChange">
|
||||
<block wx:for="{{img_url}}" >
|
||||
<swiper-item>
|
||||
<view class="swiper-item">
|
||||
<image src="{{item}}" ></image>
|
||||
</view>
|
||||
</swiper-item>
|
||||
</block>
|
||||
</swiper>
|
||||
</view>
|
||||
<view class="dots">
|
||||
<block wx:for="{{img_url}}" wx:key="unique">
|
||||
<view class="dot{{index == swiperCurrent ? ' active' : ''}}"></view>
|
||||
</block>
|
||||
</view>
|
||||
</view>
|
||||
<!--内容-->
|
||||
<view class="view-bg top40">
|
||||
<view class="countdown">
|
||||
<view class="names">
|
||||
<text>距离投票结束还有</text>
|
||||
</view>
|
||||
<view class="time" >
|
||||
<text>{{day}}</text>天 <text>{{hou}}</text>时<text>{{min}}</text>分<text>{{sec}}</text>秒
|
||||
</view>
|
||||
<view class="tab">
|
||||
<view class="list">
|
||||
{{tab_number}}<text>人</text>
|
||||
<text>参与者</text>
|
||||
</view>
|
||||
<view class="list">
|
||||
{{tab_vote}}<text>票</text>
|
||||
<text>投票数</text>
|
||||
</view>
|
||||
<view class="list">
|
||||
{{tab_visit}}<text>次</text>
|
||||
<text>访问量</text>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
<!--活动规则-->
|
||||
<view class="view-bg top40">
|
||||
<view class="rule-name">
|
||||
<text>活动规则</text>
|
||||
</view>
|
||||
<rich-text class="rule-center" nodes="{{rule}}"></rich-text>
|
||||
</view>
|
||||
<!--报名-->
|
||||
<!--view class="signup" bindtap="sign">
|
||||
我要报名
|
||||
</view-->
|
||||
<!---->
|
||||
</view>
|
|
@ -0,0 +1,56 @@
|
|||
/* pages/rule/rule.wxss */
|
||||
.page-body{
|
||||
height: 300rpx;
|
||||
position: relative;
|
||||
}
|
||||
.swiper-item image{
|
||||
width: 100%;
|
||||
height: 300rpx;
|
||||
}
|
||||
.dots{
|
||||
display: inline-block;
|
||||
position: absolute;
|
||||
bottom: 20rpx;
|
||||
right: 0;
|
||||
padding: 0 20rpx;
|
||||
}
|
||||
.dots .dot{
|
||||
width: 8rpx;
|
||||
height: 8rpx;
|
||||
background: #fff;
|
||||
float: left;
|
||||
margin:0 4rpx;
|
||||
border-radius: 50%;
|
||||
}
|
||||
.dots .dot.active{
|
||||
background: #2a8de9;
|
||||
}
|
||||
.view-bg{
|
||||
overflow: inherit;
|
||||
}
|
||||
.rule-name{
|
||||
position: relative;
|
||||
padding-top: 50rpx;
|
||||
height: 104rpx;
|
||||
width: 100%;
|
||||
}
|
||||
.rule-name text{
|
||||
background: url() no-repeat center left;
|
||||
background-size: 158rpx 54rpx;
|
||||
width: 158rpx;
|
||||
height: 54rpx;
|
||||
padding-left: 20rpx;
|
||||
font-size: 30rpx;
|
||||
color: #fff;
|
||||
display: block;
|
||||
position: absolute;
|
||||
left: -10rpx;
|
||||
top:50rpx;
|
||||
}
|
||||
.rule-center{
|
||||
margin-top: 30rpx;
|
||||
font-size: 24rpx;
|
||||
padding: 20rpx;
|
||||
display: block;
|
||||
width: 100%;
|
||||
}
|
|
@ -0,0 +1,277 @@
|
|||
// pages/sign/sign.js
|
||||
Page({
|
||||
|
||||
/**
|
||||
* 页面的初始数据
|
||||
*/
|
||||
data: {
|
||||
img_url:wx.getStorageSync('img_url'),
|
||||
swiperCurrent:0,
|
||||
autoplay: false,
|
||||
interval: 3000,
|
||||
duration: 800,
|
||||
//倒计时数据
|
||||
endTime: '2020/11/22 10:40:30',
|
||||
//
|
||||
tab_number:31,//参与者
|
||||
tab_vote:2375,//投票数
|
||||
tab_visit:55,//访问次数
|
||||
//上传图
|
||||
source:'',
|
||||
is_upload:'0',
|
||||
tel : '',
|
||||
name : '',
|
||||
img : '',
|
||||
desc : '',
|
||||
user : wx.getStorageSync('user')
|
||||
},
|
||||
/**
|
||||
* 上传图片
|
||||
*/
|
||||
uploadimg:function(){
|
||||
var that = this;
|
||||
wx.chooseImage({ //从本地相册选择图片或使用相机拍照
|
||||
count: 1, // 默认9
|
||||
sizeType: ['original', 'compressed'], // 可以指定是原图还是压缩图,默认二者都有
|
||||
sourceType: ['album', 'camera'], // 可以指定来源是相册还是相机,默认二者都有
|
||||
success:function(res){
|
||||
//前台显示
|
||||
that.setData({
|
||||
source: res.tempFilePaths,
|
||||
is_upload:'1'
|
||||
})
|
||||
// 返回选定照片的本地文件路径列表,tempFilePath可以作为img标签的src属性显示图片
|
||||
var tempFilePaths = res.tempFilePaths
|
||||
wx.uploadFile({
|
||||
url: wx.getStorageSync('urlPath').upload,
|
||||
header:{
|
||||
token: wx.getStorageSync('token')
|
||||
},
|
||||
filePath: tempFilePaths[0],
|
||||
name: 'image',
|
||||
success:function(res){
|
||||
var result = JSON.parse(res.data);
|
||||
console.log(result);
|
||||
if(result.code == 0){
|
||||
that.setData({
|
||||
img: result.data.src
|
||||
});
|
||||
}else{
|
||||
console.log(result.msg);
|
||||
}
|
||||
}
|
||||
})
|
||||
}
|
||||
})
|
||||
//https://www.jb51.net/article/132557.htm 后端源码
|
||||
},
|
||||
//上传图片
|
||||
swiperChange: function (e) {
|
||||
// console.log(e);
|
||||
this.setData({
|
||||
swiperCurrent: e.detail.current
|
||||
})
|
||||
},
|
||||
/**
|
||||
* 生命周期函数--监听页面加载
|
||||
*/
|
||||
onLoad: function (options) {
|
||||
var that = this;
|
||||
var baseInfo = wx.getStorageSync('baseInfo');
|
||||
that.setData({
|
||||
tab_number: baseInfo.numberOfPeople,
|
||||
tab_vote: baseInfo.voteNumber,
|
||||
endTime: baseInfo.vote.time,
|
||||
rule_text: baseInfo.vote.rule_text,
|
||||
tab_visit:baseInfo.vote.visits,
|
||||
img_url:wx.getStorageSync('img_url'),
|
||||
});
|
||||
that.setData({
|
||||
user:wx.getStorageSync('user')
|
||||
});
|
||||
that.countDown();
|
||||
},
|
||||
// 倒计时
|
||||
countDown:function(){
|
||||
var that=this;
|
||||
var nowTime = new Date().getTime();//现在时间(时间戳)
|
||||
var endTime = new Date(that.data.endTime).getTime();//结束时间(时间戳)
|
||||
var time = (endTime-nowTime)/1000;//距离结束的毫秒数
|
||||
// 获取天、时、分、秒
|
||||
let day = parseInt(time / (60 * 60 * 24));
|
||||
let hou = parseInt(time % (60 * 60 * 24) / 3600);
|
||||
let min = parseInt(time % (60 * 60 * 24) % 3600 / 60);
|
||||
let sec = parseInt(time % (60 * 60 * 24) % 3600 % 60);
|
||||
// console.log(day + "," + hou + "," + min + "," + sec)
|
||||
day = that.timeFormin(day),
|
||||
hou = that.timeFormin(hou),
|
||||
min = that.timeFormin(min),
|
||||
sec = that.timeFormin(sec)
|
||||
that.setData({
|
||||
day: that.timeFormat(day),
|
||||
hou: that.timeFormat(hou),
|
||||
min: that.timeFormat(min),
|
||||
sec: that.timeFormat(sec)
|
||||
})
|
||||
// 每1000ms刷新一次
|
||||
if (time>0){
|
||||
that.setData({
|
||||
countDown: true
|
||||
})
|
||||
setTimeout(this.countDown, 1000);
|
||||
}else{
|
||||
that.setData({
|
||||
countDown:false
|
||||
})
|
||||
}
|
||||
},
|
||||
//小于10的格式化函数(2变成02)
|
||||
timeFormat(param) {
|
||||
return param < 10 ? '0' + param : param;
|
||||
},
|
||||
//小于0的格式化函数(不会出现负数)
|
||||
timeFormin(param) {
|
||||
return param < 0 ? 0: param;
|
||||
},
|
||||
/**
|
||||
* 生命周期函数--监听页面初次渲染完成
|
||||
*/
|
||||
onReady: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 生命周期函数--监听页面显示
|
||||
*/
|
||||
onShow: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 生命周期函数--监听页面隐藏
|
||||
*/
|
||||
onHide: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 生命周期函数--监听页面卸载
|
||||
*/
|
||||
onUnload: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 页面相关事件处理函数--监听用户下拉动作
|
||||
*/
|
||||
onPullDownRefresh: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 页面上拉触底事件的处理函数
|
||||
*/
|
||||
onReachBottom: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 用户点击右上角分享
|
||||
*/
|
||||
onShareAppMessage: function () {
|
||||
|
||||
},
|
||||
setname:function(e){
|
||||
this.setData({
|
||||
name:e.detail.value
|
||||
});
|
||||
},
|
||||
settel:function(e){
|
||||
this.setData({
|
||||
tel:e.detail.value
|
||||
});
|
||||
},
|
||||
setdesc:function(e){
|
||||
this.setData({
|
||||
desc:e.detail.value
|
||||
});
|
||||
},
|
||||
save:function(){
|
||||
var that = this;
|
||||
var user = wx.getStorageSync('user');
|
||||
var name = that.data.name;
|
||||
var tel = that.data.tel;
|
||||
if(user.tel == '' || user.name == ''){
|
||||
if(name == ''){
|
||||
wx.showToast({
|
||||
title: '姓名不可为空',
|
||||
icon: 'none'
|
||||
});
|
||||
}
|
||||
if(tel == ''){
|
||||
wx.showToast({
|
||||
title: '电话不可为空',
|
||||
icon: 'none'
|
||||
});
|
||||
}
|
||||
}
|
||||
var desc = that.data.desc;
|
||||
var img = that.data.img;
|
||||
console.log(img);
|
||||
if(desc == ''){
|
||||
wx.showToast({
|
||||
title: '描述不可为空',
|
||||
icon: 'none'
|
||||
});
|
||||
}
|
||||
if(img == ''){
|
||||
wx.showToast({
|
||||
title: '请上传图片',
|
||||
icon: 'none'
|
||||
});
|
||||
}
|
||||
wx.request({
|
||||
url: wx.getStorageSync('urlPath').saveProduction,
|
||||
header:{
|
||||
token: wx.getStorageSync('token')
|
||||
},
|
||||
method: 'post',
|
||||
data:{
|
||||
name: name,
|
||||
tel: tel,
|
||||
desc: desc,
|
||||
img:img
|
||||
},
|
||||
success(res){
|
||||
if(res.data.code == 0){
|
||||
if(user.tel == '' || user.name == ''){
|
||||
wx.request({
|
||||
url: wx.getStorageSync('urlPath').getUser,
|
||||
header:{
|
||||
token: wx.getStorageSync('token')
|
||||
},
|
||||
success(resForUser){
|
||||
if(resForUser.data.code == 0){
|
||||
console.log(resForUser.data.data);
|
||||
wx.setStorageSync('user', resForUser.data.data);
|
||||
that.onLoad();
|
||||
}
|
||||
}
|
||||
});
|
||||
}
|
||||
wx.showToast({
|
||||
title: '上传成功'
|
||||
});
|
||||
wx.switchTab({
|
||||
url: '/pages/index/index',
|
||||
})
|
||||
}else{
|
||||
wx.showToast({
|
||||
title: res.data.msg,
|
||||
icon: 'none'
|
||||
});
|
||||
}
|
||||
}
|
||||
});
|
||||
}
|
||||
})
|
|
@ -0,0 +1,3 @@
|
|||
{
|
||||
"usingComponents": {}
|
||||
}
|
|
@ -0,0 +1,76 @@
|
|||
<!--pages/sign.wxml-->
|
||||
<view class="container">
|
||||
<view class="page-body">
|
||||
<view class="page-section page-section-spacing swiper">
|
||||
<swiper autoplay="true" interval="{{interval}}" duration="{{duration}}"
|
||||
circular="true" current="{{swiperCurrent}}" bindchange="swiperChange">
|
||||
<block wx:for="{{img_url}}" >
|
||||
<swiper-item>
|
||||
<view class="swiper-item">
|
||||
<image src="{{item}}" ></image>
|
||||
</view>
|
||||
</swiper-item>
|
||||
</block>
|
||||
</swiper>
|
||||
</view>
|
||||
<view class="dots">
|
||||
<block wx:for="{{img_url}}" wx:key="unique">
|
||||
<view class="dot{{index == swiperCurrent ? ' active' : ''}}"></view>
|
||||
</block>
|
||||
</view>
|
||||
</view>
|
||||
<!--内容-->
|
||||
<view class="view-bg top40">
|
||||
<view class="countdown">
|
||||
<view class="names">
|
||||
<text>距离投票结束还有</text>
|
||||
</view>
|
||||
<view class="time" >
|
||||
<text>{{day}}</text>天 <text>{{hou}}</text>时<text>{{min}}</text>分<text>{{sec}}</text>秒
|
||||
</view>
|
||||
<view class="tab">
|
||||
<view class="list">
|
||||
{{tab_number}}<text>人</text>
|
||||
<text>参与者</text>
|
||||
</view>
|
||||
<view class="list">
|
||||
{{tab_vote}}<text>票</text>
|
||||
<text>投票数</text>
|
||||
</view>
|
||||
<view class="list">
|
||||
{{tab_visit}}<text>次</text>
|
||||
<text>访问量</text>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
<!--表单-->
|
||||
<view class="sign">
|
||||
<form>
|
||||
<view wx-if='{{user.tel == "" || user.tel == undefined || user.name == "" || user.name == undefined}}'>
|
||||
<view class="list" >
|
||||
<text>姓名</text>
|
||||
<input placeholder="请输入您的姓名" adjust-position="true" bindinput="setname" />
|
||||
</view>
|
||||
<view class="list">
|
||||
<text>手机号</text>
|
||||
<input placeholder="请输入您的联系电话" adjust-position="true" bindinput="settel" />
|
||||
</view>
|
||||
</view>
|
||||
<view class="list">
|
||||
<text>描述</text>
|
||||
<textarea placeholder="请介绍一下作品" maxlength="100" adjust-position="true" bindinput="setdesc" />
|
||||
</view>
|
||||
<view class="list">
|
||||
<text>上传作品</text>
|
||||
<view class="img">
|
||||
<image src='{{source}}'/>
|
||||
<view class="{{is_upload=='1'?'uploadopacity':''}} uploadimg" bindtap="uploadimg"></view>
|
||||
</view>
|
||||
</view>
|
||||
<view class="list">
|
||||
<button bindtap="save">提交报名</button>
|
||||
</view>
|
||||
</form>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
|
@ -0,0 +1,102 @@
|
|||
/* pages/sign/sign.wxss */
|
||||
.page-body{
|
||||
height: 300rpx;
|
||||
position: relative;
|
||||
}
|
||||
.swiper-item image{
|
||||
width: 100%;
|
||||
height: 300rpx;
|
||||
}
|
||||
.dots{
|
||||
display: inline-block;
|
||||
position: absolute;
|
||||
bottom: 20rpx;
|
||||
right: 0;
|
||||
padding: 0 20rpx;
|
||||
}
|
||||
.dots .dot{
|
||||
width: 8rpx;
|
||||
height: 8rpx;
|
||||
background: #fff;
|
||||
float: left;
|
||||
margin:0 4rpx;
|
||||
border-radius: 50%;
|
||||
}
|
||||
.dots .dot.active{
|
||||
background: #2a8de9;
|
||||
}
|
||||
.sign{
|
||||
padding: 0 40rpx;
|
||||
width: 100%;
|
||||
}
|
||||
.sign .list{
|
||||
margin-top: 40rpx;
|
||||
width: 100%;
|
||||
}
|
||||
.sign .list text{
|
||||
font-size: 30rpx;
|
||||
}
|
||||
.sign .list input,.sign .list textarea{
|
||||
width: 610rpx;
|
||||
height: 70rpx;
|
||||
border: none;
|
||||
background-color: #eeeeee;
|
||||
border-radius: 5rpx;
|
||||
margin-top: 10rpx;
|
||||
padding: 0 20rpx;
|
||||
font-size: 26rpx;
|
||||
}
|
||||
.sign .list textarea{
|
||||
height: 173rpx;
|
||||
padding-top: 20rpx;
|
||||
}
|
||||
.sign .list button:not([size='mini']){
|
||||
width: 570rpx;
|
||||
border-radius: 8rpx;
|
||||
background-color: #2a8de9;
|
||||
color: #fff;
|
||||
font-size: 30rpx;
|
||||
height: 74rpx;
|
||||
}
|
||||
.sign .list .img{
|
||||
margin-top:20rpx;
|
||||
display: inline-block;
|
||||
width: 100%;
|
||||
position: relative;
|
||||
}
|
||||
.sign .list image{
|
||||
width: 160rpx;
|
||||
height: 160rpx;
|
||||
float: left;
|
||||
}
|
||||
.sign .list .uploadimg{
|
||||
width: 160rpx;
|
||||
height: 160rpx;
|
||||
border: 2rpx solid #cacaca;
|
||||
position: relative;
|
||||
}
|
||||
.uploadopacity{
|
||||
opacity:0
|
||||
}
|
||||
.sign .list .uploadimg::after{
|
||||
width: 112rpx;
|
||||
height: 6rpx;
|
||||
background: #cacaca;
|
||||
content: "";
|
||||
position: absolute;
|
||||
left: 50%;
|
||||
margin-left: -56rpx;
|
||||
top: 50%;
|
||||
margin-top: -3rpx;
|
||||
}
|
||||
.sign .list .uploadimg::before{
|
||||
width: 6rpx;
|
||||
height: 112rpx;
|
||||
background: #cacaca;
|
||||
content: "";
|
||||
position: absolute;
|
||||
left: 50%;
|
||||
margin-left: -3rpx;
|
||||
top: 50%;
|
||||
margin-top: -56rpx;
|
||||
}
|
|
@ -0,0 +1,137 @@
|
|||
// pages/picture/picture.js
|
||||
var urlPath = require('../../config.js');
|
||||
Page({
|
||||
// 前往下一页
|
||||
picture() {
|
||||
wx.navigateTo({ url: '../picture/picture' });
|
||||
},
|
||||
again() {
|
||||
wx.navigateTo({ url: '../sign/sign' });
|
||||
},
|
||||
/**
|
||||
* 页面的初始数据
|
||||
*/
|
||||
data: {
|
||||
img_url:wx.getStorageSync('img_url'),
|
||||
swiperCurrent:0,
|
||||
autoplay: false,
|
||||
interval: 3000,
|
||||
duration: 800,
|
||||
//数据
|
||||
name: wx.getStorageSync('user').name,
|
||||
nm_number:"0",
|
||||
//列表
|
||||
works_list:[],
|
||||
},
|
||||
swiperChange: function (e) {
|
||||
// console.log(e);
|
||||
this.setData({
|
||||
swiperCurrent: e.detail.current
|
||||
})
|
||||
},
|
||||
|
||||
/**
|
||||
* 生命周期函数--监听页面加载
|
||||
*/
|
||||
onLoad: function (options) {
|
||||
var that = this;
|
||||
var user = wx.getStorageSync('user');
|
||||
console.log(user);
|
||||
that.getImgs();
|
||||
},
|
||||
//小于10的格式化函数(2变成02)
|
||||
timeFormat(param) {
|
||||
return param < 10 ? '0' + param : param;
|
||||
},
|
||||
//小于0的格式化函数(不会出现负数)
|
||||
timeFormin(param) {
|
||||
return param < 0 ? 0: param;
|
||||
},
|
||||
/**
|
||||
* 生命周期函数--监听页面初次渲染完成
|
||||
*/
|
||||
onReady: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 生命周期函数--监听页面显示
|
||||
*/
|
||||
onShow: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 生命周期函数--监听页面隐藏
|
||||
*/
|
||||
onHide: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 生命周期函数--监听页面卸载
|
||||
*/
|
||||
onUnload: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 页面相关事件处理函数--监听用户下拉动作
|
||||
*/
|
||||
onPullDownRefresh: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 页面上拉触底事件的处理函数
|
||||
*/
|
||||
onReachBottom: function () {
|
||||
|
||||
},
|
||||
|
||||
/**
|
||||
* 用户点击右上角分享
|
||||
*/
|
||||
onShareAppMessage: function () {
|
||||
|
||||
},
|
||||
onShow:function(){
|
||||
if (typeof this.getTabBar === 'function' && this.getTabBar()) {
|
||||
this.getTabBar().setData({
|
||||
selected: 3
|
||||
})
|
||||
}
|
||||
},
|
||||
getImgs:function(){
|
||||
var that = this;
|
||||
wx.request({
|
||||
url: urlPath.getImgs,
|
||||
header:{
|
||||
'token': wx.getStorageSync('token')
|
||||
},
|
||||
success(res){
|
||||
if(res.data.code == 0){
|
||||
if(res.data.data.length > 0){
|
||||
var works_list = [];
|
||||
var num = 0;
|
||||
res.data.data.forEach(function(item, index){
|
||||
works_list.push({
|
||||
ids: item.id,
|
||||
img: urlPath.host + item.pic,
|
||||
text: item.explain,
|
||||
number: item.votes,
|
||||
});
|
||||
num = num + item.votes;
|
||||
});
|
||||
that.setData({
|
||||
works_list: works_list,
|
||||
nm_number: num
|
||||
});
|
||||
}
|
||||
}else{
|
||||
console.log(res); //失败
|
||||
}
|
||||
}
|
||||
});
|
||||
}
|
||||
})
|
|
@ -0,0 +1,3 @@
|
|||
{
|
||||
"usingComponents": {}
|
||||
}
|
|
@ -0,0 +1,51 @@
|
|||
<!--pages/personal/personal.wxml-->
|
||||
<view class="container">
|
||||
<view class="page-body">
|
||||
<view class="page-section page-section-spacing swiper">
|
||||
<swiper autoplay="true" interval="{{interval}}" duration="{{duration}}" circular="true"
|
||||
current="{{swiperCurrent}}" bindchange="swiperChange">
|
||||
<block wx:for="{{img_url}}" wx:key="index">
|
||||
<swiper-item>
|
||||
<view class="swiper-item">
|
||||
<image src="{{item}}"></image>
|
||||
</view>
|
||||
</swiper-item>
|
||||
</block>
|
||||
</swiper>
|
||||
</view>
|
||||
<view class="dots">
|
||||
<block wx:for="{{img_url}}" wx:key="unique">
|
||||
<view class="dot{{index == swiperCurrent ? ' active' : ''}}"></view>
|
||||
</block>
|
||||
</view>
|
||||
</view>
|
||||
<!--内容-->
|
||||
|
||||
<view class="view-bg top40">
|
||||
<view class="personal-name">
|
||||
{{name}} <text>{{nm_number}}票</text>
|
||||
</view>
|
||||
<!--作品列表-->
|
||||
<view class="works">
|
||||
<block wx:for="{{works_list}}" wx:key="index">
|
||||
<view class="list">
|
||||
<view class="img" bindtap='picture'>
|
||||
<view class="id">{{item.ids}}<text>号</text></view>
|
||||
<image mode="aspectFill" src="{{item.img}}"></image>
|
||||
</view>
|
||||
<view class="personal-right">
|
||||
<view class="text">
|
||||
简介:{{item.text}}
|
||||
</view>
|
||||
<view class="name">
|
||||
<text>{{item.number}}</text>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
</block>
|
||||
<!--view class="upload">
|
||||
<button bindtap="again">继续上传</button>
|
||||
</view-->
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
|
@ -0,0 +1,137 @@
|
|||
/* pages/personal/personal.wxss */
|
||||
.container{
|
||||
padding-bottom: 120rpx;
|
||||
}
|
||||
.page-body{
|
||||
height: 300rpx;
|
||||
position: relative;
|
||||
}
|
||||
.swiper-item image{
|
||||
width: 100%;
|
||||
height: 300rpx;
|
||||
}
|
||||
.dots{
|
||||
display: inline-block;
|
||||
position: absolute;
|
||||
bottom: 20rpx;
|
||||
right: 0;
|
||||
padding: 0 20rpx;
|
||||
}
|
||||
.dots .dot{
|
||||
width: 8rpx;
|
||||
height: 8rpx;
|
||||
background: #fff;
|
||||
float: left;
|
||||
margin:0 4rpx;
|
||||
border-radius: 50%;
|
||||
}
|
||||
.dots .dot.active{
|
||||
background: #2a8de9;
|
||||
}
|
||||
/**/
|
||||
.personal-name{
|
||||
font-size: 40rpx;
|
||||
width: 100%;
|
||||
text-align: center;
|
||||
background-color: #2a8de9;
|
||||
color: #fff;
|
||||
padding: 30rpx 0;
|
||||
}
|
||||
.personal-name text{
|
||||
position: relative;
|
||||
margin-left: 10px;
|
||||
padding-left: 10px;
|
||||
font-size: 28rpx;
|
||||
}
|
||||
.personal-name text::after{
|
||||
position: absolute;
|
||||
width: 1px;
|
||||
height: 33rpx;
|
||||
content: '';
|
||||
left: 0;
|
||||
top: 50%;
|
||||
margin-top: -15rpx;
|
||||
background-color: #fff;
|
||||
}
|
||||
/**/
|
||||
.works{
|
||||
padding: 0 24rpx;
|
||||
}
|
||||
.works .list{
|
||||
width:100% ;
|
||||
float: left;
|
||||
display: inline-block;
|
||||
margin-top: 30rpx;
|
||||
padding: 0 30rpx;
|
||||
}
|
||||
.works .list .img{
|
||||
padding: 16rpx;
|
||||
width: 50%;
|
||||
position: relative;
|
||||
float: left;
|
||||
}
|
||||
.works .list .img image{
|
||||
width: 277rpx;
|
||||
height: 256rpx;
|
||||
}
|
||||
.works .list .img .id{
|
||||
width: 61rpx;
|
||||
height: 72rpx;
|
||||
position: absolute;
|
||||
left: 0;
|
||||
top: 0;
|
||||
font-size: 24rpx;
|
||||
color: #fff;
|
||||
text-align: center;
|
||||
background: url() no-repeat top center;
|
||||
background-size:61rpx 72rpx ;
|
||||
}
|
||||
.works .list .img .id text{
|
||||
display: block;
|
||||
margin-top: -5rpx;
|
||||
}
|
||||
.personal-right{
|
||||
float: left;
|
||||
width: 50%;
|
||||
padding: 16rpx 0 0 20rpx;
|
||||
}
|
||||
.personal-right .text{
|
||||
font-size: 28rpx;
|
||||
display: -webkit-box;
|
||||
overflow: hidden;
|
||||
text-overflow: ellipsis;
|
||||
word-wrap: break-word;
|
||||
white-space: normal !important;
|
||||
-webkit-line-clamp: 2;
|
||||
-webkit-box-orient: vertical;
|
||||
color: #8c8c8c;
|
||||
}
|
||||
.personal-right .name{
|
||||
padding: 20rpx 0;
|
||||
font-size: 30rpx;
|
||||
color: #ff1a1a;
|
||||
margin-bottom: 30rpx;
|
||||
}
|
||||
.personal-right .add{
|
||||
width: 100%;
|
||||
height: 58rpx;
|
||||
line-height: 58rpx;
|
||||
background:#ffc103;
|
||||
padding: 0;
|
||||
border-radius: 0;
|
||||
color: #fff;
|
||||
font-size: 30rpx;
|
||||
}
|
||||
.upload{
|
||||
width: 100%;
|
||||
margin-top: 60rpx;
|
||||
display: inline-block;
|
||||
}
|
||||
.upload button:not([size='mini']){
|
||||
width: 570rpx;
|
||||
border-radius: 8rpx;
|
||||
background-color: #2a8de9;
|
||||
color: #fff;
|
||||
font-size: 30rpx;
|
||||
height: 74rpx;
|
||||
}
|
|
@ -0,0 +1,68 @@
|
|||
{
|
||||
"description": "项目配置文件",
|
||||
"packOptions": {
|
||||
"ignore": []
|
||||
},
|
||||
"setting": {
|
||||
"urlCheck": true,
|
||||
"es6": false,
|
||||
"enhance": true,
|
||||
"postcss": true,
|
||||
"preloadBackgroundData": false,
|
||||
"minified": true,
|
||||
"newFeature": false,
|
||||
"coverView": true,
|
||||
"nodeModules": false,
|
||||
"autoAudits": false,
|
||||
"showShadowRootInWxmlPanel": true,
|
||||
"scopeDataCheck": false,
|
||||
"uglifyFileName": false,
|
||||
"checkInvalidKey": true,
|
||||
"checkSiteMap": true,
|
||||
"uploadWithSourceMap": true,
|
||||
"compileHotReLoad": false,
|
||||
"lazyloadPlaceholderEnable": false,
|
||||
"useMultiFrameRuntime": true,
|
||||
"useApiHook": true,
|
||||
"useApiHostProcess": true,
|
||||
"babelSetting": {
|
||||
"ignore": [],
|
||||
"disablePlugins": [],
|
||||
"outputPath": ""
|
||||
},
|
||||
"useIsolateContext": true,
|
||||
"userConfirmedBundleSwitch": false,
|
||||
"packNpmManually": false,
|
||||
"packNpmRelationList": [],
|
||||
"minifyWXSS": true,
|
||||
"disableUseStrict": false,
|
||||
"minifyWXML": true,
|
||||
"showES6CompileOption": false,
|
||||
"useCompilerPlugins": false
|
||||
},
|
||||
"compileType": "miniprogram",
|
||||
"libVersion": "2.13.0",
|
||||
"appid": "wx11006256adcf321f",
|
||||
"projectname": "DG-vote",
|
||||
"debugOptions": {
|
||||
"hidedInDevtools": []
|
||||
},
|
||||
"isGameTourist": false,
|
||||
"simulatorType": "wechat",
|
||||
"simulatorPluginLibVersion": {},
|
||||
"condition": {
|
||||
"search": {
|
||||
"list": []
|
||||
},
|
||||
"conversation": {
|
||||
"list": []
|
||||
},
|
||||
"game": {
|
||||
"currentL": -1,
|
||||
"list": []
|
||||
},
|
||||
"miniprogram": {
|
||||
"list": []
|
||||
}
|
||||
}
|
||||
}
|
|
@ -0,0 +1,7 @@
|
|||
{
|
||||
"desc": "关于本文件的更多信息,请参考文档 https://developers.weixin.qq.com/miniprogram/dev/framework/sitemap.html",
|
||||
"rules": [{
|
||||
"action": "allow",
|
||||
"page": "*"
|
||||
}]
|
||||
}
|
|
@ -0,0 +1,19 @@
|
|||
const formatTime = date => {
|
||||
const year = date.getFullYear()
|
||||
const month = date.getMonth() + 1
|
||||
const day = date.getDate()
|
||||
const hour = date.getHours()
|
||||
const minute = date.getMinutes()
|
||||
const second = date.getSeconds()
|
||||
|
||||
return [year, month, day].map(formatNumber).join('/') + ' ' + [hour, minute, second].map(formatNumber).join(':')
|
||||
}
|
||||
|
||||
const formatNumber = n => {
|
||||
n = n.toString()
|
||||
return n[1] ? n : '0' + n
|
||||
}
|
||||
|
||||
module.exports = {
|
||||
formatTime: formatTime
|
||||
}
|