Android(java)学习笔记180:多媒体之图形的变化处理

1. 图形的缩放

(1)布局文件activity_main.xml如下:

 1 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 2     xmlns:tools="http://schemas.android.com/tools"
 3     android:layout_width="match_parent"
 4     android:layout_height="match_parent"
 5     android:orientation="vertical"
 6     android:gravity="center_horizontal"
 7     tools:context="com.himi.bitmapdemo.MainActivity" >
 8 
 9     <ImageView
10         android:layout_width="wrap_content"
11         android:layout_height="wrap_content"
12         android:id="@+id/iv_src" />
13     <ImageView
14         android:layout_marginTop="10dip"
15         android:layout_width="wrap_content"
16         android:layout_height="wrap_content"
17         android:id="@+id/iv_copyed" />
18     
19 
20 </LinearLayout>

(2)MainActivity.java,如下:

 1 package com.himi.bitmapdemo;
 2 
 3 import android.app.Activity;
 4 import android.graphics.Bitmap;
 5 import android.graphics.Bitmap.Config;
 6 import android.graphics.BitmapFactory;
 7 import android.graphics.Canvas;
 8 import android.graphics.Color;
 9 import android.graphics.Matrix;
10 import android.graphics.Paint;
11 import android.os.Bundle;
12 import android.widget.ImageView;
13 
14 public class MainActivity extends Activity {
15     private ImageView iv_src;
16     private ImageView iv_copyed;
17 
18     @Override
19     protected void onCreate(Bundle savedInstanceState) {
20         super.onCreate(savedInstanceState);
21         setContentView(R.layout.activity_main);
22         iv_src = (ImageView) findViewById(R.id.iv_src);
23         iv_copyed = (ImageView) findViewById(R.id.iv_copyed);
24         // 设置原图
25         Bitmap bitmapSrc = BitmapFactory.decodeResource(getResources(),
26                 R.drawable.img01);
27         iv_src.setImageBitmap(bitmapSrc);
28 
29         // 对原图进行 缩放,创建一个原图的拷贝(副本),不能直接对原图变化
30         // 获取原图的纸张类型
31         Config config = bitmapSrc.getConfig();
32         // 创建的副本,里面的内容是空白的,画布
33         Bitmap alertBitmap = Bitmap.createBitmap(bitmapSrc.getWidth(),
34                 bitmapSrc.getHeight(), config);
35         // 以alertBitmap大小为模板创建一个画板
36         Canvas canvas = new Canvas(alertBitmap);
37         // 创建画笔
38         Paint paint = new Paint();
39         // 画笔的默认颜色
40         paint.setColor(Color.BLACK);
41         // 第一参数是临摹的图片
42         canvas.drawBitmap(bitmapSrc, new Matrix(), paint);
43         iv_copyed.setImageBitmap(alertBitmap);
44     }
45 
46 }

 new Matrix默认是1:1缩放比例,上面代码获取的是1:1的图片,效果如下:

 

如果我们想缩小图片大小为原来2倍,就可以直接这样修改代码,如下:

MainActivity.java,如下:

 1 package com.himi.bitmapdemo;
 2 
 3 import android.app.Activity;
 4 import android.graphics.Bitmap;
 5 import android.graphics.Bitmap.Config;
 6 import android.graphics.BitmapFactory;
 7 import android.graphics.Canvas;
 8 import android.graphics.Color;
 9 import android.graphics.Matrix;
10 import android.graphics.Paint;
11 import android.os.Bundle;
12 import android.widget.ImageView;
13 
14 public class MainActivity extends Activity {
15     private ImageView iv_src;
16     private ImageView iv_copyed;
17 
18     @Override
19     protected void onCreate(Bundle savedInstanceState) {
20         super.onCreate(savedInstanceState);
21         setContentView(R.layout.activity_main);
22         iv_src = (ImageView) findViewById(R.id.iv_src);
23         iv_copyed = (ImageView) findViewById(R.id.iv_copyed);
24         // 设置原图
25         Bitmap bitmapSrc = BitmapFactory.decodeResource(getResources(),
26                 R.drawable.img01);
27         iv_src.setImageBitmap(bitmapSrc);
28 
29         // 对原图进行 缩放,创建一个原图的拷贝(副本),不能直接对原图变化
30         // 获取原图的纸张类型
31         Config config = bitmapSrc.getConfig();
32         // 创建的副本,里面的内容是空白的,画布
33         Bitmap alertBitmap = Bitmap.createBitmap(bitmapSrc.getWidth()*2,
34                 bitmapSrc.getHeight()*2, config);
35         // 以alertBitmap大小为模板创建一个画板
36         Canvas canvas = new Canvas(alertBitmap);
37         // 创建画笔
38         Paint paint = new Paint();
39         // 画笔的默认颜色
40         paint.setColor(Color.BLACK);
41         // 第一参数是临摹的图片
42         Matrix matrix = new Matrix();
43         matrix.setScale(2.0f, 2.0f);
44         canvas.drawBitmap(bitmapSrc, matrix , paint);
45         iv_copyed.setImageBitmap(alertBitmap);
46     }
47 
48 }

