图像的色调、饱和度、亮度调节

简介: 对于图像的色调、亮度、饱和度Android提供了ColorMatrix来供我们进行修改●setRotate(int axis, float degrees) 设置色调参数一(axis):颜色编号1(红),2(绿),3(蓝)参数二(degrees)...

对于图像的色调、亮度、饱和度Android提供了ColorMatrix来供我们进行修改

●setRotate(int axis, float degrees) 设置色调

参数一(axis):颜色编号1(红),2(绿),3(蓝)

参数二(degrees):修改的值(这里为角度值0~360)

方法调用

ColorMatrix colorMatrixS=new ColorMatrix();
colorMatrixS.setRotate(0,one);//红
colorMatrixS.setRotate(1,one);//绿
colorMatrixS.setRotate(2,one);//蓝

●setSaturation(float sat) 设置饱和度

参数(sat):值为1时是原图,大于1饱和度增加,小于1时饱和度减少,值为0时图像为灰色

方法调用

colorMatrixB.setSaturation(three);

●setScale(float rScale, float gScale, float bScale, float aScale)设置亮度

参数一(rScale):红色

参数二(gScale):绿色

参数三(bScale):蓝色

参数四(aScale):透明度

各个参数的值对应调节各个颜色的亮度,0代表全黑1代表原图,一般将透明度的值固定设置为1(原图效果),通过调节三元色的值来调节亮度。

方法调用

colorMatrixL.setScale(two,two,two,1);

效果展示

img_a2494b87b63db23185a4e1c11fa1624d.gif
效果展示

完整代码

Activity

public class MainActivity extends AppCompatActivity     implements SeekBar.OnSeekBarChangeListener{
    SeekBar seekBarone,seekbartwo,seekbarthree;
    ImageView imageView;
    float one=1,two=1,three=1;
    private Bitmap baseBitmap,copyBitmap;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        imageView = findViewById(R.id.img);
        seekBarone=findViewById(R.id.one);
        seekbartwo=findViewById(R.id.two);
        seekbarthree=findViewById(R.id.three);
        seekBarone.setOnSeekBarChangeListener(this);
        seekbartwo.setOnSeekBarChangeListener(this);
        seekbarthree.setOnSeekBarChangeListener(this);
        baseBitmap = BitmapFactory.decodeResource(getResources(), R.mipmap.aaa);
        //既然是复制一张与原图一模一样的图片那么这张复制图片的画纸的宽度和高度以及分辨率都要与原图一样,copyBitmap就为一张与原图相同尺寸分辨率的空白画纸
        copyBitmap=Bitmap.createBitmap(baseBitmap.getWidth(), baseBitmap.getHeight(), baseBitmap.getConfig());
    }
    @Override
    public void onProgressChanged(SeekBar seekBar, int progress, boolean fromUser) {
        switch (seekBar.getId()){
            case R.id.one:
                one=progress*1.0f/seekBar.getMax()*360;
                break;
            case R.id.two:
                two=progress*1.0f/(seekBar.getMax()-50);
                break;
            case R.id.three:
                three=progress*1.0f/(seekBar.getMax()-50);
                break;
        }
        Paint paint=new Paint();
        Canvas canvas=new Canvas(copyBitmap);
        ColorMatrix colorMatrixS=new ColorMatrix();
        colorMatrixS.setRotate(0,one);
        colorMatrixS.setRotate(1,one);
        colorMatrixS.setRotate(2,one);
        ColorMatrix colorMatrixL=new ColorMatrix();
        colorMatrixL.setScale(two,two,two,1);
        ColorMatrix colorMatrixB=new ColorMatrix();
        colorMatrixB.setSaturation(three);
        ColorMatrix colorMatriximg=new ColorMatrix();
    //        通过postConcat()方法可以将以上效果叠加到一起
        colorMatriximg.postConcat(colorMatrixB);
        colorMatriximg.postConcat(colorMatrixL);
        colorMatriximg.postConcat(colorMatrixS);
        ColorMatrixColorFilter colorMatrixColorFilter=new ColorMatrixColorFilter(colorMatriximg);
        paint.setColorFilter(colorMatrixColorFilter);
        canvas.drawBitmap(baseBitmap,new Matrix(),paint);
        imageView.setImageBitmap(copyBitmap);
    }

    @Override
    public void onStartTrackingTouch(SeekBar seekBar) {

    }

    @Override
    public void onStopTrackingTouch(SeekBar seekBar) {

    }
}

