微信小程序实现拍照打卡功能

本文实例为大家分享了微信小程序实现拍照打卡的具体代码,供大家参考,具体内容如下

由于拍照组件是相当于一个块,用隐藏显示的方法不太好,为了更好的用户交互,选择了在一个新的页面调用相机组件,上传图片并保存打卡数据的方式。

小程序端

签到页面wxml

<view class="signBtn" bindtap="signSubmit">
  <view>{{signTime}}</view>
  <view>打卡签到</view>
</view>

签到页面js

onLoad: function (options) {
  setInterval(function(){ showTime(_self); }, 1000);
},

//签到按钮方法
signSubmit(){
  let _self = this.data;
  let userInfo = this.data.ruleInfo;
  let data = {
    //签到需要保存的数据
  }
  if(this.data.signDisabled){//在打卡距离内
    if(this.data.photoDisabled){//需要拍照人员
      this.toPhoto(data);
      return true;
    }
    wx.request({
      url: getApp().globalData.requestPath + '/sign/saveSignRuleData',
      data: data,
      method:'POST',
      header: {'content-type': 'application/json'},
      success: function (res) {
        if(res.data.success){
          wx.showToast({
            title: '打卡成功',
          })
        }else{
          wx.showToast({
            icon:'none',
            title: res.data.msg,
          })
        }
      }
    })
  }else{
    wx.showToast({
      icon: 'none',
      title: '当前位置不允许打卡',
    })
  }
},

//跳转到拍照页面方法
toPhoto(data){
  let signData = JSON.stringify(data);
  wx.navigateTo({
    url: './takePhoto?signData='+signData,    //跳转到自定义的一个拍照页面
  })
}

//自动获取时间,并实时显示
function showTime(obj){
  var today,year,month,day,hour,second,minute;
  var strTime;
  var strDate;
  today=new Date();
  var year=today.getFullYear();
  var month=today.getMonth();
  var day=today.getDate();
  hour = today.getHours();
  minute =today.getMinutes();
  second = today.getSeconds();
  strDate = year+"年"+check(month)+"月"+check(day)+"日";
  strTime = check(hour)+":"+check(minute)+":"+check(second);
  obj.setData({
    signTime : strTime
  })
}

拍照页面wxml

<view>
  <camera class="camera" device-position='{{devicePosition}}'>
    <cover-view>
      <cover-image wx:if="{{havaPhoto}}" src="{{src}}"></cover-image>
    </cover-view>
  </camera>
  <view hidden="{{havaPhoto}}" style="background-color:black;height:15vh">
    <button bindtap="takePhoto" class="takeButton" style="left:45vw">拍照</button>
    <button bindtap="changeCamera" class="takeButton" style="right:15vw">转换</button>
  </view>
  <view hidden="{{!havaPhoto}}" style="background-color:black;height:15vh">
    <button bindtap="retake" class="takeButton" style="left:15vw">重拍</button>
    <button bindtap="signPhoto" class="takeButton" style="left:45vw">打卡</button>
  </view>
</view>

拍照页面js

takePhoto(){//拍照按钮
  let ctx = wx.createCameraContext();
  let _self = this;
  ctx.takePhoto({
    quality: 'high',//high,normal,low
    success: (res) => {
      _self.setData({
        src:res.tempImagePath,
        havaPhoto:true
      })
    }
  })
},
retake(){//重新拍摄
  this.setData({
    havaPhoto:false,
    src:''
  })
},
changeCamera(){//转换摄像头
  if(this.data.devicePosition=='front'){
    this.setData({
      devicePosition:'back'
    })
  }else{
    this.setData({
      devicePosition:'front'
    })
  }
},
signPhoto(){//上传文件,并保存打卡数据
  let _self = this;
  wx.uploadFile({
    url: getApp().globalData.requestPath + '/sign/saveSignPhoto',
    filePath: _self.data.src,
    name: 'filePath',
    formData: {
      'user': _self.data.signData.userId
    },
    success: function (res) {
      let resData = JSON.parse(res.data);
      let data = _self.data.signData;
      data.imagePath = resData.msg;
      if(res.statusCode==200 && resData.success){
        wx.request({
          url: getApp().globalData.requestPath + '/sign/saveSignRuleData',
          data: data,
          method:'POST',
          header: {'content-type': 'application/json'},
          success: function (result) {
            if(result.data.success){
              wx.showToast({
                title: '打卡成功',
              })
              setTimeout(() => {
                wx.navigateBack();
              }, 2000);
            }else{
              wx.showToast({
                icon:'none',
                title: result.data.msg,
              })
            }
          }
        })
      }else{
        wx.showToast({
          title: resData.msg,
        })
        setTimeout(() => {
          wx.navigateBack();
        }, 2000);
      }
    }
  })
}

