国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

目錄
如何解決opencv.js投影變換結(jié)果為空白的透明圖片問題
首頁(yè) web前端 js教程 如何解決OpenCV.js投影變換后結(jié)果為空白透明圖片的問題?

如何解決OpenCV.js投影變換后結(jié)果為空白透明圖片的問題?

Apr 04, 2025 pm 03:45 PM
ai 解決方法 點(diǎn)擊事件

如何解決opencv.js投影變換結(jié)果為空白的透明圖片問題

在使用opencv.js進(jìn)行圖像處理時(shí),有時(shí)候會(huì)遇到投影變換后圖像結(jié)果為空白的透明圖片的問題。以下是我遇到的問題以及解決方法。

我在處理圖像時(shí),代碼能夠成功識(shí)別出文檔的四個(gè)坐標(biāo),但到了投影變換這一步,得到的結(jié)果總是空白的透明圖片,并且沒有報(bào)錯(cuò)。以下是我使用的投影變換部分代碼:

// 投影變換
let srcquad = cv.matfromarray(4, 1, cv.cv_32fc2, points.flat());
let dstquad = cv.matfromarray(4, 1, cv.cv_32fc2, [0, 0, img.cols, 0, img.cols, img.rows, 0, img.rows]);
let transmtx = cv.getperspectivetransform(srcquad, dstquad);
let target = new cv.mat();
cv.warpperspective(img, target, transmtx, new cv.size(img.cols, img.rows));
// 顯示結(jié)果
cv.imshow(canvas, target);

為了解決這個(gè)問題,我進(jìn)行了以下改進(jìn):

  1. 設(shè)置 canvas 大小:在圖像加載完成后,即在 imgelement.onload 函數(shù)中,設(shè)置 canvas 的寬度和高度與圖像的尺寸一致。
  2. 添加錯(cuò)誤處理:在圖像加載失敗時(shí),即在 imgelement.onerror 函數(shù)中,添加錯(cuò)誤處理以捕獲圖像加載錯(cuò)誤。