运行效果如下:

 

 

如果我们想缩小图片大小为原来一半,就可以直接这样修改代码,如下:

MainActivity.java,如下:

 1 package com.himi.bitmapdemo;
 2 
 3 import android.app.Activity;
 4 import android.graphics.Bitmap;
 5 import android.graphics.Bitmap.Config;
 6 import android.graphics.BitmapFactory;
 7 import android.graphics.Canvas;
 8 import android.graphics.Color;
 9 import android.graphics.Matrix;
10 import android.graphics.Paint;
11 import android.os.Bundle;
12 import android.widget.ImageView;
13 
14 public class MainActivity extends Activity {
15     private ImageView iv_src;
16     private ImageView iv_copyed;
17 
18     @Override
19     protected void onCreate(Bundle savedInstanceState) {
20         super.onCreate(savedInstanceState);
21         setContentView(R.layout.activity_main);
22         iv_src = (ImageView) findViewById(R.id.iv_src);
23         iv_copyed = (ImageView) findViewById(R.id.iv_copyed);
24         // 设置原图
25         Bitmap bitmapSrc = BitmapFactory.decodeResource(getResources(),
26                 R.drawable.img01);
27         iv_src.setImageBitmap(bitmapSrc);
28 
29         // 对原图进行 缩放,创建一个原图的拷贝(副本),不能直接对原图变化
30         // 获取原图的纸张类型
31         Config config = bitmapSrc.getConfig();
32         // 创建的副本,里面的内容是空白的,画布
33         Bitmap alertBitmap = Bitmap.createBitmap(bitmapSrc.getWidth()/2,
34                 bitmapSrc.getHeight()/2, config);
35         // 以alertBitmap大小为模板创建一个画板
36         Canvas canvas = new Canvas(alertBitmap);
37         // 创建画笔
38         Paint paint = new Paint();
39         // 画笔的默认颜色
40         paint.setColor(Color.BLACK);
41         // 第一参数是临摹的图片
42         Matrix matrix = new Matrix();
43         matrix.setScale(0.5f, 0.5f);
44         canvas.drawBitmap(bitmapSrc, matrix , paint);
45         iv_copyed.setImageBitmap(alertBitmap);
46     }
47 
48 }

运行的效果如下:

 

 

2. 图形的旋转

承接上面的代码,修改MainActivity.java,如下:

 1 package com.himi.bitmapdemo;
 2 
 3 import android.app.Activity;
 4 import android.graphics.Bitmap;
 5 import android.graphics.Bitmap.Config;
 6 import android.graphics.BitmapFactory;
 7 import android.graphics.Canvas;
 8 import android.graphics.Color;
 9 import android.graphics.Matrix;
10 import android.graphics.Paint;
11 import android.os.Bundle;
12 import android.widget.ImageView;
13 
14 public class MainActivity extends Activity {
15     private ImageView iv_src;
16     private ImageView iv_copyed;
17 
18     @Override
19     protected void onCreate(Bundle savedInstanceState) {
20         super.onCreate(savedInstanceState);
21         setContentView(R.layout.activity_main);
22         iv_src = (ImageView) findViewById(R.id.iv_src);
23         iv_copyed = (ImageView) findViewById(R.id.iv_copyed);
24         // 设置原图
25         Bitmap bitmapSrc = BitmapFactory.decodeResource(getResources(),
26                 R.drawable.img01);
27         iv_src.setImageBitmap(bitmapSrc);
28 
29         // 对原图进行 缩放,创建一个原图的拷贝(副本),不能直接对原图变化
30         // 获取原图的纸张类型
31         Config config = bitmapSrc.getConfig();
32         // 创建的副本,里面的内容是空白的,画布
33         Bitmap alertBitmap = Bitmap.createBitmap(bitmapSrc.getWidth(),
34                 bitmapSrc.getHeight(), config);
35         // 以alertBitmap大小为模板创建一个画板
36         Canvas canvas = new Canvas(alertBitmap);
37         // 创建画笔
38         Paint paint = new Paint();
39         // 画笔的默认颜色
40         paint.setColor(Color.BLACK);
41         // 第一参数是临摹的图片
42         Matrix matrix = new Matrix();
43         //默认以画布左上角为旋转原点,旋转30°
44         //matrix.setRotate(30);
45         //以画布中心点为旋转原点,旋转30°
46         matrix.setRotate(30, bitmapSrc.getWidth()/2, bitmapSrc.getHeight()/2);
47         canvas.drawBitmap(bitmapSrc, matrix , paint);
48         iv_copyed.setImageBitmap(alertBitmap);
49     }
50 
51 }