布局代码

<?xml version="1.0" encoding="utf-8"?>
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:app="http://schemas.android.com/apk/res-auto"
        xmlns:tools="http://schemas.android.com/tools"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical"
        tools:context="com.yuyigufen.customview.MainActivity">
    
        <ImageView
            android:layout_width="match_parent"
            android:src="@mipmap/aaa"
            android:id="@+id/img"
            android:layout_height="200dp" />
        <TextView
            android:layout_width="wrap_content"
            android:text="色调"
            android:layout_marginTop="20dp"
            android:layout_height="wrap_content" />
        <android.support.v7.widget.AppCompatSeekBar
            android:layout_width="match_parent"
            android:layout_marginLeft="10dp"
            android:id="@+id/one"
            android:layout_marginRight="10dp"
            android:layout_height="wrap_content" />
        <TextView
            android:layout_width="wrap_content"
            android:text="亮度"
            android:layout_marginTop="20dp"
            android:layout_height="wrap_content" />
        <android.support.v7.widget.AppCompatSeekBar
            android:layout_width="match_parent"
            android:layout_marginLeft="10dp"
            android:id="@+id/two"
            android:progress="50"
            android:layout_marginRight="10dp"
            android:layout_height="wrap_content" />
        <TextView
            android:layout_width="wrap_content"
            android:text="饱和度"
            android:layout_marginTop="20dp"
            android:layout_height="wrap_content" />
        <android.support.v7.widget.AppCompatSeekBar
            android:layout_width="match_parent"
            android:layout_marginLeft="10dp"
            android:id="@+id/three"
            android:progress="50"
            android:layout_marginRight="10dp"
            android:layout_height="wrap_content" />

</LinearLayout>
目录
相关文章
|
6月前
|
算法 计算机视觉
图像处理之调整亮度与对比度
图像处理之调整亮度与对比度
72 6
|
6月前
|
计算机视觉
限制对比度自适应直方图均衡化
【6月更文挑战第12天】限制对比度自适应直方图均衡化。
50 1
|
6月前
|
算法 Python
扭曲图像 鼻子拉伸
【6月更文挑战第28天】
31 0
|
6月前
|
计算机视觉
图像处理之调整亮度与饱和度
图像处理之调整亮度与饱和度
76 0
|
7月前
|
API 计算机视觉
【OpenCV】—图像对比度、亮度值调整
【OpenCV】—图像对比度、亮度值调整
|
7月前
[光源频闪] Basler相机光源频闪设置操作说明
[光源频闪] Basler相机光源频闪设置操作说明
312 0
|
Ubuntu
USB摄像头设置采集亮度和对比度
USB摄像头设置采集亮度和对比度
407 0
USB摄像头设置采集亮度和对比度
|
计算机视觉
四、OpenCV调整图像的亮度
像素越靠近0图像越按,越靠近255,图像越亮,所以调整图片的亮度也就是调整每个像素点数值的大小。
162 0
四、OpenCV调整图像的亮度
|
并行计算 iOS开发 MacOS
Metal每日分享,调节亮度滤镜效果
Metal每日分享,调节亮度滤镜效果
Metal每日分享,调节亮度滤镜效果
利用相机焦距进行物体尺寸测量
利用相机焦距进行物体尺寸测量
1258 0
利用相机焦距进行物体尺寸测量