uniapp實現水印相機

uniapp實現水印相機-livePusher

水印相機

背景

前兩天拿到了一個需求,要求在內部的oaApp中增加一個衛生檢查模塊,這個模塊中的核心訴求就是要求拍照的照片添加水印。對于這個需求,我首先想到的是直接去插件市場,下一個水印相機插件導入使用。可惜,這個oaApp的架子搭建實在是毛坯,很多時候一些簡單方法,并不能直接使用。沒辦法,只能去找一些不那么常規的方法。在網上,找到一些方法使用livePusher和canvas來實現水印相機的效果。

核心livePusher與canvas

livePusher

官方介紹

實時音視頻錄制,也稱直播推流。

這里使用livePusher來實現,調起系統相機,實現攝像頭實時畫面預覽。
頁面布局(頁面需要是 .nvue的文件)

<live-pusher id="livePusher" ref="livePusher" class="livePusher" mode="FHD" beauty="0" whiteness="0":aspect="aspect" min-bitrate="1000" audio-quality="16KHz" device-position="back" :auto-focus="true":muted="true" :enable-camera="true" :enable-mic="false" :zoom="false" @statechange="statechange":style="{ width: windowWidth, height: windowHeight }">
</live-pusher>

onReady時創建 live-pusher 上下文 livePusherContext 對象,并初始化相機開啟預覽。

this.livePusher = uni.createLivePusherContext('livePusher', this);
this.startPreview(); //開啟預覽并設置攝像頭//開始預覽
startPreview() {this.livePusher.startPreview({success: a => {console.log(a)}});
},
一些踩坑的想法

這里沒使用livePusher之前,我的想法是采用webView加plus-camera的方法去構建一個能夠自定義的拍攝頁面。為什么會有這個錯誤的想法,是因為我曾用過webView加plus-barcode構建了自定義的掃碼頁面。實踐發現這個想法是錯誤的,因為無論是uniapp還是plus-camera使用到相機時都是調起系統的相機功能,且在app端使用內嵌相機頁面的api也不支持。

拍照的操作方法
<view class="menu"><!-- 底部菜單區域背景 --><cover-image class="menu-mask" src="/static/image/13@3x.png"></cover-image><!--返回鍵--><cover-image class="menu-back" @click="back" src="/static/image/icon-back@3x.png"></cover-image><!--快門鍵--><cover-image class="menu-snapshot" @tap="snapshot" src="/static/image/condition-data-bj-circles@3x.png"></cover-image><!--反轉鍵--><cover-image class="menu-flip" @tap="flip" src="/static/image/Ranking-cylindricality-top10@3x.png"></cover-image></view>
//抓拍snapshot() {//震動uni.vibrateShort({success: function() {console.log('success');}});this.livePusher.snapshot({success: e => {_this.snapshotsrc = e.message.tempImagePathlet data = {url:_this.snapshotsrc,deptName: _this.deptName,time: _this.time}uni.$emit('waterMark', data);// 發送數據后返回上一頁uni.navigateBack();}});},//反轉flip() {this.livePusher.switchCamera();},
水印添加

用一個相對定位,將你的水印添加到你需要的位置,就可以試下水印和畫面的實時預覽啦。

canvas

前面拍照得到的照片,實際上水印并沒有添加到畫面中,這個時候我們需要使用canvas重新繪制,將圖片和水印繪制在一起。

		<canvas v-if="canvasShow" :style="canvasStyle" canvas-id="watermarkCanvas"></canvas>
// 添加水印的函數addWatermark(imagePath, markDept, markTime) {return new Promise((resolve, reject) => {uni.getImageInfo({src: imagePath,success: (info) => {console.log("info.width, info.height", info.width, info.height);const ctx = uni.createCanvasContext('watermarkCanvas');ctx.drawImage(info.path, 0, 0, info.width, info.height);ctx.width = info.width;ctx.height = info.height;// 設置水印樣式ctx.setFontSize(50); // 設置字體大小ctx.setFillStyle('white'); // 設置水印顏色ctx.setGlobalAlpha(0.5); // 設置水印透明度// 添加水印文字// ctx.fillText(markDept, info.width - 15, info.height - 55);// ctx.fillText(markTime, info.width - 15, info.height - 15);ctx.fillText('部門', 30, 250); // 設置水印位置ctx.fillText(markDept, 30, 300); // 設置水印位置ctx.fillText('時間', 30, 350); // 設置水印位置ctx.fillText(markTime, 30, 400); // 設置水印位置ctx.draw(true, () => {uni.canvasToTempFilePath({canvasId: 'watermarkCanvas',success: (res) => {console.log("res.tempFilePath", res.tempFilePath);resolve(res.tempFilePath);},fail: (err) => {reject(err);}});});},fail: (err) => {reject(err);}});});},

