【uniapp小程序-生成二维码+多个图片文字合并一张图】

这篇具有很好参考价值的文章主要介绍了【uniapp小程序-生成二维码+多个图片文字合并一张图】。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

<!-- 二维码 -->
		<canvas id="qrcode" canvas-id="qrcode" width="120" ></canvas>

		<!-- 生成带小程序码的分享图片 -->
		<canvas canvas-id="shareCanvas" class="share-canvas"></canvas>
#qrcode{
	opacity: 0;
	position: absolute;
	left: -800rpx;
}
/*注意:一定要是px,不然在ios和安卓就会有区别*/
.share-canvas {
	width: 720px;
	height: 1280px;
	background: #fff;
	position: fixed;
	left: -720px;
	top: 0;
}

下载uqrcodejs:https://uqrcode.cn/doc/guide/getting-started.html文章来源地址https://www.toymoban.com/news/detail-775790.html

import UQRCode from 'uqrcodejs'; 
export default{
	data(){
		return{
			val: 'https', // 要生成的二维码的地址
			src: '', // 二维码生成后的图片地址或base64
			bgUrl:'https',//背景图片
		}
	},
	methods:{
			andImg() {
				//分享生成图片
				uni.showLoading({
					title: "正在生成图片"
				})
				if(this.activity_id==11){
				// 获取uQRCode实例
				var qr = new UQRCode();
				// 设置二维码内容
				qr.data = this.val
				// 设置二维码大小,必须与canvas设置的宽高一致
				qr.size = 120;
				// 调用制作二维码方法
				qr.make();
				// 获取canvas上下文
				var canvasContext = uni.createCanvasContext('qrcode', this); // 如果是组件,this必须传入
				// 设置uQRCode实例的canvas上下文
				qr.canvasContext = canvasContext;
				// 调用绘制方法将二维码图案绘制到canvas上
				qr.drawCanvas();
				this.$nextTick(()=>{
					uni.canvasToTempFilePath(
					    {
					        canvasId: 'qrcode',
					        width: 120,
					        height: 120,
					        success: res => {
								if(res.errMsg=='canvasToTempFilePath:ok'){
									this.src = res.tempFilePath//获取生成的二维码地址
									this.onImg()
								}
					        },
					        fail: err => {
					            console.log(err);
					        }
					    }, 
					);
				})
			},
			
			onImg() {
				function toFormateStr (ctx, str, draw_width, lineNum, startX, startY, steps ) {
				
					var strWidth = ctx.measureText(str).width;     // 测量文本源尺寸信息(宽度)
					var startpoint = startY, keyStr = '', sreLN = strWidth / draw_width;
					var liner = Math.ceil(sreLN);     // 计算文本源一共能生成多少行
					let strlen = parseInt(str.length / sreLN); 	// 等比缩放测量一行文本显示多少个字符
								
					// 若文本不足一行,则直接绘制,反之大于传入的最多行数(lineNum)以省略号(...)代替
					if (strWidth  < draw_width) {
					
						ctx.fillText(str, startX, startpoint);
						
					} else {
					
						for (var i = 1; i < liner + 1; i++) {
							let startPoint = strlen * (i-1);
							if (i < lineNum || lineNum == -1) {
								keyStr = str.substr(startPoint, strlen);
								ctx.fillText(keyStr, startX, startpoint);
							} else {
								keyStr = str.substr(startPoint, strlen-5) + '...';
								ctx.fillText(keyStr, startX, startpoint);
								break;
							}
							startpoint = startpoint + steps;
						}
						
					}
				}
				const that = this
				//绘制图片
				that.csimg = true
				that.iconlogo = true
				//创建canvas
				let shareCanvas = uni.createCanvasContext('shareCanvas')
				//绘制背景图片
					//canvas绘制图片(drawImage)无效,显示不了,
					//uniapp的drawImage绘制图片和微信小程序一样,图片路径不能使用网络路径,必须先下载到本地(使用uni.downloadFile()下载成临时文件路径也行)
				uni.downloadFile({
					url:that.bgUrl,
					success(res){
						shareCanvas.drawImage(res.tempFilePath, 0, 120, 720, 1280)
						if(that.companyInfo.company_abbr){
							if(that.companyInfo.company_abbr.length <= 6){
								shareCanvas.setFontSize('56')
							}else if(that.companyInfo.company_abbr.length > 6 && that.companyInfo.company_abbr.length <= 10){
								shareCanvas.setFontSize('48')
							}else if(that.companyInfo.company_abbr.length > 10 && that.companyInfo.company_abbr.length <= 15){
								shareCanvas.setFontSize('32')
							}else if(that.companyInfo.company_abbr.length > 15){
								shareCanvas.setFontSize('26')
							}
						}
						
						shareCanvas.setTextAlign('center')
						
						// 公司名称
						function title() {
							const grds = shareCanvas.createLinearGradient(360, 795, 360, 826)
							shareCanvas.setFontSize('36')
							shareCanvas.setFillStyle('#e7c998')
							
							toFormateStr(shareCanvas, that.companyInfo.company_abbr, 400, 3, 360, 620, 40);
						}
						
						// 奖项
						function prize_title() {
							const grds = shareCanvas.createLinearGradient(360, 795, 360, 826)
							shareCanvas.setFontSize('36')
							shareCanvas.setFillStyle('#e7c998')
							
							toFormateStr(shareCanvas,that.companyInfo.prize.prize_title, 400, 3,360, 800, 40);
						}
						if(that.companyInfo.company_abbr){
							title()
						}
						prize_title()
									
						shareCanvas.setFontSize('24')
						shareCanvas.drawImage(that.src, 300, 1045, 120, 120)
						shareCanvas.draw(false, () => {
							uni.canvasToTempFilePath({
								canvasId: "shareCanvas",
								destWidth: 720, //分享图片尺寸=画布尺寸1*缩放比0.5*像素比21067
								destHeight: 1280,
								success(canvasres) {
									that.csimg = canvasres.tempFilePath
									uni.previewImage({
										urls: [canvasres.tempFilePath]
									})
									uni.hideLoading()
								},
							})
						})
					}
				})
				
			
			
			},
	}
}

到了这里,关于【uniapp小程序-生成二维码+多个图片文字合并一张图】的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • uniapp开发微信小程序生成二维码海报

    模板:

    2024年02月12日
    浏览(53)
  • 使用uniapp生成二维码并下载,小程序扫码进入指定页面

    功能1:通过扫码链接进入小程序指定页面(带参数) 功能2:将网址链接(带参数)在微信小程序中使用二维码展示出来,并可以点击下载二维码图片  扫码链接进入指定页面并且带参数 在小程序管理后台-开发管理-开发设置-扫普通链接二维码打开小程序中,配置链接地址,

    2024年02月11日
    浏览(51)
  • 小程序-Taro如何实现利用Canvas生成一个二维码以及保存图片

    不多说,直接看代码和文字见解: 第一步:先安装weapp-qrcode,利用一个函数触发drawQrcode的方法生成一个二维码Canvas   到这一步其实你的二维码几乎成型了,但是你还有要把它给展示出来 第二步:调用Taro.canvasToTempFilePath的Taro文档的方法,他是用来将Canvas转换为临时路径的图

    2024年02月12日
    浏览(61)
  • 微信小程序使用canvas画布生成二维码海报分享图片(完整示例代码)

    canvas.js //获取应用实例 const app = getApp() Page({ /** 页面的初始数据 */ data: { // canvas _width: 0, //手机屏宽 _heigth: 0,//手机屏高 swiperHeight: 300,//主图图片高度 canvasType: false,//canvas是否显示 loadImagePath: ‘’,//下载的图片 imageUrl: ‘https://cos.myfaka.com/car/service/1.jpg’, //主图网络路径 codeU

    2024年04月12日
    浏览(92)
  • Taro+vue微信小程序根据字符串生成二维码图片,点击弹出图片,长按保存(可用!!!)

    效果:页面加载时生成二维码,点击二维码弹出图片,长按图片可保存。 借鉴了一个大佬的文章https://www.zhangshengrong.com/p/q0arZ9J4ax/#google_vignette

    2024年02月10日
    浏览(58)
  • vue,uniapp生成二维码

    话不多说直接开干 先是vue的 1,首先按照一下依赖 2,在需要使用的页面引入 3,使用 然后是uniapp // 1,新建一个js文件夹,把以下代码放进来,代码我放在最后了,js文件名为uqrcode.js 2,在使用的页面引用 3,在使用前需要有一个画布 4,使用 下面附上js代码

    2024年02月11日
    浏览(38)
  • HarmonyOS学习路之开发篇—AI功能开发(二维码生成及文字识别)

    为应用提供丰富的AI(Artificial Intelligence)能力,支持开箱即用。开发者可以灵活、便捷地选择AI能力,让应用变得更加智能。 已开放的AI能力如下表所示: 能力 简介 二维码生成 根据开发者给定的字符串信息和二维码图片尺寸,返回相应的二维码图片字节流。调用方可以通过

    2024年02月11日
    浏览(64)
  • 使用PHPqrcode根据Url生成图片二维码

    1.首先下载这个插件的源码包 下载地址:PHP QR Code download | SourceForge.net 下载后放到vendeor文件夹下面 引用文件类 }

    2024年02月09日
    浏览(36)
  • 生成微信小程序发布上线后的二维码 、获取微信小程序二维码、微信小程序二维码如何生成?

    情景: 1、在微信小程序审核完成,发布到线上后,想通过扫描小程序二维码进入小程序 2、可分享二维码出去,通过二维码扫码进入小程序 方法: 1、进入微信小程序的后台配置。链接:微信公众平台。(如图一) 2、进入 “设置” -- “ 基本设置” -- “小程序码及线下物

    2024年02月12日
    浏览(52)
  • 如何生成微信小程序二维码,小程序内页二维码

    你自己得有个微信公众号,只需要知道小程序的名字就可以了 生成小程序二维码 第一步编辑素材 第二步搜索小程序名字,然后回车,下一步 第三步选小程序码 小程序内页二维码 第一步编辑素材 第二步搜索小程序名字,然后回车,下一步 第三步点击‘获取更多路径’ 第四

    2024年02月15日
    浏览(47)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包