Java后台

保存照片

@RequestMapping("/saveSignPhoto")
@ResponseBody
public AjaxResult saveSignPhoto(HttpServletRequest request, @RequestParam(value = "filePath", required = false) MultipartFile file) throws IOException {
    String fileName = file.getOriginalFilename();
    String path;
    String type;
    String trueFileName;
    String basePath = "D:/file/";
    String user = request.getParameter("user");
    if(!file.isEmpty()) {
        type = fileName.contains(".") ? fileName.substring(fileName.lastIndexOf(".") + 1, fileName.length()) : null;
        if (type != null) {
            if ("PNG".equals(type.toUpperCase())||"JPG".equals(type.toUpperCase())) {
                // 项目在容器中实际发布运行的根路径
//                    String realPath = request.getSession().getServletContext().getRealPath("/");
                // 自定义的文件名称
                trueFileName = System.currentTimeMillis() + "_" +user + "_" + sdf.format(new Date()) + "." +type;
                // 设置存放图片文件的路径
                path = basePath + trueFileName;
                file.transferTo(new File(path));
            }else {
                return AjaxResult.errorResult("文件类型错误");
            }
        }else {
            return AjaxResult.errorResult("文件类型不存在");
        }
    }else {
        return AjaxResult.errorResult("文件不存在");
    }
    return AjaxResult.successResult(trueFileName);
}

保存打卡数据