以下是改進(jìn)后的完整代碼:


    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>OpenCV.js Example</title>


    <script async src="https://docs.opencv.org/4.5.5/opencv.js" onload="onOpenCvReady();"></script>
    <canvas id="canvasOutput"></canvas>
    <script>
        function onOpenCvReady() {
            console.log("OpenCV.js加載完成.");
            processImage();
        }

        function sleep(ms) {
            return new Promise(resolve => setTimeout(resolve, ms));
        }

        async function processImage() {
            await sleep(3000); // 等待 3 秒
            let imageUrl = "../archives/111.jpg";
            let imgElement = new Image();
            imgElement.src = imageUrl;
            var img;

            // 加載圖像
            imgElement.onload = function() {
                try {
                    img = cv.imread(imgElement);
                    if (img.empty()) {
                        console.error("Image could not be read.");
                        return;
                    }

                    // 獲取 canvas 元素并設(shè)置大小
                    let canvas = document.getElementById('canvasOutput');
                    canvas.width = img.cols;
                    canvas.height = img.rows;

                    // 重置圖像大小
                    let dsize = new cv.Size(img.cols, img.rows);
                    let dst = new cv.Mat();
                    cv.resize(img, dst, dsize, 0, 0, cv.INTER_AREA);

                    // 轉(zhuǎn)為灰度圖像
                    console.log("轉(zhuǎn)換之前:", img);
                    let gray = new cv.Mat(); // 創(chuàng)建一個(gè)新的 Mat 對(duì)象來(lái)存灰度圖像
                    cv.cvtColor(dst, gray, cv.COLOR_BGR2GRAY); // 使用適當(dāng)?shù)霓D(zhuǎn)換
                    console.log("轉(zhuǎn)換之后:", gray);

                    // 高斯濾波
                    cv.GaussianBlur(gray, gray, new cv.Size(11, 11), 0, 0);
                    cv.imshow(canvas, gray);
                    cv.Canny(gray, gray, 20, 50, 3);

                    let contours = new cv.MatVector();
                    let hierarchy = new cv.Mat();
                    cv.findContours(gray, contours, hierarchy, cv.RETR_CCOMP, cv.CHAIN_APPROX_NONE);

                    let index = 0, maxArea = 0;
                    const area = img.cols * img.rows;
                    for (let i = 0; i < contours.size();   i) {
                        let tempArea = Math.abs(cv.contourArea(contours.get(i)));
                        if (tempArea > maxArea && tempArea > 0.3 * area) {
                            index = i;
                            maxArea = tempArea;
                        }
                    }

                    if (maxArea === 0) return;
                    const foundContour = contours.get(index);
                    const arcL = cv.arcLength(foundContour, true);
                    let approx = new cv.Mat();

                    // 逼近多邊形
                    cv.approxPolyDP(foundContour, approx, 0.01 * arcL, true);

                    if (approx.total() === 4) {
                        let points = [];
                        const data32S = approx.data32S;
                        for (let i = 0, len = data32S.length / 2; i < len; i  ) {
                            points[i] = {x: data32S[i * 2], y: data32S[i * 2   1]};
                        }
                        console.log("檢測(cè)到四邊形點(diǎn):", points);

                        // 投影變換
                        let srcQuad = cv.matFromArray(4, 1, cv.CV_32FC2, points.flat());
                        let dstQuad = cv.matFromArray(4, 1, cv.CV_32FC2, [0, 0, img.cols, 0, img.cols, img.rows, 0, img.rows]);
                        let transmtx = cv.getPerspectiveTransform(srcQuad, dstQuad);
                        let target = new cv.Mat();
                        cv.warpPerspective(img, target, transmtx, new cv.Size(img.cols, img.rows));

                        // 顯示結(jié)果
                        cv.imshow(canvas, target);

                        // 創(chuàng)建一個(gè)臨時(shí)的 canvas 元素
                        let tempCanvas = document.createElement('canvas');
                        tempCanvas.width = target.cols;
                        tempCanvas.height = target.rows;
                        let tempCtx = tempCanvas.getContext('2d');

                        // 將 cv.Mat 轉(zhuǎn)換為 ImageData
                        let imageData = new ImageData(new Uint8ClampedArray(target.data), target.cols, target.rows);

                        // 將 ImageData 繪制到臨時(shí)的 canvas 上
                        tempCtx.putImageData(imageData, 0, 0);

                        // 將 canvas 生成 Blob 對(duì)象
                        tempCanvas.toBlob((blob) => {
                            // 創(chuàng)建一個(gè) URL 對(duì)象
                            let url = URL.createObjectURL(blob);
                            // 創(chuàng)建一個(gè) a 元素并設(shè)置其屬性
                            let a = document.createElement('a');
                            a.href = url;
                            a.download = 'processed_image.png'; // 設(shè)置下載文件的名稱
                            // 將 a 元素添加到 body 中
                            document.body.appendChild(a);
                            // 觸發(fā)點(diǎn)擊事件以開始下載
                            a.click();
                            // 下載完成后移除 a 元素
                            document.body.removeChild(a);
                            // 釋放 URL 對(duì)象
                            URL.revokeObjectURL(url);
                        }, 'image/png');

                        // 釋放內(nèi)存
                        target.delete(); // 在這里釋放 target,否則會(huì)造成內(nèi)存泄露
                    }

                    // 釋放內(nèi)存
                    img.delete();
                    dst.delete();
                    gray.delete(); // 釋放灰度圖像 Mat
                    contours.delete();
                    hierarchy.delete();
                    approx.delete();
                    foundContour.delete();
                } catch (err) {
                    console.error("圖像處理出現(xiàn)錯(cuò)誤:", err);
                }
            }

            imgElement.onerror = function() {
                console.error("Image could not be loaded.");
            };
        }
    </script>

通過上述改進(jìn),我成功解決了投影變換后結(jié)果為空白透明圖片的問題。希望這些改進(jìn)對(duì)大家也有幫助。

以上是如何解決OpenCV.js投影變換后結(jié)果為空白透明圖片的問題?的詳細(xì)內(nèi)容。更多信息請(qǐng)關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本站聲明
本文內(nèi)容由網(wǎng)友自發(fā)貢獻(xiàn),版權(quán)歸原作者所有,本站不承擔(dān)相應(yīng)法律責(zé)任。如您發(fā)現(xiàn)有涉嫌抄襲侵權(quán)的內(nèi)容,請(qǐng)聯(lián)系admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費(fèi)脫衣服圖片

