电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

JavaScript基于用戶照片姓名生成海報

瀏覽:121日期:2023-10-24 17:00:13

前言

最近在為公司的一個比賽制作專題頁,碰到一個使用參賽者上傳的照片生成專屬海報的需求,實現過程中用到了一些以前沒用過的 api,也踩了一些坑,于是將其記錄下來。

需求描述

用戶點擊按鈕進行照片上傳 照片上傳完成后,將照片進行裁剪,并和海報背景、姓名等組合得到海報 將生成的海報上傳

效果大概如下:

海報背景:

JavaScript基于用戶照片姓名生成海報

成品:

JavaScript基于用戶照片姓名生成海報

實現過程

1、初始化 canvas

canvas#poster-canvas(width=’960’ height=’1280’)function initCanvas() {canvasCtx = document.getElementById('poster-canvas').getContext(’2d’);}

2、繪制海報背景

海報背景為預先提供的一張照片,將其設置到一個隱藏的 img 標簽里面,并且預留一個 canvas 元素用于繪制海報:

img.poster-background(src=’/assets/xxx/poster-background.jpeg’)

頁面加載完成后,將海報背景繪制到 canvas 內:

$(’img.poster-background’).on(’load’, function () { var backgroundImg = $(’img.poster-background’)[0]; canvasCtx.drawImage(backgroundImg, 0, 0, 960, 1280); renderName();});

海報背景繪制完成之后,需要將用戶姓名繪制到特定位置。由于用戶姓名長度不一,因此需要進行計算確定字體大小:

function renderName() { var name = $(’input[name='chName']’).val(); var fontSize; if (name.length < 3) { fontSize = 100; } else { fontSize = parseInt(320 / name.length); } canvasCtx.font = 'bold ' + fontSize + 'px Courier New'; canvasCtx.fillStyle = '#de071b'; canvasCtx.fillText(name, 20, 1066);}

3、上傳照片

使用 file 類型的 input 元素,因為頁面上表現為點擊按鈕,因此使用經典的將 input 元素透明化并覆蓋按鈕的方法:

a.upload-btn input#photo(type=’file’ name=’photo’ accept=’image/jpeg, image/png’) | 上傳自己的照片生成專屬海報.upload-btn input { position: absolute; left: 0; top: 0; opacity: 0; width: 100%; height: 68px; cursor: pointer;}

然后監聽 input 元素的 change 事件,然后使用 FormData API 構造表單數據,使用 ajax 進行異步上傳,照片上傳完成之后。得到一個地址,將這個地址設置到頁面上預留的一個 img 標簽里面:

