当前位置: 首页 > news >正文

html做的网站图片横着摆放百度网页大全

html做的网站图片横着摆放,百度网页大全,获取网站访客qq信息,江西建设门户网站一、效果图 二、图像二值化的作用 二值化是图像处理中常用的一种方法,其作用是将灰度图像转换为二值图像,即将图像中的像素点根据其灰度值分成两类:黑色和白色。这种处理方法可以帮助我们更清晰地识别图像中的目标,简化图像的复杂…

一、效果图

在这里插入图片描述

二、图像二值化的作用

二值化是图像处理中常用的一种方法,其作用是将灰度图像转换为二值图像,即将图像中的像素点根据其灰度值分成两类:黑色和白色。这种处理方法可以帮助我们更清晰地识别图像中的目标,简化图像的复杂度,提高图像的处理速度和准确性。

三、实现思路

1、获取框选的图片,进行截图

<div><canvasref="grayCanvas":width="canvasProp.width":height="canvasProp.height"></canvas><canvasref="binaryCanvas":width="canvasProp.width":height="canvasProp.height"></canvas></div><!-- 隐藏的 canvas --><canvasref="hiddenCanvas":width="canvasProp.width":height="canvasProp.height"style="display: none;"></canvas>// 根据框选的数据,对原图进行截图getCanvasImageData() {const viewportTransform = this.fabricCanvas.viewportTransform;const zoom = this.fabricCanvas.getZoom();let selectedCoords = null;this.fabricCanvas.getObjects().forEach(rect => {const coords = [];const points = rect.get("aCoords");Object.keys(points).forEach(key => {let point = points[key];const actualX = (point.x - viewportTransform[4]) / zoom;const actualY = (point.y - viewportTransform[5]) / zoom;coords.push([Math.round(actualX), Math.round(actualY)]);});// 假设只有一个矩形对象,我们只需获取一个对象的坐标selectedCoords = coords;});if (selectedCoords) {// 获取矩形区域的最小和最大坐标const minX = Math.min(...selectedCoords.map(coord => coord[0]));const minY = Math.min(...selectedCoords.map(coord => coord[1]));const maxX = Math.max(...selectedCoords.map(coord => coord[0]));const maxY = Math.max(...selectedCoords.map(coord => coord[1]));const width = maxX - minX;const height = maxY - minY;// 从隐藏的 canvas 中获取选中区域的图像数据const ctx = this.$refs.hiddenCanvas.getContext("2d");return ctx.getImageData(minX, minY, width, height);}return null;},

页面中要有3个canvas,grayCanvas 画灰度图片,binaryCanvas画二值化图片,hiddenCanvas 画原始的图片便于截图

2、对图片进行灰度处理
转化为灰度图片,放在灰度画布中

  convertToGrayScale(imageData) {const data = imageData.data;for (let i = 0; i < data.length; i += 4) {const avg = 0.3 * data[i] + 0.59 * data[i + 1] + 0.11 * data[i + 2];data[i] = avg;data[i + 1] = avg;data[i + 2] = avg;}return imageData;},applyGrayScale() {const imageData = this.getCanvasImageData();const grayImageData = this.convertToGrayScale(imageData);const grayCtx = this.$refs.grayCanvas.getContext("2d");grayCtx.putImageData(grayImageData, 0, 0);this.applyThreshold();},

3、拖动滑块,根据阈值对图片进行二值化处理

    applyThreshold() {const grayCtx = this.$refs.grayCanvas.getContext("2d");const grayImageData = grayCtx.getImageData(0,0,this.canvasProp.width,this.canvasProp.height);const data = grayImageData.data;for (let i = 0; i < data.length; i += 4) {const avg = data[i];const value = avg > this.threshold ? 255 : 0;data[i] = value;data[i + 1] = value;data[i + 2] = value;}const binaryCtx = this.$refs.binaryCanvas.getContext("2d");binaryCtx.putImageData(grayImageData, 0, 0);},

4、添加滑块移动的监听

   this.fabricCanvas.on("object:modified", this.applyGrayScale);this.fabricCanvas.on("object:added", this.applyGrayScale);this.fabricCanvas.on("object:removed", this.applyGrayScale);
http://www.yayakq.cn/news/143018/

相关文章:

  • 沈阳建设厅网站首页网站设计思路方案
  • 找做玻璃的网站松江品划做企业网站
  • 响应式网站好么wordpress 广告 能赚多少
  • wordpress压缩缩略图体积seo外贸网站制作
  • 专业集团门户网站建设企业直接玩的网页游戏
  • 网站名字 备案铁路学校都有哪些学校
  • 大兴网站建设首选公司学seo网络推广
  • 如何做产品网站建设微信游戏小程序代理
  • 模板式网站建设wordpress 分类目录函数
  • 新网站如何快速收录企业起名网免费取名大全
  • 培训课程网站建设网站添加二级域名
  • 网站运营的含义是什么优化推广网站排名
  • 网站开发实验报告总结网站发布小说封面怎么做
  • 营销手机网站学动漫设计有前途吗
  • 建立网站的公司怎么建立企业网站
  • 重庆企业网站开发服务网站与网页的关系
  • 网站建设的流程和内容广州白云区123号
  • 美食网站建设毕业设计最挣钱没人干的行业
  • 网站开发工程师asp考试试题网站 字号 英文
  • 基于jsp企业网站开发设计答辩ppt中信建设有限责任公司资质等级
  • 淘宝做图网站好wordpress导出数据字典
  • 学校网站建站成都装饰公司
  • 给wordpress博客加上一个娃娃seo基础知识培训
  • 南京领动做网站怎么样郑州本地做团购的网站
  • 我和你99谁做的网站支部建设杂志官方网站
  • 深圳网站建设制作开发公司做网站需要公司
  • 百度不收录网站内页网站美工建设意见
  • 济南专业做企业网站附近广告公司喷绘刻字
  • 阿里绿网网站违规网站存在风险什么意思
  • ftp如何转换wordpress合肥网站搜索优化