怎么通过html5实现拼图功能效果
发表于:2024-11-27 作者:千家信息网编辑
千家信息网最后更新 2024年11月27日,这篇"怎么通过html5实现拼图功能效果"文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇
千家信息网最后更新 2024年11月27日怎么通过html5实现拼图功能效果
这篇"怎么通过html5实现拼图功能效果"文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇"怎么通过html5实现拼图功能效果"文章吧。
实现的思路其实挺简单的,主要是通过服务端获取图片链接,图片宽度,图片高度,然后利用简单的递归实现就行了(注意移动端需要采用2倍数的比例,否则会出现图片模糊的问题)
/** * canvas绘图数据 * @param {Object[]} option.photoData * @param {string} option.photoData[].photo - 照片的链接地址 * @param {number} option.photoData[].width - 照片的宽度 * @param {number} option.photoData[].height - 照片的高度 * @param {Object[]} option.wordData * @param {string} option.wordData[].color - 文字的颜色 * @param {number} option.wordData[].fontSize - 文字的大小 * @param {string} option.wordData[].fontWeight - 文字的粗细 * @param {number} option.wordData[].left - 文字的左边距 * @param {number} option.wordData[].top - 文字的上边距 * @param {string} option.wordData[].word - 文字的内容 * @param {Object[]} option.iconData * @param {string} option.iconData[].photo - icon的链接地址 * @param {number} option.iconData[].left - icon的左边距 * @param {number} option.iconData[].top - icon的上边距 * @param {number} option.iconData[].width - icon的宽度 * @param {number} option.iconData[].height - icon的高度 * */function canvasDraw(option){ var canvas = document.createElement('canvas'), ctx = canvas.getContext('2d'), clientWidth = document.documentElement.clientWidth, canvasHeight = 0, distance = 0, photoCount = 0, iconCount = 0; // canvas中手机上一倍绘图会模糊,需采用两倍,pc端不会。 clientWidth = clientWidth > 480? 480 * 2 : clientWidth * 2; option.photoData.forEach(function(item,index,picArr){ if (!index) { item.distance = 0; }else if(index){ distance += Math.floor(clientWidth / option.photoData[index - 1].width * option.photoData[index - 1].height) item.distance = distance; } canvasHeight += Math.floor(clientWidth / item.width * item.height); item.imgHeight = Math.floor(clientWidth / item.width * item.height); }) console.log(option.photoData) if (ctx) { canvas.width = clientWidth; canvas.height = canvasHeight + clientWidth / 4 * 2 ctx.fillStyle = '#fff' ctx.fillRect(0, 0, canvas.width, canvas.height) // 绘制图片文字 if(option.wordData.length){ option.wordData.forEach(function(item,index){ ctx.fillStyle = item.color; ctx.font = 'normal normal ' + item.fontWeight + ' ' + calculate(item.fontSize) + 'px Microsoft YaHei'; ctx.textAlign = 'left'; ctx.fillText(item.word, calculate(item.left), canvasHeight + calculate(item.top)); }) } //按比例计算不同手机的百分比间距 function calculate(num){ return Math.floor(clientWidth * num / 750) } drawPhoto('photo0') function drawPhoto(photoDom){ var photoDom = new Image(); photoDom.setAttribute('crossOrigin', 'Anonymous'); photoDom.src = option.photoData[photoCount].photo; photoDom.onload = function(){ ctx.drawImage(photoDom, 0, option.photoData[photoCount].distance, clientWidth, option.photoData[photoCount].imgHeight); photoCount++; if (photoCount == option.photoData.length) { drawIcon('icon0') function drawIcon(iconDom){ var iconDom = new Image(); iconDom.setAttribute('crossOrigin', 'Anonymous'); iconDom.src = option.iconData[iconCount].icon; iconDom.onload = function(){ ctx.drawImage(iconDom, calculate(option.iconData[iconCount].left), canvasHeight + calculate(option.iconData[iconCount].top), calculate(option.iconData[iconCount].width), calculate(option.iconData[iconCount].height)) iconCount++; if (iconCount == option.iconData.length) { var imageURL = canvas.toDataURL("image/jpeg") document.getElementsByClassName('shareImg')[0].setAttribute('src', imageURL) //将闭包引用清除,释放内存; drawPhoto = null; }else{ drawIcon('icon' + iconCount) } } } }else{ drawPhoto('photo'+ photoCount) } } } }else{ console.log('不支持canvas') } }
以上就是关于"怎么通过html5实现拼图功能效果"这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注行业资讯频道。
文字
内容
图片
功能
效果
宽度
照片
链接
高度
上边
地址
手机
文章
比例
知识
篇文章
绘图
不同
价值
倍数
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
泰拉瑞亚多人服务器联机
c 数据库分数查询系统
韩国云服务器应注意什么
上海新炬网络技术上市
电脑数据库丢了怎么找回来
重庆时时彩 软件开发
互联网与科技有什么区别
巴中软件开发规定
数据库加字段显示锁超时
数据库分文件夹
山东滨州网络安全吗
从mysql到神通数据库
证券公司用什么数据库
服务器配置需要什么设备
网络安全培训会医院
软件开发 人 天工时费
食物 gl 数据库
网络安全审查办法开始施行
数据库静态表命名
阿里云服务器扩容技术方案
jsp数据库条件查询
数据库别名在语句中能不能使用
个人网络安全防范常识
甬工惠网络安全
网络安全2019大会西安
数据库与信息检索出来能干啥
静态变量初始化数据库
进入网络安全行业前景
ensp网络技术与应用pdf
湖南服务器虚拟化技术