当前位置: 首页 > news >正文

淮北发布网站seo教材

淮北发布,网站seo教材,宝塔wordpress 404配置,网站设计制作费用多少前言#xff1a; 最近在使用uniapp开发微信小程序#xff0c;遇到这样一个需求#xff0c;用户想要连续拍照#xff0c;拍完之后可以删除照片#xff0c;保留自己想要的照片#xff0c;然后上传到服务器上。由于原生的方法只能一个个拍照上传#xff0c;所以只能自己通过…前言 最近在使用uniapp开发微信小程序遇到这样一个需求用户想要连续拍照拍完之后可以删除照片保留自己想要的照片然后上传到服务器上。由于原生的方法只能一个个拍照上传所以只能自己通过视频流截取帧的方式开发一个拍照功能组件交互和界面都是自己开发供项目其他需要的地方使用。现做下记录以下是完整代码 // Camera.vue 页面子组件 templateview v-ifshowCamera classpage-body!--图片预览--!-- template v-ifpreviewSrcimage clickhandleBack src../../static/images/common/back.png classclose-icon/imageimage :srcpreviewSrc classpreview-img/image/template --!--图片上传--image clickhandleCancel src../../static/images/common/close.png classclose-icon/image!--摄像头组件--cameradevice-positionbackflashoffrefcameraclasspage-camera/camera!--拍照--image clicktakePhoto src../../static/images/common/photo.png classphoto/image!--选择的图片--view classselect-phototemplate v-ifimageList?.length 0view classstorageview v-for(item, index) in imageList :keyindex styleposition: relative;image :srcitem.tempImagePath classselect-img clickhandlePreviewImg(item)/imageimage clickhandleDelete(index) src../../static/images/common/cross.png classback-icon/image/view/view/templateview classfinish clickhandleFinish确认/view/view!--添加水印--view styleposition: absolute; top: -999999px;canvas stylewidth: 60px; height: 60px iduploadCanvas canvas-iduploadCanvas/canvas/view/view /templatescript setup nameMyCameraimport { ref, onMounted, getCurrentInstance } from vueimport { getToken } from /utils/auth.jsimport { useUserStore, useHomeStore } from /store/index.jsimport { $showToast, validateNull, timestampToDateTime } from /utils/index.jsconst userStore useUserStore()const homeStore useHomeStore()const props defineProps({showCamera: {type: Boolean,default: false},photos: {type: Array,default: []}})const { proxy } getCurrentInstance()const imageList ref([]) // 选择图片const uploadFileArr ref([]) // 已上传的图片const previewSrc ref() // 图片预览const $emit defineEmits([handleCancel, handleFinish])onMounted(() {imageList.value []uploadFileArr.value []})// 添加水印const waterMarkerOperate (filePath) {const address 江苏省xxxxxuni.getImageInfo({src: filePath,success: ress {let ctx uni.createCanvasContext(uploadCanvas, proxy);// 将图片绘制到canvas内 60-宽, 60-高const cWidth 40;const cHeight 60;ctx.drawImage(filePath, 0, 0, 60, cHeight);const fontSize 2;ctx.setFillStyle(rgba(128, 128, 128, 0.9)); // 设置背景色ctx.fillRect(0, 65, cWidth, 34); // 设置背景位置ctx.setFontSize(fontSize); // 设置字体大小ctx.setFillStyle(#FFFFFF); // 设置字体颜色const lineHeight 2; // 行高设置let textToWidth (ress.width / 3) * 0.01; // 绘制文本的左下角x坐标位置let textToHeight (ress.height / 3) * 0.1; // 绘制文本的左下角y坐标位置const nowTime timestampToDateTime(); // 当前日期ctx.fillText(日 期${nowTime}, textToWidth, textToHeight);textToHeight lineHeight;const lines [];let line ;// 遍历字符并拆分行for (const char of address) {const testLine line char;const testWidth ctx.measureText(testLine).width;if (testWidth 24) {lines.push(line);line char;} else {line testLine;}}// 加入最后一行lines.push(line);const addressLabel 地 址;for (let i 0; i lines.length; i) {const textLine lines[i];// 仅在第一行添加地址标签const lineText i 0 ? addressLabel textLine : textLine;ctx.fillText(lineText, textToWidth, textToHeight);textToHeight lineHeight;}// 绘制完成后在下一个事件循环将 canvas 内容导出为临时图片地址ctx.draw(false, (() {setTimeout(() {uni.canvasToTempFilePath({canvasId: uploadCanvas,success: res1 {// 生成水印imageList.value.push({tempImagePath: res1.tempFilePath})},fail: error {console.log(错误, error);},}, proxy);}, 500);})())}});}// 拍照const takePhoto () {// 最多拍摄6张const totalImages (imageList.value?.length || 0) (props.photos?.length || 0);if (totalImages 5) {$showToast(已达拍照上限)return}uni.createCameraContext().takePhoto({quality: high,success: (res) {waterMarkerOperate(res.tempImagePath)}})}// 拍照完成const handleFinish async () {// 调用上传接口const uploadPromises imageList.value?.map(item {return new Promise((resolve, reject) {uni.uploadFile({url: config.baseUrl /uploadUrl,filePath: item?.tempImagePath,name: file,header: {Authorization: Bearer getToken()},success: (res) {try {const data JSON.parse(res.data)if (data.fileName) {resolve(data.fileName)}} catch (e) {reject(e)}}})})})const imgList await Promise.all(uploadPromises);imgList.forEach(img {uploadFileArr.value.push(img)})$emit(handleFinish, JSON.stringify({uploadFileArr: uploadFileArr.value}))$showToast(上传成功)imageList.value []uploadFileArr.value []}// 图片预览const handlePreviewImg (item) {previewSrc.value item?.tempImagePath}// 返回const handleBack () {previewSrc.value }// 关闭const handleCancel () {imageList.value []uploadFileArr.value []$emit(handleCancel)}// 删除图片未上传const handleDelete (index) {imageList.value.splice(index, 1)} /scriptstyle langscss .page-body {width: 100%;height: 100%;position: fixed;top: 0;left: 0;z-index: 99;background: rgba(0, 0, 0, 0.6);display: flex;justify-content: center;align-items: center;.close-icon {position: absolute;left: 30rpx;top: 100rpx;width: 44rpx;height: 44rpx;z-index: 99;}.page-camera {width: 100%;height: 90%;position: absolute;top: 0;}.photo {width: 140rpx;height: 140rpx;position: absolute;bottom: 256rpx;}.select-photo {width: 100%;height: 180rpx;display: flex;flex-direction: row;align-items: center;margin-bottom: 12rpx;background: #000;position: absolute;bottom: 0;.storage {max-width: 540rpx; overflow-x: auto;display: flex;flex-direction: row;}.finish {width: 120rpx;height: 60rpx;line-height: 60rpx;font-size: 28rpx;color: #fff;text-align: center;position: absolute;right: 37rpx;background: #0fad70;border-radius: 10rpx;}.select-img {width: 120rpx;height: 120rpx;margin-right: 16rpx;border-radius: 10rpx;}.back-icon {width: 30rpx;height: 30rpx;position: absolute;right: 0;top: -10rpx;}}.preview-img {width: 100%;height: auto;object-fit: contain;} } /style// 时间戳转成时间 const timestampToDateTime (timestamp) {const date timestamp ? new Date(timestamp) : /* __PURE__ */ new Date();const year date.getFullYear();const month String(date.getMonth() 1).padStart(2, 0);const day String(date.getDate()).padStart(2, 0);const hours String(date.getHours()).padStart(2, 0);const minutes String(date.getMinutes()).padStart(2, 0);const seconds String(date.getSeconds()).padStart(2, 0);return ${year}-${month}-${day} ${hours}:${minutes}:${seconds}; };// 父组件使用 // index.vue import Camera from /components/Camera.vuemy-camera refcameraRef showCameratrue :photosform.photo handleFinishhandleFinish handleCancelhandleCancel/my-camerascript setupconst handleFinish () {// 上传图片完成的逻辑处理}const handleCancel () {// 上传图片取消的逻辑处理} /script欢迎各位大佬有意见的话评论区留言互相交流学习~
http://www.w-s-a.com/news/758648/

