commit 245d0886b15388b4d8a1cd3f0fb0ea16f32f138e
Author: chen <2659004835@qq.com>
Date: Wed Dec 8 16:24:28 2021 +0800
新增canvas绘制图片、保存、分享
diff --git a/.DS_Store b/.DS_Store
new file mode 100644
index 0000000..e71886d
Binary files /dev/null and b/.DS_Store differ
diff --git a/app.js b/app.js
new file mode 100644
index 0000000..dea4d17
--- /dev/null
+++ b/app.js
@@ -0,0 +1,11 @@
+//app.js
+var urlPath = require('./config.js');
+App({
+ globalData: {
+ isLogin : false
+ },
+ onLaunch: function () {
+ var that = this;
+ wx.setStorageSync('urlPath', urlPath);
+ },
+})
\ No newline at end of file
diff --git a/app.json b/app.json
new file mode 100644
index 0000000..284c505
--- /dev/null
+++ b/app.json
@@ -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"
+}
diff --git a/app.wxss b/app.wxss
new file mode 100644
index 0000000..e432794
--- /dev/null
+++ b/app.wxss
@@ -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);
+}
\ No newline at end of file
diff --git a/config.js b/config.js
new file mode 100644
index 0000000..737a607
--- /dev/null
+++ b/config.js
@@ -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;
\ No newline at end of file
diff --git a/custom-tab-bar/index.js b/custom-tab-bar/index.js
new file mode 100644
index 0000000..05cf828
--- /dev/null
+++ b/custom-tab-bar/index.js
@@ -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
+ }) //可能是改变样式的原因
+ }
+ }
+})
diff --git a/custom-tab-bar/index.json b/custom-tab-bar/index.json
new file mode 100644
index 0000000..32640e0
--- /dev/null
+++ b/custom-tab-bar/index.json
@@ -0,0 +1,3 @@
+{
+ "component": true
+}
\ No newline at end of file
diff --git a/custom-tab-bar/index.wxml b/custom-tab-bar/index.wxml
new file mode 100644
index 0000000..79d688c
--- /dev/null
+++ b/custom-tab-bar/index.wxml
@@ -0,0 +1,8 @@
+
+
+
+
+ {{item.text}}
+
+
diff --git a/custom-tab-bar/index.wxss b/custom-tab-bar/index.wxss
new file mode 100644
index 0000000..b7fb156
--- /dev/null
+++ b/custom-tab-bar/index.wxss
@@ -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;
+}
diff --git a/img/.DS_Store b/img/.DS_Store
new file mode 100644
index 0000000..5008ddf
Binary files /dev/null and b/img/.DS_Store differ
diff --git a/img/background/2.png b/img/background/2.png
new file mode 100644
index 0000000..d398fc6
Binary files /dev/null and b/img/background/2.png differ
diff --git a/img/background/3.png b/img/background/3.png
new file mode 100644
index 0000000..6878d02
Binary files /dev/null and b/img/background/3.png differ
diff --git a/img/banner.png b/img/banner.png
new file mode 100644
index 0000000..ba53838
Binary files /dev/null and b/img/banner.png differ
diff --git a/img/bg_b.png b/img/bg_b.png
new file mode 100644
index 0000000..94692fb
Binary files /dev/null and b/img/bg_b.png differ
diff --git a/img/bg_w.png b/img/bg_w.png
new file mode 100644
index 0000000..9b8bb1e
Binary files /dev/null and b/img/bg_w.png differ
diff --git a/img/button/1.png b/img/button/1.png
new file mode 100644
index 0000000..bc049e2
Binary files /dev/null and b/img/button/1.png differ
diff --git a/img/button/2.png b/img/button/2.png
new file mode 100644
index 0000000..bf4eded
Binary files /dev/null and b/img/button/2.png differ
diff --git a/img/close-icon.png b/img/close-icon.png
new file mode 100644
index 0000000..810fab7
Binary files /dev/null and b/img/close-icon.png differ
diff --git a/img/decorate/1.png b/img/decorate/1.png
new file mode 100644
index 0000000..7efb0ab
Binary files /dev/null and b/img/decorate/1.png differ
diff --git a/img/decorate/2.png b/img/decorate/2.png
new file mode 100644
index 0000000..f97f423
Binary files /dev/null and b/img/decorate/2.png differ
diff --git a/img/decorate/3.png b/img/decorate/3.png
new file mode 100644
index 0000000..4ac0ef4
Binary files /dev/null and b/img/decorate/3.png differ
diff --git a/img/download-icon.png b/img/download-icon.png
new file mode 100644
index 0000000..a44c10b
Binary files /dev/null and b/img/download-icon.png differ
diff --git a/img/face/3.png b/img/face/3.png
new file mode 100644
index 0000000..23966f9
Binary files /dev/null and b/img/face/3.png differ
diff --git a/img/face/4.png b/img/face/4.png
new file mode 100644
index 0000000..3b58c21
Binary files /dev/null and b/img/face/4.png differ
diff --git a/img/icon_01.png b/img/icon_01.png
new file mode 100644
index 0000000..fcbff29
Binary files /dev/null and b/img/icon_01.png differ
diff --git a/img/icon_02.png b/img/icon_02.png
new file mode 100644
index 0000000..cb7de9c
Binary files /dev/null and b/img/icon_02.png differ
diff --git a/img/icon_03.png b/img/icon_03.png
new file mode 100644
index 0000000..72d6372
Binary files /dev/null and b/img/icon_03.png differ
diff --git a/img/icon_04.png b/img/icon_04.png
new file mode 100644
index 0000000..e25b15e
Binary files /dev/null and b/img/icon_04.png differ
diff --git a/img/icon_05.png b/img/icon_05.png
new file mode 100644
index 0000000..e7a5f8b
Binary files /dev/null and b/img/icon_05.png differ
diff --git a/img/icon_06.png b/img/icon_06.png
new file mode 100644
index 0000000..9b97232
Binary files /dev/null and b/img/icon_06.png differ
diff --git a/img/img_01.png b/img/img_01.png
new file mode 100644
index 0000000..ee74138
Binary files /dev/null and b/img/img_01.png differ
diff --git a/img/img_02.png b/img/img_02.png
new file mode 100644
index 0000000..bc8e77b
Binary files /dev/null and b/img/img_02.png differ
diff --git a/img/img_03.png b/img/img_03.png
new file mode 100644
index 0000000..b096e3a
Binary files /dev/null and b/img/img_03.png differ
diff --git a/img/opera/3.png b/img/opera/3.png
new file mode 100644
index 0000000..23966f9
Binary files /dev/null and b/img/opera/3.png differ
diff --git a/img/opera/4.png b/img/opera/4.png
new file mode 100644
index 0000000..3b58c21
Binary files /dev/null and b/img/opera/4.png differ
diff --git a/img/opera/5.png b/img/opera/5.png
new file mode 100644
index 0000000..bf3f22f
Binary files /dev/null and b/img/opera/5.png differ
diff --git a/img/personage/1.png b/img/personage/1.png
new file mode 100644
index 0000000..80a6483
Binary files /dev/null and b/img/personage/1.png differ
diff --git a/img/personage/2.png b/img/personage/2.png
new file mode 100644
index 0000000..3a2c72a
Binary files /dev/null and b/img/personage/2.png differ
diff --git a/img/personage/3.png b/img/personage/3.png
new file mode 100644
index 0000000..2c6291c
Binary files /dev/null and b/img/personage/3.png differ
diff --git a/img/robot.png b/img/robot.png
new file mode 100644
index 0000000..3384992
Binary files /dev/null and b/img/robot.png differ
diff --git a/img/share-icon.png b/img/share-icon.png
new file mode 100644
index 0000000..42d04bc
Binary files /dev/null and b/img/share-icon.png differ
diff --git a/img/word/1.png b/img/word/1.png
new file mode 100644
index 0000000..a2e5027
Binary files /dev/null and b/img/word/1.png differ
diff --git a/img/word/2.png b/img/word/2.png
new file mode 100644
index 0000000..a90124c
Binary files /dev/null and b/img/word/2.png differ
diff --git a/img/word/3.png b/img/word/3.png
new file mode 100644
index 0000000..35651e7
Binary files /dev/null and b/img/word/3.png differ
diff --git a/img/zoom-icon.png b/img/zoom-icon.png
new file mode 100644
index 0000000..9a503f8
Binary files /dev/null and b/img/zoom-icon.png differ
diff --git a/pages/again/again.js b/pages/again/again.js
new file mode 100644
index 0000000..5f5c8bc
--- /dev/null
+++ b/pages/again/again.js
@@ -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 () {
+
+ }
+})
\ No newline at end of file
diff --git a/pages/again/again.json b/pages/again/again.json
new file mode 100644
index 0000000..8835af0
--- /dev/null
+++ b/pages/again/again.json
@@ -0,0 +1,3 @@
+{
+ "usingComponents": {}
+}
\ No newline at end of file
diff --git a/pages/again/again.wxml b/pages/again/again.wxml
new file mode 100644
index 0000000..92aa2f0
--- /dev/null
+++ b/pages/again/again.wxml
@@ -0,0 +1,66 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 距离投票结束还有
+
+
+ {{day}}天 {{hou}}时{{min}}分{{sec}}秒
+
+
+
+ {{tab_number}}人
+ 参与者
+
+
+ {{tab_vote}}票
+ 投票数
+
+
+ {{tab_visit}}次
+ 访问量
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/pages/again/again.wxss b/pages/again/again.wxss
new file mode 100644
index 0000000..da39e56
--- /dev/null
+++ b/pages/again/again.wxss
@@ -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;
+}
\ No newline at end of file
diff --git a/pages/auth/auth.js b/pages/auth/auth.js
new file mode 100644
index 0000000..ee531ef
--- /dev/null
+++ b/pages/auth/auth.js
@@ -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',
+ })
+ }
+ }
+ })
+ }
+})
\ No newline at end of file
diff --git a/pages/auth/auth.json b/pages/auth/auth.json
new file mode 100644
index 0000000..8835af0
--- /dev/null
+++ b/pages/auth/auth.json
@@ -0,0 +1,3 @@
+{
+ "usingComponents": {}
+}
\ No newline at end of file
diff --git a/pages/auth/auth.wxml b/pages/auth/auth.wxml
new file mode 100644
index 0000000..453bbc3
--- /dev/null
+++ b/pages/auth/auth.wxml
@@ -0,0 +1,7 @@
+
+
+ 微信授权页面
+ 此页面是微信授权页面,点击下方按钮弹出授权或跳转页面
+
+ 已经授权点击调转
+
\ No newline at end of file
diff --git a/pages/auth/auth.wxss b/pages/auth/auth.wxss
new file mode 100644
index 0000000..4f2e1b4
--- /dev/null
+++ b/pages/auth/auth.wxss
@@ -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;
+ }
\ No newline at end of file
diff --git a/pages/canvasposter/canvasposter.js b/pages/canvasposter/canvasposter.js
new file mode 100644
index 0000000..f928b88
--- /dev/null
+++ b/pages/canvasposter/canvasposter.js
@@ -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);
+ }
+ });
+ }
+})
diff --git a/pages/canvasposter/canvasposter.json b/pages/canvasposter/canvasposter.json
new file mode 100644
index 0000000..8835af0
--- /dev/null
+++ b/pages/canvasposter/canvasposter.json
@@ -0,0 +1,3 @@
+{
+ "usingComponents": {}
+}
\ No newline at end of file
diff --git a/pages/canvasposter/canvasposter.wxml b/pages/canvasposter/canvasposter.wxml
new file mode 100644
index 0000000..94f3ab6
--- /dev/null
+++ b/pages/canvasposter/canvasposter.wxml
@@ -0,0 +1,75 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ {{item}}
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 提示:
+ 您当前是游客身份
+ 请授权登录后再进行保存、分享操作
+
+
+ 申请 获取你的昵称、头像、地区及性别
+
+ 暂不授权
+
+ 立即授权
+
+
+
+
+
\ No newline at end of file
diff --git a/pages/canvasposter/canvasposter.wxss b/pages/canvasposter/canvasposter.wxss
new file mode 100644
index 0000000..5d2f6f1
--- /dev/null
+++ b/pages/canvasposter/canvasposter.wxss
@@ -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;}
diff --git a/pages/index/index.js b/pages/index/index.js
new file mode 100644
index 0000000..9985826
--- /dev/null
+++ b/pages/index/index.js
@@ -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
+ });
+ }
+ }
+})
\ No newline at end of file
diff --git a/pages/index/index.json b/pages/index/index.json
new file mode 100644
index 0000000..8835af0
--- /dev/null
+++ b/pages/index/index.json
@@ -0,0 +1,3 @@
+{
+ "usingComponents": {}
+}
\ No newline at end of file
diff --git a/pages/index/index.wxml b/pages/index/index.wxml
new file mode 100644
index 0000000..7868b13
--- /dev/null
+++ b/pages/index/index.wxml
@@ -0,0 +1,84 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 距离投票结束还有
+
+
+ {{day}}天 {{hou}}时{{min}}分{{sec}}秒
+
+
+
+ {{tab_number}}人
+ 参与者
+
+
+ {{tab_vote}}票
+ 投票数
+
+
+ {{tab_visit}}次
+ 访问量
+
+
+
+
+
+
+
+
+
+
+
+
+
+ {{item.ids}}号
+
+
+
+ 简介:{{item.text}}
+
+
+ {{item.name}} {{item.number}}
+
+
+
+
+
+
+ 没有更多内容
+
+
+
+
+ 活动规则
+
+
+
+
diff --git a/pages/index/index.wxss b/pages/index/index.wxss
new file mode 100644
index 0000000..1a0608b
--- /dev/null
+++ b/pages/index/index.wxss
@@ -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;
+}
\ No newline at end of file
diff --git a/pages/personal/personal.js b/pages/personal/personal.js
new file mode 100644
index 0000000..19e514f
--- /dev/null
+++ b/pages/personal/personal.js
@@ -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'
+ });
+ }
+ }
+ })
+ }
+ },
+})
\ No newline at end of file
diff --git a/pages/personal/personal.json b/pages/personal/personal.json
new file mode 100644
index 0000000..8835af0
--- /dev/null
+++ b/pages/personal/personal.json
@@ -0,0 +1,3 @@
+{
+ "usingComponents": {}
+}
\ No newline at end of file
diff --git a/pages/personal/personal.wxml b/pages/personal/personal.wxml
new file mode 100644
index 0000000..f1d2436
--- /dev/null
+++ b/pages/personal/personal.wxml
@@ -0,0 +1,52 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ {{name}} {{nm_number}}票
+
+
+
+
+
+
+ {{item.ids}}号
+
+
+
+
+ 简介:{{item.text}}
+
+
+ {{item.number}}
+
+
+
+
+
+
+
+
+
diff --git a/pages/personal/personal.wxss b/pages/personal/personal.wxss
new file mode 100644
index 0000000..13fe8bd
--- /dev/null
+++ b/pages/personal/personal.wxss
@@ -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;
+}
\ No newline at end of file
diff --git a/pages/picture/picture.js b/pages/picture/picture.js
new file mode 100644
index 0000000..9b45837
--- /dev/null
+++ b/pages/picture/picture.js
@@ -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'
+ });
+ }
+ }
+ })
+ }
+ }
+})
\ No newline at end of file
diff --git a/pages/picture/picture.json b/pages/picture/picture.json
new file mode 100644
index 0000000..ccfc528
--- /dev/null
+++ b/pages/picture/picture.json
@@ -0,0 +1,5 @@
+{
+ "usingComponents": {
+ "mp-tabbar": "../../custom-tab-bar/index"
+ }
+}
\ No newline at end of file
diff --git a/pages/picture/picture.wxml b/pages/picture/picture.wxml
new file mode 100644
index 0000000..a774311
--- /dev/null
+++ b/pages/picture/picture.wxml
@@ -0,0 +1,72 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 距离投票结束还有
+
+
+ {{day}}天 {{hou}}时{{min}}分{{sec}}秒
+
+
+
+ {{tab_number}}人
+ 参与者
+
+
+ {{tab_vote}}票
+ 投票数
+
+
+ {{tab_visit}}次
+ 访问量
+
+
+
+
+
+
+ {{ids}}号
+
+
+
+
+
+ {{name}} {{number}}
+
+
+
+
+
+
+
+ 活动规则
+
+
+
diff --git a/pages/picture/picture.wxss b/pages/picture/picture.wxss
new file mode 100644
index 0000000..44daae9
--- /dev/null
+++ b/pages/picture/picture.wxss
@@ -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;
+}
\ No newline at end of file
diff --git a/pages/ranking/ranking.js b/pages/ranking/ranking.js
new file mode 100644
index 0000000..ea6d2ea
--- /dev/null
+++ b/pages/ranking/ranking.js
@@ -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); //失败
+ }
+ }
+ });
+ }
+})
\ No newline at end of file
diff --git a/pages/ranking/ranking.json b/pages/ranking/ranking.json
new file mode 100644
index 0000000..8835af0
--- /dev/null
+++ b/pages/ranking/ranking.json
@@ -0,0 +1,3 @@
+{
+ "usingComponents": {}
+}
\ No newline at end of file
diff --git a/pages/ranking/ranking.wxml b/pages/ranking/ranking.wxml
new file mode 100644
index 0000000..183f1ed
--- /dev/null
+++ b/pages/ranking/ranking.wxml
@@ -0,0 +1,33 @@
+
+
+
+
+ 投票排行榜
+
+
+
+
+
+
+
+
+ 排名
+ 姓名
+ 作品序号
+ 票数
+
+
+
+
+ {{item.ranks}}
+ {{item.name}}
+
+ {{item.ids}}号
+
+
+ {{item.number}}
+
+
+
+
+
diff --git a/pages/ranking/ranking.wxss b/pages/ranking/ranking.wxss
new file mode 100644
index 0000000..c68597c
--- /dev/null
+++ b/pages/ranking/ranking.wxss
@@ -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;
+}
\ No newline at end of file
diff --git a/pages/rule/rule.js b/pages/rule/rule.js
new file mode 100644
index 0000000..d25b0d6
--- /dev/null
+++ b/pages/rule/rule.js
@@ -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 () {
+
+ }
+})
\ No newline at end of file
diff --git a/pages/rule/rule.json b/pages/rule/rule.json
new file mode 100644
index 0000000..8835af0
--- /dev/null
+++ b/pages/rule/rule.json
@@ -0,0 +1,3 @@
+{
+ "usingComponents": {}
+}
\ No newline at end of file
diff --git a/pages/rule/rule.wxml b/pages/rule/rule.wxml
new file mode 100644
index 0000000..470d7e3
--- /dev/null
+++ b/pages/rule/rule.wxml
@@ -0,0 +1,59 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 距离投票结束还有
+
+
+ {{day}}天 {{hou}}时{{min}}分{{sec}}秒
+
+
+
+ {{tab_number}}人
+ 参与者
+
+
+ {{tab_vote}}票
+ 投票数
+
+
+ {{tab_visit}}次
+ 访问量
+
+
+
+
+
+
+
+ 活动规则
+
+
+
+
+
+
+
diff --git a/pages/rule/rule.wxss b/pages/rule/rule.wxss
new file mode 100644
index 0000000..ee47130
--- /dev/null
+++ b/pages/rule/rule.wxss
@@ -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%;
+}
\ No newline at end of file
diff --git a/pages/sign/sign.js b/pages/sign/sign.js
new file mode 100644
index 0000000..495cc9c
--- /dev/null
+++ b/pages/sign/sign.js
@@ -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'
+ });
+ }
+ }
+ });
+ }
+})
\ No newline at end of file
diff --git a/pages/sign/sign.json b/pages/sign/sign.json
new file mode 100644
index 0000000..8835af0
--- /dev/null
+++ b/pages/sign/sign.json
@@ -0,0 +1,3 @@
+{
+ "usingComponents": {}
+}
\ No newline at end of file
diff --git a/pages/sign/sign.wxml b/pages/sign/sign.wxml
new file mode 100644
index 0000000..8615673
--- /dev/null
+++ b/pages/sign/sign.wxml
@@ -0,0 +1,76 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 距离投票结束还有
+
+
+ {{day}}天 {{hou}}时{{min}}分{{sec}}秒
+
+
+
+ {{tab_number}}人
+ 参与者
+
+
+ {{tab_vote}}票
+ 投票数
+
+
+ {{tab_visit}}次
+ 访问量
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/pages/sign/sign.wxss b/pages/sign/sign.wxss
new file mode 100644
index 0000000..da39e56
--- /dev/null
+++ b/pages/sign/sign.wxss
@@ -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;
+}
\ No newline at end of file
diff --git a/pages/user/user.js b/pages/user/user.js
new file mode 100644
index 0000000..c2ff692
--- /dev/null
+++ b/pages/user/user.js
@@ -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); //失败
+ }
+ }
+ });
+ }
+})
\ No newline at end of file
diff --git a/pages/user/user.json b/pages/user/user.json
new file mode 100644
index 0000000..8835af0
--- /dev/null
+++ b/pages/user/user.json
@@ -0,0 +1,3 @@
+{
+ "usingComponents": {}
+}
\ No newline at end of file
diff --git a/pages/user/user.wxml b/pages/user/user.wxml
new file mode 100644
index 0000000..8ad5ee5
--- /dev/null
+++ b/pages/user/user.wxml
@@ -0,0 +1,51 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ {{name}} {{nm_number}}票
+
+
+
+
+
+
+ {{item.ids}}号
+
+
+
+
+ 简介:{{item.text}}
+
+
+ {{item.number}}
+
+
+
+
+
+
+
+
diff --git a/pages/user/user.wxss b/pages/user/user.wxss
new file mode 100644
index 0000000..5c68900
--- /dev/null
+++ b/pages/user/user.wxss
@@ -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;
+}
\ No newline at end of file
diff --git a/project.config.json b/project.config.json
new file mode 100644
index 0000000..2fa6c75
--- /dev/null
+++ b/project.config.json
@@ -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": []
+ }
+ }
+}
\ No newline at end of file
diff --git a/sitemap.json b/sitemap.json
new file mode 100644
index 0000000..ca02add
--- /dev/null
+++ b/sitemap.json
@@ -0,0 +1,7 @@
+{
+ "desc": "关于本文件的更多信息,请参考文档 https://developers.weixin.qq.com/miniprogram/dev/framework/sitemap.html",
+ "rules": [{
+ "action": "allow",
+ "page": "*"
+ }]
+}
\ No newline at end of file
diff --git a/utils/util.js b/utils/util.js
new file mode 100644
index 0000000..dbadbb8
--- /dev/null
+++ b/utils/util.js
@@ -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
+}