Undresser.AI Undress

Undresser.AI Undress

人工智能驅(qū)動(dòng)的應(yīng)用程序,用于創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用于從照片中去除衣服的在線人工智能工具。

Clothoff.io

Clothoff.io

AI脫衣機(jī)

Video Face Swap

Video Face Swap

使用我們完全免費(fèi)的人工智能換臉工具輕松在任何視頻中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費(fèi)的代碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

功能強(qiáng)大的PHP集成開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺化網(wǎng)頁(yè)開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級(jí)代碼編輯軟件(SublimeText3)

幣圈熱度回歸,為什么聰明人都開始悄悄加倉(cāng)?從鏈上數(shù)據(jù)看趨勢(shì),把握下一輪財(cái)富密碼! 幣圈熱度回歸,為什么聰明人都開始悄悄加倉(cāng)?從鏈上數(shù)據(jù)看趨勢(shì),把握下一輪財(cái)富密碼! Jul 09, 2025 pm 08:30 PM

隨著市場(chǎng)行情的回暖,越來(lái)越多的聰明投資者開始在幣圈悄悄加倉(cāng),不少人疑惑,是什么讓他們?cè)诖蠖鄶?shù)人觀望時(shí)果斷出手?本文將通過鏈上數(shù)據(jù)分析當(dāng)前趨勢(shì),幫助讀者理解聰明資金的邏輯,從而更好地把握下一輪潛在的財(cái)富增長(zhǎng)機(jī)會(huì)。

加密貨幣主流公鏈有哪些?2025加密貨幣主流公鏈排行榜前十名匯總 加密貨幣主流公鏈有哪些?2025加密貨幣主流公鏈排行榜前十名匯總 Jul 10, 2025 pm 08:21 PM

公鏈領(lǐng)域的格局呈現(xiàn)出“一超多強(qiáng)、百花齊放”的態(tài)勢(shì)。以太坊憑借其生態(tài)護(hù)城河依然領(lǐng)先,而Solana、Avalanche等則在性能上發(fā)起挑戰(zhàn)。與此同時(shí),專注于互操作性的Polkadot、Cosmos和作為關(guān)鍵基礎(chǔ)設(shè)施的Chainlink,共同構(gòu)成了多鏈并存的未來(lái)圖景。對(duì)于用戶和開發(fā)者而言,選擇哪個(gè)平臺(tái)不再是單選題,而是需要根據(jù)具體需求在性能、成本、安全性和生態(tài)成熟度之間做出權(quán)衡。

Cardano的智能合約演變:Alonzo升級(jí)對(duì)2025年的影響 Cardano的智能合約演變:Alonzo升級(jí)對(duì)2025年的影響 Jul 10, 2025 pm 07:36 PM

Cardano的Alonzo硬分叉升級(jí)通過引入Plutus智能合約平臺(tái),成功將Cardano從價(jià)值轉(zhuǎn)移網(wǎng)絡(luò)轉(zhuǎn)變?yōu)楣δ芡陚涞闹悄芎霞s平臺(tái)。1. Plutus基于Haskell語(yǔ)言,具備強(qiáng)大的功能性、增強(qiáng)的安全性和可預(yù)測(cè)的費(fèi)用模型;2. 升級(jí)后dApps部署加速,開發(fā)者社區(qū)擴(kuò)大,DeFi和NFT生態(tài)迅速發(fā)展;3. 展望2025年,Cardano生態(tài)系統(tǒng)將更加成熟多元,結(jié)合Basho時(shí)代的可擴(kuò)展性提升、跨鏈互操作性增強(qiáng)、Voltaire時(shí)代的去中心化治理演進(jìn)以及企業(yè)級(jí)應(yīng)用推動(dòng)主流采用,Cardano有

比特幣破新高,狗狗幣強(qiáng)勢(shì)反彈,以太坊是否還能跟上節(jié)奏 比特幣破新高,狗狗幣強(qiáng)勢(shì)反彈,以太坊是否還能跟上節(jié)奏 Jul 09, 2025 pm 08:24 PM

近期,比特幣刷新高點(diǎn),狗狗幣迎來(lái)強(qiáng)勢(shì)反彈,行情火熱。接下來(lái)從市場(chǎng)驅(qū)動(dòng)因素和技術(shù)面分析,以便判斷以太坊是否還有跟漲機(jī)會(huì)。