效果如下:

3. 图形的平移

MainActivity代码如下:

 1 package com.himi.bitmapdemo;
 2 
 3 import android.app.Activity;
 4 import android.graphics.Bitmap;
 5 import android.graphics.Bitmap.Config;
 6 import android.graphics.BitmapFactory;
 7 import android.graphics.Canvas;
 8 import android.graphics.Color;
 9 import android.graphics.Matrix;
10 import android.graphics.Paint;
11 import android.os.Bundle;
12 import android.widget.ImageView;
13 
14 public class MainActivity extends Activity {
15     private ImageView iv_src;
16     private ImageView iv_copyed;
17 
18     @Override
19     protected void onCreate(Bundle savedInstanceState) {
20         super.onCreate(savedInstanceState);
21         setContentView(R.layout.activity_main);
22         iv_src = (ImageView) findViewById(R.id.iv_src);
23         iv_copyed = (ImageView) findViewById(R.id.iv_copyed);
24         // 设置原图
25         Bitmap bitmapSrc = BitmapFactory.decodeResource(getResources(),
26                 R.drawable.img01);
27         iv_src.setImageBitmap(bitmapSrc);
28 
29         // 对原图进行 缩放,创建一个原图的拷贝(副本),不能直接对原图变化
30         // 获取原图的纸张类型
31         Config config = bitmapSrc.getConfig();
32         // 创建的副本,里面的内容是空白的,画布
33         Bitmap alertBitmap = Bitmap.createBitmap(bitmapSrc.getWidth(),
34                 bitmapSrc.getHeight(), config);
35         // 以alertBitmap大小为模板创建一个画板
36         Canvas canvas = new Canvas(alertBitmap);
37         // 创建画笔
38         Paint paint = new Paint();
39         // 画笔的默认颜色
40         paint.setColor(Color.BLACK);
41         // 第一参数是临摹的图片
42         Matrix matrix = new Matrix();
43         matrix.setTranslate(0, 50);
44         canvas.drawBitmap(bitmapSrc, matrix , paint);
45         iv_copyed.setImageBitmap(alertBitmap);
46     }
47 
48 }