相关文章:

  • 做班级网站的目的网站设计制作公司需要什么资质
  • 济南做网站哪家好财政网站平台建设不足
  • php网站建设招聘网站开发与设计论文
  • 上海 网站建设平台 补贴网站开发招标文件范本
  • 延安网站建设公司电话手机上那个网站做农产品推广比较好
  • 增城哪家网站建设好如何做网站实名认证
  • 常州地区做网站个人购物网站需要备案吗
  • 网站建设公司 跨界鱼科技专业做服务器的网站都有哪些
  • 欧洲网站服务器网站建设费用计入什么科目
  • 网站的色调苏州策划网站模板建站公司
  • 怎么看网站用的什么后台公路建设项目可行性研究报告编制办法哪个网站查最新版
  • 可以看的网站的浏览器有哪些专业APP客户端做网站
  • 如何做网站推广自己的产品推荐个网站好吗
  • 网站经营范围wordpress注入点
  • 学校网站开发协议夫妻网络网站建设
  • 福州网站seo推广优化微信商家小程序怎么弄
  • 免费网站推广工具在游戏网站做中介合法
  • 网站建设前的规划网站建设公司六安
  • 公司注册网站开发的行业表述南宁在百度上建网站
  • 创建企业网站国内网站用django做的
  • 云主机网站的空间在哪制作微网站的平台
  • 长沙做网站 青创互联wordpress4.4.1
  • 宜昌哪里有专业做网站的网站开发做什么的
  • 3小说网站开发东莞网站公司哪家好
  • 做网站安全联盟解ps网站设计概述
  • 聊城公司做网站wordpress连接域名
  • 宣传网站建设的意义台州行app官网下载
  • 温州 网站优化网站开发公司前置审批
  • 网站开发具体的工作内容网站下载app免费
  • seo网站建设时文章频率昆山网站建设ikelv