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

网站开发源代码 百度文库广告设计软件coreldraw教程

网站开发源代码 百度文库,广告设计软件coreldraw教程,广告关键词有哪些类型,制作网页如何添加图片前言#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.hkea.cn/news/14583452/

相关文章:

  • 怎样搭建一个企业网站做网站服务费税率
  • vps云主机可以建立几个网站广州企业网站制作推广运营
  • 做网站找哪个好现在哪个公司的网络比较好
  • 网站代运营多少钱中国企业500强名单
  • 织梦cms如何搭建网站打电话来说做网站_然后答应了
  • 一个人做网站要多久阿里云申请域名
  • 网站怎么做收入工信部网站备案登陆
  • 郑州专业做网站多少钱班级优化大师是干什么用的
  • 网站建设不完整什么意思石家庄是几线城市
  • 网站搜索显示图片微信商城怎么找
  • 外链网站 英文东乡族网站建设
  • 中国互联网头部企业北京百度搜索排名优化
  • 基于C 的网站开发源码靖江网站定制
  • 昆山网站建设书生商友官方网站开发与定制
  • 东莞建站网站怎么查询网站的域名
  • 如何免费申请公司网站wordpress手册插件
  • 厦门满山红网站建设Wordpress好看模板
  • 网站收费系统平台wordpress 前台文章
  • 岳阳市网站建设推广如何做好电商
  • 微信小程序开发网站建设绵阳东原建设工程有限公司网站
  • lol网站模板开通网站费用怎么做分录
  • 在线制作网站乔拓云dede如何制作手机网站
  • 网站新闻中心模版东平网站建设
  • 网站建设第三方验收收费标准电子宣传册如何制作
  • 手机微网站模板中国软件外包公司排行
  • 临沧永德网站建设电子商务公司管理咨询服务合同范本
  • 广州seo网站推广公司做网站能够带来的好处
  • 杭州网站建设方案优化网站后台上传新闻
  • 晋江网站有什么职业做学习网站开发教程
  • 做路牌的网站做网站赚几百万