Android圖像處理(一)--Paint,Canvas,ColorMatrix基礎

本文主要是記錄學習狀況, 不是很是合適當作教程, 水平有限, 講得很差.java

首先上圖android

    

圖中三個SeekBar分別表明hue色相, saturation飽和度跟lum亮度canvas

佈局代碼app

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingTop="30dp"
	android:paddingLeft="20dp"
	android:paddingRight="20dp"
    tools:context=".MainActivity" 
    android:orientation="vertical"
    >

    
    <ImageView 
        android:layout_width="300dp"
        android:layout_height="300dp"
        android:id="@+id/id_image"
        android:background="@drawable/image_1"
        />
    <SeekBar 
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:id="@+id/id_seekbar1"
        />
    
    <SeekBar 
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:id="@+id/id_seekbar2"
        />
    
    <SeekBar 
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:id="@+id/id_seekbar3"
        />


</LinearLayout>

主界面,activity代碼ide

package com.example.imageprocess;
import android.app.Activity;
import android.content.Context;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.os.Bundle;
import android.widget.ImageView;
import android.widget.SeekBar;
public class PrimaryActivity extends Activity implements SeekBar.OnSeekBarChangeListener
{
	private Context context;
	private static final String TAG = "";
	private Bitmap bitmap;
	private ImageView imageView;
	private SeekBar seekBar1;
	private SeekBar seekBar2;
	private SeekBar seekBar3;
	private static int MAX_VALUE = 255;
	private static int MID_VALUE = 127;
	private float mHue, mSaturation, mLua;
	@Override
	protected void onCreate(Bundle savedInstanceState)
	{
		// TODO Auto-generated method stub
		super.onCreate(savedInstanceState);
		setContentView(R.layout.process_image_activity);
		bitmap = BitmapFactory.decodeResource(getResources(), R.drawable.image_1);
		imageView = (ImageView) findViewById(R.id.id_image);
		imageView.setImageBitmap(bitmap);
		seekBar1 = (SeekBar) findViewById(R.id.id_seekbar1);
		seekBar2 = (SeekBar) findViewById(R.id.id_seekbar2);
		seekBar3 = (SeekBar) findViewById(R.id.id_seekbar3);
		seekBar1.setOnSeekBarChangeListener(this);
		seekBar2.setOnSeekBarChangeListener(this);
		seekBar3.setOnSeekBarChangeListener(this);
		seekBar1.setMax(MAX_VALUE);
		seekBar2.setMax(MAX_VALUE);
		seekBar3.setMax(MAX_VALUE);
		seekBar1.setProgress(MID_VALUE);
		seekBar2.setProgress(MID_VALUE);
		seekBar3.setProgress(MID_VALUE);
	}
	@Override
	protected void onResume()
	{
		// TODO Auto-generated method stub
		super.onResume();
	}
	@Override
	public void onProgressChanged(SeekBar seekBar, int progress, boolean fromUser)
	{
		// TODO Auto-generated method stub
		switch (seekBar.getId())
		{
		case R.id.id_seekbar1:
			mHue = (progress - MID_VALUE) * 1.0f / MID_VALUE * 180;
			break;
		case R.id.id_seekbar2:
			mSaturation = progress * 1.0f / MID_VALUE;
			break;
		case R.id.id_seekbar3:
			mLua = progress * 1.0f / MID_VALUE;
			break;
		}
		imageView.setImageBitmap(ImageHelper.handleImageEffect(bitmap, mHue, mSaturation, mLua));
	}
	@Override
	public void onStartTrackingTouch(SeekBar seekBar)
	{
		// TODO Auto-generated method stub
	}
	@Override
	public void onStopTrackingTouch(SeekBar seekBar)
	{
		// TODO Auto-generated method stub
	}
}

其中,函數

 MAX_VALUE = 255;//表明seekBar的最大值佈局

 MID_VALUE = 127;//seekbar的中間值post

onProgressChanged函數中得三個公式, 是一個經驗公式, 是從視頻上得知的, 在此就用上了學習


重點就是ImageHelper裏面的處理代碼this

public class ImageHelper
{

	/**
	 * 用系統的matrix來處理圖片
	 * 
	 * @param bm
	 * @param hue
	 * @param saturation
	 * @param lua
	 * @return
	 */
	public static Bitmap handleImageEffect(Bitmap bm, Float hue, Float saturation, Float lua)
	{
		// 參數bitmap是final 不可修改 因此新建一個bitmap
		Bitmap bmp = Bitmap.createBitmap(bm.getWidth(), bm.getHeight(), Bitmap.Config.ARGB_8888);
		Canvas canvas = new Canvas(bmp);
		Paint paint = new Paint(Paint.ANTI_ALIAS_FLAG);

		ColorMatrix hueMatrix = new ColorMatrix();
		hueMatrix.setRotate(0, hue);// R
		hueMatrix.setRotate(1, hue);// G
		hueMatrix.setRotate(2, hue);// B

		ColorMatrix saturationMatrix = new ColorMatrix();
		saturationMatrix.setSaturation(saturation);

		ColorMatrix luaMatrix = new ColorMatrix();
		luaMatrix.setScale(lua, lua, lua, 1);

		ColorMatrix colorMatrix = new ColorMatrix();
		colorMatrix.postConcat(hueMatrix);
		colorMatrix.postConcat(saturationMatrix);
		colorMatrix.postConcat(luaMatrix);

		paint.setColorFilter(new ColorMatrixColorFilter(colorMatrix));
		canvas.drawBitmap(bm, 0, 0, paint);
		return bmp;
	}
}
相關文章
相關標籤/搜索