最終效果

預覽畫面

水印相機-預覽

繪制好的水印照片

水印相機-水印照片

最后

水印照片的比例以及水印的位置需要自己多調試幾次找到合適的比例和位置。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/45193.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/45193.shtml
英文地址,請注明出處:http://en.pswp.cn/web/45193.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

多頭注意力機制詳解:多維度的深度學習利器

引言 多頭注意力機制是對基礎注意力機制的一種擴展&#xff0c;通過引入多個注意力頭&#xff0c;每個頭獨立計算注意力&#xff0c;然后將結果拼接在一起進行線性變換。本文將詳細介紹多頭注意力機制的原理、應用以及具體實現。 原理 多頭注意力機制的核心思想是通過多個注…

springAMQP自定義fanout交換機進行消息的廣播

rabbitmq一共有三種交換機&#xff1a; fanout--廣播direct--定向topic--話題 rabbitmq-web端 首先我們需要建立一個名叫cybg.fanout交換機與兩個自定義的隊列用于測試廣播效果 我這里就起名字叫做fanout_queue1&fanout_queue2 項目中&#xff1a; 首先對我們的Liste…

當代政治制度(練習題)

當代政治制度&#xff08;練習題&#xff09; *** Rz整理 僅供參考 *** 目前地方人大設立的專門委員會不包括&#xff08;B.法律審查委員會F.外交事務專門委員會 &#xff09;答案不確定 等待指點 A.法制委員會 B.法律審查委員會 C.財政經濟委員會 D.社會建設委員會 E.農業與…

Go語言基礎數據類型、變量及自增語法

本文內容為Go語言的基礎數據類型、變量定義和賦值及自增語法介紹。 目錄 基礎數據類型 變量 先定義后賦值 定義時直接賦值 自動推導定義賦值 平行賦值 自增語法 總結 基礎數據類型 int,int8 intl6, int32, int64 uint8... uint64 float32,float64 true/false 變量 …

unity 環形循環切換UI

