美文网首页
Java实现图像中值滤波

Java实现图像中值滤波

作者: 愤怒的桑树 | 来源:发表于2019-07-26 12:05 被阅读0次

pixel是通过标准jdk或android bitmap获取的图像32位像素数组
这个方法的滤波器尺寸是3*3,需要更大尺寸滤波器可以依此类推,ColorModel可根据各平台变化调整

private int[] medianFiltering(int[] pixel, int w, int h) {
        int[] newPixel = new int[w * h];
        int[] tempR = new int[9];
        int[] tempG = new int[9];
        int[] tempB = new int[9];
        ColorModel cm = ColorModel.getRGBdefault();
        // median values of the matrix
        int r;
        int g;
        int b;
        for (int y = 0; y < h; y++) {
            for (int x = 0; x < w; x++) {
                if (x == 0 || x == w - 1 || y == 0 || y == h - 1) {
                    newPixel[y * w + x] = pixel[y * w + x];
                    continue;
                }
                tempR[0] = cm.getRed(pixel[x - 1 + (y - 1) * w]);
                tempR[1] = cm.getRed(pixel[x + (y - 1) * w]);
                tempR[2] = cm.getRed(pixel[x + 1 + (y - 1) * w]);
                tempR[3] = cm.getRed(pixel[x - 1 + y * w]);
                tempR[4] = cm.getRed(pixel[x + y * w]);
                tempR[5] = cm.getRed(pixel[x + 1 + y * w]);
                tempR[6] = cm.getRed(pixel[x - 1 + (y + 1) * w]);
                tempR[7] = cm.getRed(pixel[x + (y + 1) * w]);
                tempR[8] = cm.getRed(pixel[x + 1 + (y + 1) * w]);
                r = getMedianValue(tempR);

                tempG[0] = cm.getGreen(pixel[x - 1 + (y - 1) * w]);
                tempG[1] = cm.getGreen(pixel[x + (y - 1) * w]);
                tempG[2] = cm.getGreen(pixel[x + 1 + (y - 1) * w]);
                tempG[3] = cm.getGreen(pixel[x - 1 + y * w]);
                tempG[4] = cm.getGreen(pixel[x + y * w]);
                tempG[5] = cm.getGreen(pixel[x + 1 + y * w]);
                tempG[6] = cm.getGreen(pixel[x - 1 + (y + 1) * w]);
                tempG[7] = cm.getGreen(pixel[x + (y + 1) * w]);
                tempG[8] = cm.getGreen(pixel[x + 1 + (y + 1) * w]);

                g = getMedianValue(tempG);
                tempB[0] = cm.getBlue(pixel[x - 1 + (y - 1) * w]);
                tempB[1] = cm.getBlue(pixel[x + (y - 1) * w]);
                tempB[2] = cm.getBlue(pixel[x + 1 + (y - 1) * w]);
                tempB[3] = cm.getBlue(pixel[x - 1 + y * w]);
                tempB[4] = cm.getBlue(pixel[x + y * w]);
                tempB[5] = cm.getBlue(pixel[x + 1 + y * w]);
                tempB[6] = cm.getBlue(pixel[x - 1 + (y + 1) * w]);
                tempB[7] = cm.getBlue(pixel[x + (y + 1) * w]);
                tempB[8] = cm.getBlue(pixel[x + 1 + (y + 1) * w]);

                // median value
                b = getMedianValue(tempB);
                newPixel[y * w + x] = 255 << 24 | r << 16 | g << 8 | b;
            }
        }
        return newPixel;
    }

相关文章

  • Java实现图像中值滤波

    pixel是通过标准jdk或android bitmap获取的图像32位像素数组这个方法的滤波器尺寸是3*3,需要...

  • 计算摄影学Lab2:图像滤波和傅里叶变换

    任务清单 实现盒装均值滤波 实现高斯滤波 实现中值滤波 实现简单的双边滤波 利用傅里叶变换完成图像的频域变换 空域...

  • 7.6 2D卷积

    OpencV提供了多种滤波方式,来实现平滑图像的效果,例如均值滤波、方框滤波、高斯滤波、中值滤波等,大多数滤波方式...

  • 第 6 章 图像滤波

    本章包括以下内容: 用低通滤波器进行图像滤波; 用滤波器进行缩减像素采样; 用中值滤波器进行图像滤波; 用定向滤波...

  • 图像滤波器选用准则

    我们平时在做图像处理工作的时候经常会听到各种各样的滤波,什么均值滤波、高斯滤波、中值滤波、双边滤波等等,但着眼于应...

  • [图像增强][空间滤波]1.噪声消除法

    本篇主要介绍几种常见的噪声消除法:模糊,高斯滤波,盒滤波,中值滤波。 1. 基本原理 邻域 根据图像中像素与像素之...

  • opencv各种卷积核滤波器

    高斯滤波 使图像平滑,可以用来去除噪声。高斯滤波器将中心像素周围的像素按照高斯分布加权平均进行平滑化。 中值滤波 ...

  • 2018-03-04~提纲

    图像的像素,频率,格式 灰度值处理,阈值 灰度直方图 灰度梯度图HOG 图像分割 平滑,去噪(中值滤波) 锐化~边...

  • Android NDK开发:利用OpenCV实现美颜

    目录 效果演示 实现原理 首先使用中值滤波进行模糊操作,目的在于除去图像的噪点(包括一些小的色斑),然后利用双边滤...

  • 55. 高斯均值滤波

    本文使用高斯滤波api和均值滤波的源码实现图像滤波 高斯滤波: 结果如下: 均值滤波: 实现步骤: 读取原图片 指...

网友评论

      本文标题:Java实现图像中值滤波

      本文链接:https://www.haomeiwen.com/subject/ypurrctx.html