$(’#photo’).on(’change’, function (e) { var file = e.target.files[0]; var type = file.type; if (type !== ’image/jpeg’ && type !== ’image/png’) { window.toastr.error(’請上傳 jpg 或 png 格式的圖片’); } else { var formData = new FormData(); formData.append(’avatar’, file); $.ajax({ type: ’POST’, url: ’/upload_url’, data: formData, contentType: false, processData: false, success: function(result) { var avatarUrl = result.data.url; $(’img.avatar’).attr(’src’, avatarUrl); }, error: function(err) { } }); }});

4、繪制照片

海報中放置照片的區域為正方形,但是用戶上傳的照片卻不一定,因此需要對照片進行裁剪,裁剪的原則為取照片中間部分。然后將裁剪參數傳進 canvas 的 drawImage 方法,進行繪制:

$(’img.avatar’).on(’load’, function () { var avatarImg = $(’img.avatar’)[0]; var originWidth = avatarImg.width; var originHeight = avatarImg.height; var newWidth, cutStartX, cutStartY; if (originWidth < originHeight) { newWidth = originWidth; cutStartX = 0; cutStartY = (originHeight - originWidth) / 2; } else if (originWidth > originHeight) { newWidth = originHeight; cutStartX = (originWidth - originHeight) / 2; cutStartY = 0; } else { newWidth = originWidth; cutStartX = 0; cutStartY = 0; } canvasCtx.drawImage(avatarImg, cutStartX, cutStartY, newWidth, newWidth, 0, 0, 960, 960); uploadPoster(); });

前面繪制海報背景和這里繪制照片,調用的是同一個方法,只不過后者多傳進去了裁剪參數。但是需要注意的是,裁剪參數是在繪制位置之前傳進去的,而不是簡單的補在后面:

canvasCtx.drawImage(backgroundImg, 0, 0, 960, 1280);

canvasCtx.drawImage(avatarImg, cutStartX, cutStartY, newWidth, newWidth, 0, 0, 960, 960);

5、上傳海報

依然使用 FormData API,因此需要先用 canvas 構造一個 Blob 對象。新版本的 Chrome 和 Firefox 支持 canvas 的 toBlob 方法,可以直接使用:

document.getElementById('poster-canvas').toBlob(function (blob) {});

其它瀏覽器里,可以先用 toDataURL方法得到 base64 格式的圖片數據,再轉為 Blob:

var blob = dataURLtoBlob(document.getElementById('poster-canvas').toDataURL());function dataURLtoBlob(dataurl) { if (dataurl.indexOf(’base64’) < 0) { dataurl = ’data:image/jpeg;base64,’ + dataurl; } var arr = dataurl.split(’,’); var mime = arr[0].match(/:(.*?);/)[1]; var bstr = atob(arr[1]); var n = bstr.length; var u8arr = new Uint8Array(n); while (n --) { u8arr[n] = bstr.charCodeAt(n); } return new Blob([u8arr], {type: mime});}

然后進行上傳,步驟和前面上傳照片一致:

var formData = new FormData();formData.append(’poster’, blob);$.ajax({ type: ’POST’, url: ’/upload_poster_url’, data: formdata, contentType: false, processData: false, success: function(result) { }, error: function(err) { }});

至此,整個流程完結。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 山西3A认证|太原AAA信用认证|投标AAA信用证书-山西AAA企业信用评级网 | 工业胀紧套_万向节联轴器_链条-规格齐全-型号选购-非标订做-厂家批发价格-上海乙谛精密机械有限公司 | 深圳市万色印象美业有限公司 | 江西自考网-江西自学考试网 | 天空彩票天下彩,天空彩天空彩票免费资料,天空彩票与你同行开奖,天下彩正版资料大全 | 老房子翻新装修,旧房墙面翻新,房屋防水补漏,厨房卫生间改造,室内装潢装修公司 - 一修房屋快修官网 | 寮步纸箱厂_东莞纸箱厂 _东莞纸箱加工厂-东莞市寮步恒辉纸制品厂 | 洛阳网站建设_洛阳网站优化_网站建设平台_洛阳香河网络科技有限公司 | 金蝶帐无忧|云代账软件|智能财税软件|会计代账公司专用软件 | 温州富欧金属封头-不锈钢封头厂家 | 无锡装修装潢公司,口碑好的装饰装修公司-无锡索美装饰设计工程有限公司 | SRRC认证_电磁兼容_EMC测试整改_FCC认证_SDOC认证-深圳市环测威检测技术有限公司 | ERP企业管理系统永久免费版_在线ERP系统_OA办公_云版软件官网 | 便携式谷丙转氨酶检测仪|华图生物科技百科 | 石英陶瓷,石英坩埚,二氧化硅陶瓷-淄博百特高新材料有限公司 | Trimos测长机_测高仪_TESA_mahr,WYLER水平仪,PWB对刀仪-德瑞华测量技术(苏州)有限公司 | 威海防火彩钢板,威海岩棉复合板,威海彩钢瓦-文登区九龙岩棉复合板厂 | 防爆型气象站_农业气象站_校园气象站_农业四情监测系统「山东万象环境科技有限公司」 | 建筑工程资质合作-工程资质加盟分公司-建筑资质加盟 | 【星耀裂变】_企微SCRM_任务宝_视频号分销裂变_企业微信裂变增长_私域流量_裂变营销 | 武汉印刷厂-不干胶标签印刷厂-武汉不干胶印刷-武汉标签印刷厂-武汉标签制作 - 善进特种标签印刷厂 | 耐高温风管_耐高温软管_食品级软管_吸尘管_钢丝软管_卫生级软管_塑料波纹管-东莞市鑫翔宇软管有限公司 | 水篦子|雨篦子|镀锌格栅雨水篦子|不锈钢排水篦子|地下车库水箅子—安平县云航丝网制品厂 | 杭州中央空调维修_冷却塔/新风机柜/热水器/锅炉除垢清洗_除垢剂_风机盘管_冷凝器清洗-杭州亿诺能源有限公司 | 上海平衡机-单面卧式动平衡机-万向节动平衡机-圈带动平衡机厂家-上海申岢动平衡机制造有限公司 | 纸张环压仪-纸张平滑度仪-杭州纸邦自动化技术有限公司 | 上海办公室装修,办公楼装修设计,办公空间设计,企业展厅设计_写艺装饰公司 | 拉力机-拉力试验机-万能试验机-电子拉力机-拉伸试验机-剥离强度试验机-苏州皖仪实验仪器有限公司 | 细砂提取机,隔膜板框泥浆污泥压滤机,螺旋洗砂机设备,轮式洗砂机械,机制砂,圆锥颚式反击式破碎机,振动筛,滚筒筛,喂料机- 上海重睿环保设备有限公司 | 氢氧化钙设备, 氢氧化钙生产线-淄博惠琛工贸有限公司 | 丹佛斯变频器-丹佛斯压力开关-变送器-广州市风华机电设备有限公司 | 广东西屋电气有限公司-广东西屋电气有限公司 | 模型公司_模型制作_沙盘模型报价-中国模型网 | SOUNDWELL 编码器|电位器|旋转编码器|可调电位器|编码开关厂家-广东升威电子制品有限公司 | 上海租奔驰_上海租商务车_上海租车网-矢昂汽车服务公司 | 防爆大气采样器-防爆粉尘采样器-金属粉尘及其化合物采样器-首页|盐城银河科技有限公司 | 大行程影像测量仪-探针型影像测量仪-增强型影像测量仪|首丰百科 大通天成企业资质代办_承装修试电力设施许可证_增值电信业务经营许可证_无人机运营合格证_广播电视节目制作许可证 | 泰国专线_泰国物流专线_广州到泰国物流公司-泰廊曼国际 | 螺旋丝杆升降机-SWL蜗轮-滚珠丝杆升降机厂家-山东明泰传动机械有限公司 | 定制奶茶纸杯_定制豆浆杯_广东纸杯厂_[绿保佳]一家专业生产纸杯碗的厂家 | 蓝鹏测控平台 - 智慧车间系统 - 车间生产数据采集与分析系统 |