環形ui管理器 using System.Collections.Generic; using UnityEngine; using UnityEngine.UI; using DG.Tweening; using System.Collections; using Unity.VisualScripting;public class LevelSelector : MonoBehaviour {public GameObject levelButtonPrefab; // 關卡按鈕的…

Elasticsearch:介紹 retrievers - 搜索一切事物

作者&#xff1a;來自 Elastic Jeff Vestal, Jack Conradson 在 8.14 中&#xff0c;Elastic 在 Elasticsearch 中引入了一項名為 “retrievers - 檢索器” 的新搜索功能。繼續閱讀以了解它們的簡單性和效率&#xff0c;以及它們如何增強你的搜索操作。 檢索器是 Elasticsearc…

Linux:解決vim打開文件默認為replace模式

現象 Ubuntu打開 vim 默認為 replace 模式 原因 終端的編碼設置與目標機器的編碼設置不同。 解決方案 修改 vim 配置文件( /etc/vim/vimrc或者~/.vimrc)&#xff0c;添加&#xff1a; set termencodingutf-8 set fileformatsunix set encodingprcP.S. vimrc 中注釋使用英…

知識圖譜與LLMs:實時圖分析(通過其關系的上下文理解數據點)

大型語言模型 (LLM) 極大地改變了普通人獲取數據的方式。不到一年前&#xff0c;訪問公司數據需要具備技術技能&#xff0c;包括熟練掌握各種儀表板工具&#xff0c;甚至深入研究數據庫查詢語言的復雜性。然而&#xff0c;隨著 ChatGPT 等 LLM 的興起&#xff0c;隨著所謂的檢索…

Ubuntu系統安裝mysql之后進行遠程連接

1.首先要配置數據庫允許進行遠程連接 1.1 打開MySQL配置文件 /etc/mysql/mysql.conf.d/mysqld.cnf sudo vim /etc/mysql/mysql.conf.d/mysqld.cnf1.2 修改 bind-address 行 #按i進入插入模式 bind-address 0.0.0.0 #按 Esc 鍵退出插入模式。 #輸入:wq 然后按 Enter 保存并退…

React學習筆記02-----

一、React簡介 想實現頁面的局部刷新&#xff0c;而不是整個網頁的刷新。AJAXDOM可以實現局部刷新 1.特點 &#xff08;1&#xff09;虛擬DOM 開發者通過React來操作原生DOM&#xff0c;從而構建頁面。 React通過虛擬DOM來實現&#xff0c;可以解決DOM的兼容性問題&#x…

Window10下安裝WSL-Ubuntu20.04

1.開啟并更新WSL 1.1開啟WSL 首先先來看一下電腦是否能夠開啟WSL:待補充... 然后再來看一下如何開啟WSL:win->設置->應用->應用和功能->程序和功能&#xff0c;如下所示&#xff1a; 最后選擇啟用或關閉Windows功能&#xff0c;開啟兩個選項&#xff1a;1.Hyper-V…

工具推薦|語音輕松記筆記,AI幫你識別和潤色

# 你日常有沒有遇到這樣的場景&#xff1f; 偶爾有一些奇思妙想想要記錄下來&#xff0c;但沒有一個輕量的工具&#xff0c;往往會想著想著就把這個想法拋之腦后。特別是搞短視頻的&#xff0c;你也許希望把當時的想法錄下來&#xff0c;稍微剪輯下就能出一條不錯的口播視頻。…

springboot的JWT令牌

生成JWT令牌 依賴 <!--jwt令牌--> <dependency> <groupId>io.jsonwebtoken</groupId> <artifactId>jjwt</artifactId> <version>0.9.1</version> </dependency> <dependency> <groupId>javax.xml.bind<…

【LeetCode】最小棧

目錄 一、題目二、解法完整代碼 一、題目 設計一個支持 push &#xff0c;pop &#xff0c;top 操作&#xff0c;并能在常數時間內檢索到最小元素的棧。 實現 MinStack 類: MinStack() 初始化堆棧對象。 void push(int val) 將元素val推入堆棧。 void pop() 刪除堆棧頂部的元…

ACE之ACE_Handle_Set

簡介 ACE_Handle_Set是對select io復用中fd_set的封裝 結構 #mermaid-svg-dwnlrGqy52ds6ctC {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-dwnlrGqy52ds6ctC .error-icon{fill:#552222;}#mermaid-svg-dwnlrGqy52…

微信小程序開發基礎知識6----使用npm包

一、小程序對npm的支持與限制 目前&#xff0c;小程序中已經支持使用 npm 安裝第三方包&#xff0c;從而來提高小程序的開發效率。但是&#xff0c;在小程序中使用npm 包有如下3個限制: ① 不支持依賴于 Node.js 內置庫的包 ② 不支持依賴于瀏覽器內置對象的包 ③ 不支持依賴于…

Java算法-力扣leetcode-209. 長度最小的子數組

209. 長度最小的子數組 給定一個含有 n ****個正整數的數組和一個正整數 target 。 找出該數組中滿足其總和大于等于 ****target ****的長度最小的 **** 子數組 [numsl, numsl1, ..., numsr-1, numsr] &#xff0c;并返回其長度 。 如果不存在符合條件的子數組&#xff0c;…

pico+unity預設配置

picosdk中有很多預設的配置、使用預設配置的方法有 1、創建 XR Origin、展開 XR Origin > Camera Offset&#xff0c;選中 LeftHand Controller。點擊 XR Controller (Action-Based) 面板右上角的 預設 按鈕 2、打開Assets\Samples\XR Interaction Toolkit\2.5.2\Starter A…

Linux--YUM倉庫部署及NFS共享存儲

目錄 一、YUM倉庫服務 1.1 YUM介紹 1.2 yum 常用的命令 1.3 YUM 源的提供方式 1.3.1 配置本地 yum 源倉庫 1.3.2 配置 ftp 源 1.3.3 配置http服務源 二、NFS 共享存儲 2.1 NFS基本概述 2.2 為什么使用 NFS 共享存儲 2.3 NFS 應用場景 2.4 NFS 實現原理 2.5 NFS文件…

配置提交節點

方法一&#xff1a;配置lsf.cluster.<clustername> 到$LSF_TOP/conf目錄&#xff0c;編輯lsf.cluster.<clustername>文件。將下面配置中的server列設置成0&#xff0c;此節點就會作為Login節點。此方法通過bhosts不可以查看到這個節點。 # cd $LSF_ENVDIR# vim l…