@RequestMapping("/saveSignRuleData")
@ResponseBody
public AjaxResult saveSignRuleData(@RequestBody BgCard bgCard){
    boolean flag = signDataService.saveSignRuleData(bgCard);
    if(flag){
        return AjaxResult.successResult();
    }else {
        return AjaxResult.errorResult("保存失败");
    }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • 微信小程序实现打卡日历功能

    生活中有各种可以打卡的app,例如背单词打卡什么的,本人觉得很有意思,于是本人在大二时做了一款诚信状打卡的微信小程序,这里讲述一下编写的过程. 先说一下开发环境:用的是微信web开发工具开发的,后台采用了Bmob后台,比较方便. 先展示一下成果: 话不多说,直接上代码,里面也有挺多的注释,以防自己忘记,当然各位如果直接复制过去肯定不能有当前的效果,注意后台数据的交互,不过做一个界面还是没有问题的. Calendar.wxml 页面文件 页面上显示出来的东西,布局上主要是一个年月栏.上一个月和下一

  • 微信小程序实现打卡签到页面

    本文实例为大家分享了微信小程序实现打卡签到页面的具体代码,供大家参考,具体内容如下 效果图如下所示 .wxml <view class='gs_banner'> <view class='gs_continue'> <view>每日坚持签到</view> <view>总共签到:<text>{{continuity}}</text>天</view> </view> </view> <

  • 微信小程序实战之打卡时钟的绘制

    目录 一.项目展示 二.首页 三.设置 一.项目展示 这是一款简单实用的小时钟工具 分为工作和休息两种状态 用户可以设置相应的时间 所有的时钟记录都会被保存下来 二.首页 首页由计时器.任务输入框和两个计时按钮组成 <view class="container timer {{isRuning ? 'timer--runing': ''}}"> <view class="timer_main"> <view class="ti

  • JavaScript实现微信小程序打卡时钟项目实例

    目录 一.项目展示 二.首页 三.设置 一.项目展示 这是一款简单实用的小时钟工具 分为工作和休息两种状态 用户可以设置相应的时间 所有的时钟记录都会被保存下来 二.首页 首页由计时器.任务输入框和两个计时按钮组成 <view class="container timer {{isRuning ? 'timer--runing': ''}}"> <view class="timer_main"> <view class="ti

  • 微信小程序实现拍照打卡功能

    本文实例为大家分享了微信小程序实现拍照打卡的具体代码,供大家参考,具体内容如下 由于拍照组件是相当于一个块,用隐藏显示的方法不太好,为了更好的用户交互,选择了在一个新的页面调用相机组件,上传图片并保存打卡数据的方式. 小程序端 签到页面wxml <view class="signBtn" bindtap="signSubmit">   <view>{{signTime}}</view>   <view>打卡签到<

  • 微信小程序实现带刻度尺滑块功能

    摘要: 与自带的slider不同的是,它是通过手势滑动标尺得到取值,而不是通过滑动滑块本身. 效果图 场景 当一屏显示不下,例如年龄体重选择,金额选择等大区间需要的选择器,相比自带的picker要直观一些. 思路: 先画一个scrollView 2 装进canvas lineTo画刻度线段,lineTo+fill画出三角形游标,fillText描绘文本标签 通过bindscroll监听刻度尺触摸事件 渲染取值到页面 基本布局 <scroll-view scroll-x="true"

  • 微信小程序中实现车牌输入功能

    目录 前言 背景 大猜想 找规律 结构和样式 组件实现 参数 键盘类型的判断 获取输入内容 组件传参 组件使用 测试 解决键盘类型判断的bug 结束语 组件的代码 使用页面代码 前言 哈哈哈,上新文章啦.好久没有更新啦,今天乘着休息来总结下之前用的到自定义键盘来输入车辆号牌微信组件.下面是效果图,请欣赏: 背景 近期做了一个和车有关的项目,有车肯定就有车牌,我们都知道车牌是有一定规律的,如果简单的给个输入框的话......这里省略一万字哈,从小我的编程老师告诉我不要相信任何用户输入的东西.嗯嗯!

  • 微信小程序 向左滑动删除功能的实现

    微信小程序 向左滑动删除功能的实现 实现效果图: 实现代码: 1.wxml touch-item元素绑定了bindtouchstart.bindtouchmove事件 <view class="container"> <view class="touch-item {{item.isTouchMove ? 'touch-move-active' : ''}}" data-index="{{index}}" bindtouchst

  • 微信小程序实现添加手机联系人功能示例

    本文实例讲述了微信小程序实现添加手机联系人功能.分享给大家供大家参考,具体如下: 1.效果展示   2.关键代码 1)WXML文件 <view bindlongtap="phoneNumTap">{{phoneNum}}</view> 2)JS文件 Page({ data:{ phoneNum:'12345678901'//测试用的号码,并非真实号码 }, // 长按号码响应函数 phoneNumTap:function(){ var that=this; //

  • 微信小程序实现swiper切换卡内嵌滚动条不显示的方法示例

    本文实例讲述了微信小程序实现swiper切换卡内嵌滚动条不显示的方法.分享给大家供大家参考,具体如下: index.wxml文件: <view class="swiper-tab"> <view class="swiper-tab-item {{currentTab==0 ? 'on' : ''}}" data-current="0" bindtap="swichNav">为你推荐</view&g

  • 微信小程序实现的自定义分享功能示例

    本文实例讲述了微信小程序实现的自定义分享功能.分享给大家供大家参考,具体如下: 大家都知道,小程序有分享的功能,可以分享整个程序,也可以自定义分享的内容 onShareAppMessage 在 Page 中定义 onShareAppMessage 函数,设置该页面的分享信息. 只有定义了此事件处理函数,右上角菜单才会显示"分享"按钮 用户点击分享按钮的时候会调用 此事件需要 return 一个 Object,用于自定义分享内容 示例代码: Page({ onShareAppMessag

  • 使用wxapp-img-loader自定义组件实现微信小程序图片预加载功能

    由于微信小程序没有提供类似 Image 这样的 JS 对象,要实现图片的预加载要麻烦一些, wxapp-img-loader自定义组件可以在微信小程序中实现图片预加载功能. 使用 1.下载 wxapp-img-loader项目源代码(https://github.com/o2team/wxa...),将 img-loader 目录拷贝到你的项目中 2.在页面的 WXML 文件中添加以下代码,将组件模板引入 <import src="../../img-loader/img-loader.w

  • 微信小程序实现的五星评价功能示例

    本文实例讲述了微信小程序实现的五星评价功能.分享给大家供大家参考,具体如下: 实现五星评价功能,效果图如下: .wxml文件: <view class="star-title">1.品质效果</view> <view class="star-pos"> <image class='stars' bindtap="changeColor" data-index='0' data-no="{{ite

  • 微信小程序导航栏滑动定位功能示例(实现CSS3的positionsticky效果)

    本文实例讲述了微信小程序导航栏滑动定位功能.分享给大家供大家参考,具体如下: 实现的效果 实现的原理 1. 通过对scroll的监听获取滚动条的scrollTop值; 2. 在导航的class判断scrollTop; 3. 切换position:fixed与position:relative. WXML <view style="height:100%;position:fixed;width:100%;"> <scroll-view scroll-y="f

随机推荐