新增canvas绘制图片、保存、分享

master
chen 2021-12-08 16:24:28 +08:00
commit 245d0886b1
88 changed files with 4467 additions and 0 deletions

BIN
.DS_Store vendored Normal file

Binary file not shown.

11
app.js Normal file
View File

@ -0,0 +1,11 @@
//app.js
var urlPath = require('./config.js');
App({
globalData: {
isLogin : false
},
onLaunch: function () {
var that = this;
wx.setStorageSync('urlPath', urlPath);
},
})

53
app.json Normal file
View File

@ -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"
}

120
app.wxss Normal file
View File

@ -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);
}

23
config.js Normal file
View File

@ -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;

38
custom-tab-bar/index.js Normal file
View File

@ -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
}) //可能是改变样式的原因
}
}
})

View File

@ -0,0 +1,3 @@
{
"component": true
}

View File

@ -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>

37
custom-tab-bar/index.wxss Normal file
View File

@ -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;
}

BIN
img/.DS_Store vendored Normal file

Binary file not shown.

BIN
img/background/2.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 914 KiB

BIN
img/background/3.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 891 KiB

BIN
img/banner.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.0 KiB

BIN
img/bg_b.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

BIN
img/bg_w.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.8 KiB

BIN
img/button/1.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 42 KiB

BIN
img/button/2.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 36 KiB

BIN
img/close-icon.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.5 KiB

BIN
img/decorate/1.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 70 KiB

BIN
img/decorate/2.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 20 KiB

BIN
img/decorate/3.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 90 KiB

BIN
img/download-icon.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.2 KiB

BIN
img/face/3.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 319 KiB

BIN
img/face/4.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 304 KiB

BIN
img/icon_01.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

BIN
img/icon_02.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 37 KiB

BIN
img/icon_03.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.3 KiB

BIN
img/icon_04.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.2 KiB

BIN
img/icon_05.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.1 KiB

BIN
img/icon_06.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

BIN
img/img_01.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

BIN
img/img_02.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 141 KiB

BIN
img/img_03.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 392 KiB

BIN
img/opera/3.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 319 KiB

BIN
img/opera/4.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 304 KiB

BIN
img/opera/5.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 245 KiB

BIN
img/personage/1.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 58 KiB

BIN
img/personage/2.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 179 KiB

BIN
img/personage/3.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 135 KiB

BIN
img/robot.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.8 KiB

BIN
img/share-icon.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.3 KiB

BIN
img/word/1.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 24 KiB

BIN
img/word/2.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 46 KiB

BIN
img/word/3.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 77 KiB

BIN
img/zoom-icon.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.2 KiB

154
pages/again/again.js Normal file
View File

@ -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 () {
}
})

3
pages/again/again.json Normal file
View File

@ -0,0 +1,3 @@
{
"usingComponents": {}
}

66
pages/again/again.wxml Normal file
View File

@ -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>

102
pages/again/again.wxss Normal file
View File

@ -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;
}

17
pages/auth/auth.js Normal file
View File

@ -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',
})
}
}
})
}
})

3
pages/auth/auth.json Normal file
View File

@ -0,0 +1,3 @@
{
"usingComponents": {}
}

7
pages/auth/auth.wxml Normal file
View File

@ -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>

68
pages/auth/auth.wxss Normal file
View File

@ -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;
}

View File

@ -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);
}
});
}
})

View File

@ -0,0 +1,3 @@
{
"usingComponents": {}
}

View File

@ -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>

View File

@ -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;}

438
pages/index/index.js Normal file
View File

@ -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
});
}
}
})

3
pages/index/index.json Normal file
View File

@ -0,0 +1,3 @@
{
"usingComponents": {}
}

84
pages/index/index.wxml Normal file
View File

@ -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>

136
pages/index/index.wxss Normal file
View File

@ -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;
}

217
pages/personal/personal.js Normal file
View File

@ -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'
});
}
}
})
}
},
})

View File

@ -0,0 +1,3 @@
{
"usingComponents": {}
}

View File

@ -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>

View File

@ -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;
}

202
pages/picture/picture.js Normal file
View File

@ -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'
});
}
}
})
}
}
})

View File

@ -0,0 +1,5 @@
{
"usingComponents": {
"mp-tabbar": "../../custom-tab-bar/index"
}
}

View File

@ -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>

View File

@ -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;
}

107
pages/ranking/ranking.js Normal file
View File

@ -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); //失败
}
}
});
}
})

View File

@ -0,0 +1,3 @@
{
"usingComponents": {}
}

View File

@ -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>

151
pages/ranking/ranking.wxss Normal file
View File

@ -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;
}

138
pages/rule/rule.js Normal file
View File

@ -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 () {
}
})

3
pages/rule/rule.json Normal file
View File

@ -0,0 +1,3 @@
{
"usingComponents": {}
}

59
pages/rule/rule.wxml Normal file
View File

@ -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>

56
pages/rule/rule.wxss Normal file
View File

@ -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%;
}

277
pages/sign/sign.js Normal file
View File

@ -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'
});
}
}
});
}
})

3
pages/sign/sign.json Normal file
View File

@ -0,0 +1,3 @@
{
"usingComponents": {}
}

76
pages/sign/sign.wxml Normal file
View File

@ -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>

102
pages/sign/sign.wxss Normal file
View File

@ -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;
}

137
pages/user/user.js Normal file
View File

@ -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); //失败
}
}
});
}
})

3
pages/user/user.json Normal file
View File

@ -0,0 +1,3 @@
{
"usingComponents": {}
}

51
pages/user/user.wxml Normal file
View File

@ -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>

137
pages/user/user.wxss Normal file
View File

@ -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;
}

68
project.config.json Normal file
View File

@ -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": []
}
}
}

7
sitemap.json Normal file
View File

@ -0,0 +1,7 @@
{
"desc": "关于本文件的更多信息,请参考文档 https://developers.weixin.qq.com/miniprogram/dev/framework/sitemap.html",
"rules": [{
"action": "allow",
"page": "*"
}]
}

19
utils/util.js Normal file
View File

@ -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
}