news 2026/3/6 2:12:30

用之前的轮变换高效去除画面模糊,处理画面失真的情况,但是因为是AI写的,所以外面仍有一些用不上的多余部分

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
用之前的轮变换高效去除画面模糊,处理画面失真的情况,但是因为是AI写的,所以外面仍有一些用不上的多余部分

<!DOCTYPE html>

<html>

<head>

<meta charset="utf-8">

<title>轮廓加权融合+卷积去模糊工具</title>

<style>

body {text-align:center;font-family:Arial;margin:20px;}

canvas {border:2px solid #333;margin:10px auto;display:block;background:#fff;}

button {padding:8px 20px;font-size:16px;cursor:pointer;background:#4CAF50;color:white;border:none;border-radius:4px;margin:10px;}

button:hover {background:#45a049;}

.container {width:800px;margin:0 auto;}

.slider {margin:15px auto;width:400px;}

</style>

</head>

<body>

<div class="container">

<h3>初始模糊图(模糊程度可调)</h3>

<input type="range" min="1" max="10" value="3" class="slider" id="blurSlider">

<span id="blurValue">模糊程度:3</span>

<canvas id="blurCanvas" width="400" height="300"></canvas>

<h3>最终去模糊结果图</h3>

<canvas id="resultCanvas" width="400" height="300"></canvas>

<button onclick="reset()">重置生成图形</button>

<button onclick="startProcess()">开始轮廓融合+卷积去模糊</button>

</div>

<script>

let blurCtx = blurCanvas.getContext('2d'), resCtx = resultCanvas.getContext('2d');

let blurSlider = document.getElementById('blurSlider');

let blurValue = document.getElementById('blurValue');

let originalImgData, blurLevel = 3;

let hiddenFrames = [];

blurSlider.oninput = function() {

blurLevel = parseInt(this.value);

blurValue.textContent = `模糊程度:${blurLevel}`;

drawRandomGraph();

generateBlurFrames();

};

// 原有核心:生成图形

function drawRandomGraph() {

blurCtx.clearRect(0,0,400,300);

for(let k=0;k<4;k++){

let n=3+Math.floor(Math.random()*5),x0=200+(Math.random()-0.5)*80,y0=150+(Math.random()-0.5)*80;

blurCtx.beginPath();

for(let i=0;i<n;i++) blurCtx.lineTo(x0+Math.cos(i/n*2*Math.PI)*(30+k*15),y0+Math.sin(i/n*2*Math.PI)*(30+k*15));

blurCtx.closePath();

blurCtx.fillStyle=`rgb(${Math.random()*255},${Math.random()*255},${Math.random()*255})`;

blurCtx.fill();

}

for(let i=0;i<3;i++){

let r=15+Math.random()*10,x=150+Math.random()*100,y=100+Math.random()*100;

blurCtx.beginPath();blurCtx.arc(x,y,r,0,2*Math.PI);

blurCtx.fillStyle=`rgb(${Math.random()*255},${Math.random()*255},${Math.random()*255})`;

blurCtx.fill();

}

originalImgData = blurCtx.getImageData(0,0,400,300);

}

// 新增:生成隐式模糊帧

function generateBlurFrames() {

hiddenFrames = [];

let w = 400, h = 300;

for(let f=0;f<5;f++){

let tempCtx = document.createElement('canvas').getContext('2d');

tempCtx.canvas.width = w;

tempCtx.canvas.height = h;

tempCtx.putImageData(originalImgData, 0, 0);

tempCtx.filter = `blur(${blurLevel}px)`;

tempCtx.drawImage(tempCtx.canvas, f*2, f*1, w, h, 0, 0, w, h);

hiddenFrames.push(tempCtx.getImageData(0,0,w,h));

}

blurCtx.filter = `blur(${blurLevel}px)`;

blurCtx.drawImage(blurCtx.canvas, 0, 0, w, h, 0, 0, w, h);

blurCtx.filter = 'none';

}

// 原有核心:提取轮廓 → 新增边缘淡化

function extractOutline(imgData) {

let w = imgData.width, h = imgData.height;

let outlineData = new ImageData(w, h);

let data = imgData.data, outData = outlineData.data;

function wheelMatrix(x,y,cx,cy,angle) {

let dx=x-cx, dy=y-cy;

let rotX=dx*Math.cos(angle)-dy*Math.sin(angle);

let dist=Math.sqrt(rotX**2+dy**2);

return dist%10 < 4 ? 1 : 0;

}

for(let round=0;round<5;round++){

let angle=round*Math.PI/4, cx=200+round*12, cy=150+round*8;

for(let y=0;y<h;y++)for(let x=0;x<w;x++){

let i=(y*w+x)*4;

if(!wheelMatrix(x,y,cx,cy,angle)) continue;

let isEdge=false;

for(let dy=-2;dy<=2;dy++)for(let dx=-2;dx<=2;dx++){

if(dx===0&&dy===0) continue;

let nx=x+dx, ny=y+dy;

if(nx>=0&&nx<w&&ny>=0&&ny<h){

let ni=(ny*w+nx)*4;

isEdge|=Math.abs(data[i]-data[ni])>15||Math.abs(data[i+1]-data[ni+1])>15||Math.abs(data[i+2]-data[ni+2])>15;

}

}

// 边缘颜色淡化:降低轮廓亮度,避免边缘过亮

outData[i] = isEdge ? 180 : 0;

outData[i+1] = isEdge ? 180 : 0;

outData[i+2] = isEdge ? 180 : 0;

outData[i+3] = isEdge ? 120 : 0; // 降低透明度进一步淡化

}

}

return outlineData;

}

// 加权融合

function weightFusion(imgData, outlineData, alpha = 0.7) {

let w = imgData.width, h = imgData.height;

let fusedData = new ImageData(w, h);

let d1 = imgData.data, d2 = outlineData.data, d3 = fusedData.data;

for(let i=0;i<d1.length;i+=4){

d3[i] = Math.round(d1[i] * alpha + d2[i] * (1 - alpha));

d3[i+1] = Math.round(d1[i+1] * alpha + d2[i+1] * (1 - alpha));

d3[i+2] = Math.round(d1[i+2] * alpha + d2[i+2] * (1 - alpha));

d3[i+3] = 255;

}

return fusedData;

}

// 局部卷积

function localConvolution(fusedData, frames) {

let w = fusedData.width, h = fusedData.height;

let convData = new ImageData(w, h);

let d = fusedData.data, cd = convData.data;

let kernel = [1/9,1/9,1/9,1/9,1/9,1/9,1/9,1/9,1/9];

let allFrames = [fusedData, ...frames];

for(let y=1;y<h-1;y++){

for(let x=1;x<w-1;x++){

let i = (y*w + x)*4;

let r = 0, g = 0, b = 0;

for(let dy=-1;dy<=1;dy++){

for(let dx=-1;dx<=1;dx++){

let idx = ((y+dy)*w + (x+dx))*4;

let k = (dy+1)*3 + (dx+1);

for(let f=0;f<allFrames.length;f++){

let fd = allFrames[f].data;

r += fd[idx] * kernel[k] / allFrames.length;

g += fd[idx+1] * kernel[k] / allFrames.length;

b += fd[idx+2] * kernel[k] / allFrames.length;

}

}

}

cd[i] = Math.round(r);

cd[i+1] = Math.round(g);

cd[i+2] = Math.round(b);

cd[i+3] = 255;

}

}

return convData;

}

// 新增:多轮原图叠加函数

function overlayOriginal(targetData, originalData, times = 3, alpha = 0.2) {

let d1 = targetData.data, d2 = originalData.data;

for(let t=0; t<times; t++){

for(let i=0; i<d1.length; i+=4){

d1[i] = Math.round(d1[i] * (1 - alpha) + d2[i] * alpha);

d1[i+1] = Math.round(d1[i+1] * (1 - alpha) + d2[i+1] * alpha);

d1[i+2] = Math.round(d1[i+2] * (1 - alpha) + d2[i+2] * alpha);

}

}

return targetData;

}

// 核心流程:新增 多轮原图叠加

function startProcess() {

let currentData = hiddenFrames[0];

// 多轮轮廓融合

for(let i=0;i<5;i++){

let outline = extractOutline(currentData);

currentData = weightFusion(currentData, outline);

}

// 卷积去模糊

let convData = localConvolution(currentData, hiddenFrames.slice(1));

// 关键修改:多轮与原图叠加,还原细节+淡化边缘

let finalData = overlayOriginal(convData, originalImgData, 4, 0.15);

resCtx.putImageData(finalData, 0, 0);

}

function reset() {

drawRandomGraph();

generateBlurFrames();

resCtx.clearRect(0,0,400,300);

}

window.onload = function() {

drawRandomGraph();

generateBlurFrames();

};

</script>

</body>

</html>

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/3 17:06:41

12、Ourmon:网络监控与异常检测工具全解析

Ourmon:网络监控与异常检测工具全解析 1. 引言 在网络环境中,僵尸网络的检测颇具挑战性。不过,有一款名为Ourmon的工具经过改进后,可通过网络流量分析来检测僵尸网络的存在。它能基于主机间的攻击行为(如拒绝服务攻击或网络扫描)检测网络异常,并将这些信息与IRC通道关…

作者头像 李华
网站建设 2026/3/5 23:26:32

22、恶意软件分析与检测全解析

恶意软件分析与检测全解析 1. 基于XML分析报告的转换 基于原始XML分析报告,我们能够创建自定义的HTML或纯文本转换。为此,需要创建一个XSL模板,其中包含解析XML文档的指令。有多种工具可用于执行此转换,一种简单的方法是在XML文件中包含如下行(需使用正确的XSL文件名作为…

作者头像 李华
网站建设 2026/3/4 15:09:42

产品解读 | Ftrans SFT:信创浪潮下的FTP替代革命者

传统FTP协议因其固有的安全漏洞和功能局限&#xff0c;逐渐成为企业数据传输的“老邮差”。随着国家信创政策的全面推进&#xff0c;一款名为《Ftrans SFT文件安全传输系统》&#xff08;简称SFT&#xff09;的国产化解决方案&#xff0c;正以“安全、高效、自主可控”的姿态&a…

作者头像 李华
网站建设 2026/3/5 0:20:27

继何恺明DyT后,LayerNorm再遭暴击!简单erf函数竟成Transformer新宠

今年早些时候&#xff0c;由何恺明、Yann LeCun 等大佬联手推出的 Dynamic Tanh (DyT) 曾引发热议&#xff0c;它向我们展示了 Transformer 中不可或缺的 LayerNorm 其实可以用一个简单的 Tanh 函数替代。而现在&#xff0c;普林斯顿大学刘壮团队&#xff08;DyT 原班人马&…

作者头像 李华
网站建设 2026/3/4 0:26:33

C语言链表2

#include<stdio.h> #include<stdlib.h> struct node{int date;struct node* next; }; struct node* creat(int info){ //创建一个节点struct node* newnode(struct node*)malloc(sizeof(struct node));if(newnodeNULL){printf("error\n");exit(1)…

作者头像 李华
网站建设 2026/3/5 10:34:12

蜣螂优化(DBO)算法在工程实际中求目标函数最小值的例子:压力容器设计成本最小化的4变量4约束...

蜣螂优化(DBO)算法 工程实际&#xff0c;求目标函数最小值&#xff0c;图中所求例子为一个压力容器设计成本最小&#xff0c;为4变量&#xff0c;4个不等式约束。 采用罚函数将4约束问题转变为无约束问题。 代码注释完整&#xff0c;非常容易带入自己想要求的问题。深夜撸代码发…

作者头像 李华