运行效果如下:图形竖直方向向下平移了50像素点(手机坐标系是水平向右为正竖直向下为正

 

4. 图形的倒影效果

分析:在画布上,先把图片的向下翻转,但是这样会跳出画布(不能显示),在让图形整体向上移动,移动距离为图形的高度。

MainActivity.java,如下:

 1 package com.himi.bitmapdemo;
 2 
 3 import android.app.Activity;
 4 import android.graphics.Bitmap;
 5 import android.graphics.Bitmap.Config;
 6 import android.graphics.BitmapFactory;
 7 import android.graphics.Canvas;
 8 import android.graphics.Color;
 9 import android.graphics.Matrix;
10 import android.graphics.Paint;
11 import android.os.Bundle;
12 import android.widget.ImageView;
13 
14 public class MainActivity extends Activity {
15     private ImageView iv_src;
16     private ImageView iv_copyed;
17 
18     @Override
19     protected void onCreate(Bundle savedInstanceState) {
20         super.onCreate(savedInstanceState);
21         setContentView(R.layout.activity_main);
22         iv_src = (ImageView) findViewById(R.id.iv_src);
23         iv_copyed = (ImageView) findViewById(R.id.iv_copyed);
24         // 设置原图
25         Bitmap bitmapSrc = BitmapFactory.decodeResource(getResources(),
26                 R.drawable.img01);
27         iv_src.setImageBitmap(bitmapSrc);
28 
29         // 对原图进行 缩放,创建一个原图的拷贝(副本),不能直接对原图变化
30         // 获取原图的纸张类型
31         Config config = bitmapSrc.getConfig();
32         // 创建的副本,里面的内容是空白的,画布
33         Bitmap alertBitmap = Bitmap.createBitmap(bitmapSrc.getWidth(),
34                 bitmapSrc.getHeight(), config);
35         // 以alertBitmap大小为模板创建一个画板
36         Canvas canvas = new Canvas(alertBitmap);
37         // 创建画笔
38         Paint paint = new Paint();
39         // 画笔的默认颜色
40         paint.setColor(Color.BLACK);
41         // 第一参数是临摹的图片
42         Matrix matrix = new Matrix();
43         matrix.setScale(1,-1); //图形向下翻转
44         //post是在上一次变化的基础上进行新的变化,set设置一个新的变化,会把原来的设置给覆盖
45         matrix.postTranslate(0, bitmapSrc.getHeight());//图形整体向上移动
46         canvas.drawBitmap(bitmapSrc, matrix , paint);
47         iv_copyed.setImageBitmap(alertBitmap);
48     }
49 
50 }

运行效果如下:

 

 

5. 图形镜面效果

分析:在画布上,先把图片的向左翻转,但是这样会跳出画布(不能显示),在让图形整体向右移动,移动距离为图形的宽度。

MainActivity.java,如下:

 1 package com.himi.bitmapdemo;
 2 
 3 import android.app.Activity;
 4 import android.graphics.Bitmap;
 5 import android.graphics.Bitmap.Config;
 6 import android.graphics.BitmapFactory;
 7 import android.graphics.Canvas;
 8 import android.graphics.Color;
 9 import android.graphics.Matrix;
10 import android.graphics.Paint;
11 import android.os.Bundle;
12 import android.widget.ImageView;
13 
14 public class MainActivity extends Activity {
15     private ImageView iv_src;
16     private ImageView iv_copyed;
17 
18     @Override
19     protected void onCreate(Bundle savedInstanceState) {
20         super.onCreate(savedInstanceState);
21         setContentView(R.layout.activity_main);
22         iv_src = (ImageView) findViewById(R.id.iv_src);
23         iv_copyed = (ImageView) findViewById(R.id.iv_copyed);
24         // 设置原图
25         Bitmap bitmapSrc = BitmapFactory.decodeResource(getResources(),
26                 R.drawable.img01);
27         iv_src.setImageBitmap(bitmapSrc);
28 
29         // 对原图进行 缩放,创建一个原图的拷贝(副本),不能直接对原图变化
30         // 获取原图的纸张类型
31         Config config = bitmapSrc.getConfig();
32         // 创建的副本,里面的内容是空白的,画布
33         Bitmap alertBitmap = Bitmap.createBitmap(bitmapSrc.getWidth(),
34                 bitmapSrc.getHeight(), config);
35         // 以alertBitmap大小为模板创建一个画板
36         Canvas canvas = new Canvas(alertBitmap);
37         // 创建画笔
38         Paint paint = new Paint();
39         // 画笔的默认颜色
40         paint.setColor(Color.BLACK);
41         // 第一参数是临摹的图片
42         Matrix matrix = new Matrix();
43         matrix.setScale(-1,1);
44         //post是在上一次变化的基础上进行新的变化,set设置一个新的变化,会把原来的设置给覆盖
45         matrix.postTranslate(bitmapSrc.getWidth(), 0);
46         canvas.drawBitmap(bitmapSrc, matrix , paint);
47         iv_copyed.setImageBitmap(alertBitmap);
48     }
49 
50 }

运行效果如下:

 

6. 图形透明度变化效果

MainActivity.java,如下:

 1 package com.himi.bitmapdemo;
 2 
 3 import android.app.Activity;
 4 import android.graphics.Bitmap;
 5 import android.graphics.Bitmap.Config;
 6 import android.graphics.BitmapFactory;
 7 import android.graphics.Canvas;
 8 import android.graphics.Color;
 9 import android.graphics.Matrix;
10 import android.graphics.Paint;
11 import android.os.Bundle;
12 import android.widget.ImageView;
13 
14 public class MainActivity extends Activity {
15     private ImageView iv_src;
16     private ImageView iv_copyed;
17 
18     @Override
19     protected void onCreate(Bundle savedInstanceState) {
20         super.onCreate(savedInstanceState);
21         setContentView(R.layout.activity_main);
22         iv_src = (ImageView) findViewById(R.id.iv_src);
23         iv_copyed = (ImageView) findViewById(R.id.iv_copyed);
24         // 设置原图
25         Bitmap bitmapSrc = BitmapFactory.decodeResource(getResources(),
26                 R.drawable.img01);
27         iv_src.setImageBitmap(bitmapSrc);
28 
29         // 对原图进行 缩放,创建一个原图的拷贝(副本),不能直接对原图变化
30         // 获取原图的纸张类型
31         Config config = bitmapSrc.getConfig();
32         // 创建的副本,里面的内容是空白的,画布
33         Bitmap alertBitmap = Bitmap.createBitmap(bitmapSrc.getWidth(),
34                 bitmapSrc.getHeight(), config);
35         // 以alertBitmap大小为模板创建一个画板
36         Canvas canvas = new Canvas(alertBitmap);
37         // 创建画笔
38         Paint paint = new Paint();
39         //设置画笔的透明度
40         paint.setAlpha(80);
41         // 画笔的默认颜色
42         //paint.setColor(Color.BLACK); //这里必须注释掉这个设置画布默认颜色
43         // 第一参数是临摹的图片
44         Matrix matrix = new Matrix();
45         
46         canvas.drawBitmap(bitmapSrc, matrix , paint);
47         iv_copyed.setImageBitmap(alertBitmap);
48     }
49 
50 }

运行效果如下:

posted on 2015-09-12 20:48  鸿钧老祖  阅读(224)  评论(0编辑  收藏  举报

导航