穩(wěn)定幣是誰(shuí)發(fā)行的 穩(wěn)定幣有哪些 穩(wěn)定幣是誰(shuí)發(fā)行的 穩(wěn)定幣有哪些 Jul 09, 2025 pm 06:24 PM

穩(wěn)定幣是通過錨定美元等法定貨幣來(lái)維持價(jià)格穩(wěn)定的加密資產(chǎn),主要分為法幣抵押、加密資產(chǎn)抵押和算法穩(wěn)定幣三類。 1. USDT由Tether發(fā)行,是市值最大、流動(dòng)性最高的穩(wěn)定幣。 2. USDC由Circle與Coinbase推出的Centre聯(lián)盟發(fā)行,以透明合規(guī)著稱。 3. DAI由MakerDAO通過加密資產(chǎn)超額抵押生成,是DeFi領(lǐng)域核心貨幣。 4. BUSD由幣安與Paxos合作推出,受美國(guó)監(jiān)管但已停止發(fā)行。 5. TUSD通過第三方托管賬戶實(shí)現(xiàn)高透明度儲(chǔ)備驗(yàn)證。用戶可通過中心化交易所如幣安、歐易、火幣

全球主流加密貨幣有哪些?2025年加密貨幣深度分析(含網(wǎng)址) 全球主流加密貨幣有哪些?2025年加密貨幣深度分析(含網(wǎng)址) Jul 10, 2025 pm 08:36 PM

在數(shù)字經(jīng)濟(jì)浪潮席卷全球的當(dāng)下,加密貨幣以其獨(dú)特的去中心化、透明化特性,成為各界關(guān)注的焦點(diǎn)。從最初的極客小眾實(shí)驗(yàn),到如今市值數(shù)萬(wàn)億的金融版圖,加密貨幣的演變軌跡令人驚嘆。它不僅帶來(lái)了底層技術(shù)的革新,也催生了無(wú)數(shù)創(chuàng)新應(yīng)用,正深刻影響著金融、科技乃至社會(huì)治理的方方面面。

狗狗幣DOGE屬于哪條鏈?狗狗幣是否屬于幣安鏈? 狗狗幣DOGE屬于哪條鏈?狗狗幣是否屬于幣安鏈? Jul 10, 2025 pm 08:39 PM

近期,數(shù)字資產(chǎn)領(lǐng)域的討論熱度不減,狗狗幣DOGE作為其中一個(gè)備受關(guān)注的焦點(diǎn),其技術(shù)基礎(chǔ)和平臺(tái)歸屬成為不少人探索的疑問。它究竟“安家”何處?又與當(dāng)前頭部交易平臺(tái)——幣安有怎樣的關(guān)聯(lián)?要解答這些問題,我們需要從數(shù)字資產(chǎn)的底層技術(shù)邏輯和平臺(tái)生態(tài)兩個(gè)維度進(jìn)行深入剖析,而非僅僅停留在表象。

領(lǐng)漲2025加密市場(chǎng)的前二十大代幣排行榜(最新更新) 領(lǐng)漲2025加密市場(chǎng)的前二十大代幣排行榜(最新更新) Jul 10, 2025 pm 08:48 PM

2025年最具潛力的二十大加密資產(chǎn)包括BTC、ETH、SOL等,主要覆蓋公鏈、Layer 2、AI、DeFi和游戲等多個(gè)賽道。1.BTC憑借數(shù)字黃金屬性和ETF普及持續(xù)引領(lǐng)市場(chǎng);2.ETH因智能合約平臺(tái)地位和升級(jí)鞏固生態(tài);3.SOL以高性能公鏈和開發(fā)者社區(qū)脫穎而出;4.LINK作為預(yù)言機(jī)龍頭連接現(xiàn)實(shí)數(shù)據(jù);5.RNDR構(gòu)建去中心化GPU網(wǎng)絡(luò)服務(wù)AI需求;6.IMX專注Web3游戲提供零Gas費(fèi)環(huán)境;7.ARB以成熟Layer 2技術(shù)和龐大DeFi生態(tài)領(lǐng)先;8.MATIC通過多鏈演進(jìn)成為以太坊價(jià)值層

See all articles