Android(java)学习笔记240:多媒体之图形颜色的变化

1.相信大家都用过美图秀秀中如下的功能,调整颜色:

2. 下面通过案例说明Android中如何调色:

颜色矩阵 ColorMatrix cm = new ColorMatrix();

paint.setColorFilter(new ColorMatrixColorFilter(cm));

1 0 0 0 0

0 1 0 0 0

0 0 1 0 0

0 0 0 1 0

New Red Value = 1*128 + 0*128 + 0*128 + 0*0 + 0

New Blue Value = 0*128 + 1*128 + 0*128 + 0*0 + 0

New Green Value = 0*128 + 0*128 + 1*128 + 0*0 + 0

New Alpha Value = 0*128 + 0*128 + 0*128 + 1*0 + 0

(1)新建一个新的Android工程,如下:

(2)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     tools:context="com.himi.xiuxiu.MainActivity" >
 7
 8     <TextView
 9         android:layout_width="wrap_content"
10         android:layout_height="wrap_content"
11         android:text="青------------->红" />
12
13     <SeekBar
14         android:id="@+id/sb_red"
15         android:max="255"
16         android:progress="128"
17         android:layout_width="match_parent"
18         android:layout_height="wrap_content" />
19      <TextView
20         android:layout_width="wrap_content"
21         android:layout_height="wrap_content"
22         android:text="紫------------->绿" />
23
24     <SeekBar
25         android:max="255"
26         android:progress="128"
27         android:id="@+id/sb_green"
28         android:layout_width="match_parent"
29         android:layout_height="wrap_content" />
30      <TextView
31         android:layout_width="wrap_content"
32         android:layout_height="wrap_content"
33         android:text="黄------------->蓝" />
34
35     <SeekBar
36         android:max="255"
37         android:progress="128"
38         android:id="@+id/sb_blue"
39         android:layout_width="match_parent"
40         android:layout_height="wrap_content" />
41     <ImageView
42         android:layout_width="wrap_content"
43         android:layout_height="wrap_content"
44         android:id="@+id/iv"
45         />
46
47 </LinearLayout>

布局效果如下:

(3)MainActivity,如下:

 1 package com.himi.xiuxiu;
 2
 3 import android.app.Activity;
 4 import android.graphics.Bitmap;
 5 import android.graphics.BitmapFactory;
 6 import android.graphics.Canvas;
 7 import android.graphics.ColorMatrix;
 8 import android.graphics.ColorMatrixColorFilter;
 9 import android.graphics.Matrix;
10 import android.graphics.Paint;
11 import android.os.Bundle;
12 import android.widget.ImageView;
13 import android.widget.SeekBar;
14 import android.widget.SeekBar.OnSeekBarChangeListener;
15
16 public class MainActivity extends Activity implements OnSeekBarChangeListener {
17     private SeekBar sb_red;
18     private SeekBar sb_green;
19     private SeekBar sb_blue;
20     private ImageView iv;
21
22     private Bitmap srcbitmap;
23     private Bitmap alertbitmap;
24     private Canvas canvas;
25     private Paint paint;
26     @Override
27     protected void onCreate(Bundle savedInstanceState) {
28         super.onCreate(savedInstanceState);
29         setContentView(R.layout.activity_main);
30         sb_red = (SeekBar) findViewById(R.id.sb_red);
31         sb_green = (SeekBar) findViewById(R.id.sb_green);
32         sb_blue = (SeekBar) findViewById(R.id.sb_blue);
33         iv = (ImageView) findViewById(R.id.iv);
34         //获得原图的位图
35         srcbitmap = BitmapFactory.decodeResource(getResources(), R.drawable.pre19);
36         //获得原图的拷贝副本
37         alertbitmap = Bitmap.createBitmap(srcbitmap.getWidth(), srcbitmap.getHeight(), srcbitmap.getConfig());
38         //创建一个画布
39         canvas = new Canvas(alertbitmap);
40         //创建画笔
41         paint = new Paint();
42
43         ColorMatrix cm = new ColorMatrix();
44         cm.set(new float[] {
45         1, 0, 0, 0, 0,
46         0, 1, 0, 0, 0,
47         0, 0, 1, 0, 0,
48         0, 0, 0, 1, 0
49         });
50
51         paint.setColorFilter(new ColorMatrixColorFilter(cm));
52         canvas.drawBitmap(srcbitmap, new Matrix(), paint);
53         iv.setImageBitmap(alertbitmap);
54
55         sb_red.setOnSeekBarChangeListener(this);
56         sb_green.setOnSeekBarChangeListener(this);
57         sb_blue.setOnSeekBarChangeListener(this);
58
59     }
60     public void onProgressChanged(SeekBar seekBar, int progress,
61             boolean fromUser) {
62         // TODO 自动生成的方法存根
63
64     }
65     public void onStartTrackingTouch(SeekBar seekBar) {
66         // TODO 自动生成的方法存根
67
68     }
69     // 停止滑动进度条,才设置颜色变化,节省内存
70     public void onStopTrackingTouch(SeekBar seekBar) {
71         float red=1;
72         float green=1;
73         float blue=1;
74         switch (seekBar.getId()) {
75         case R.id.sb_red:
76             red = seekBar.getProgress()/128.0f;
77             break;
78         case R.id.sb_green:
79             green = seekBar.getProgress()/128.0f;
80             break;
81         case R.id.sb_blue:
82             blue = seekBar.getProgress()/128.0f;
83             break;
84
85         default:
86             break;
87         }
88         ColorMatrix cm = new ColorMatrix();
89         cm.set(new float[] {    red, 0, 0, 0, 0,
90                                 0, green, 0, 0, 0,
91                                 0, 0, blue, 0, 0,
92                                 0, 0, 0, 1, 0 });
93
94         paint.setColorFilter(new ColorMatrixColorFilter(cm));
95         canvas.drawBitmap(srcbitmap, new Matrix(), paint);
96         iv.setImageBitmap(alertbitmap);
97     }
98
99 }

运行结果如下:

时间: 2024-10-01 07:06:29

Android(java)学习笔记240:多媒体之图形颜色的变化的相关文章

java学习笔记(二)图形用户接口

这个学期主要放在ACM比赛上去了.比赛结束了.不知不觉就15周了,这周就要java考试了.复习一下java吧.java的学习的目的还是让我们学以致用,让我们可以运用java开发一下小项目.而不是单单应付考试.今天复习了一下,图形用户接口,对监听的实现又加深了一些.java的布局控制,gui动画: 对书上代码的实现: 这个程序的功能就是按下button,会改变颜色.后面改变颜色的那个类是渐变的所以效果不明显: 主要是熟悉一下,布局管理和监听的写法.还有paintComponent类的一些使用方法:

java/android 设计模式学习笔记(13)---享元模式

这篇我们来介绍一下享元模式(Flyweight Pattern),Flyweight 代表轻量级的意思,享元模式是对象池的一种实现.享元模式用来尽可能减少内存使用量,它适合用于可能存在大量重复对象的场景,缓存可共享的对象,来达到对象共享和避免创建过多对象的效果,这样一来就可以提升性能,避免内存移除和频繁 GC 等. 享元模式的一个经典使用案例是文本系统中图形显示所用的数据结构,一个文本系统能够显示的字符种类就是那么几十上百个,那么就定义这么些基础字符对象,存储每个字符的显示外形和其他的格式化数据

java/android 设计模式学习笔记(14)---外观模式

这篇博客来介绍外观模式(Facade Pattern),外观模式也称为门面模式,它在开发过程中运用频率非常高,尤其是第三方 SDK 基本很大概率都会使用外观模式.通过一个外观类使得整个子系统只有一个统一的高层的接口,这样能够降低用户的使用成本,也对用户屏蔽了很多实现细节.当然,在我们的开发过程中,外观模式也是我们封装 API 的常用手段,例如网络模块.ImageLoader 模块等.其实我们在开发过程中可能已经使用过很多次外观模式,只是没有从理论层面去了解它. 转载请注明出处:http://bl

java/android 设计模式学习笔记(10)---建造者模式

这篇博客我们来介绍一下建造者模式(Builder Pattern),建造者模式又被称为生成器模式,是创造性模式之一,与工厂方法模式和抽象工厂模式不同,后两者的目的是为了实现多态性,而 Builder 模式的目的则是为了将对象的构建与展示分离.Builder 模式是一步一步创建一个复杂对象的创建型模式,它允许用户在不知道内部构建细节的情况下,可以更精细地控制对象的构造流程.一个复杂的对象有大量的组成部分,比如汽车它有车轮.方向盘.发动机.以及各种各样的小零件,要将这些部件装配成一辆汽车,这个装配过

java/android 设计模式学习笔记(一)---单例模式

前段时间公司一些同事在讨论单例模式(我是最渣的一个,都插不上嘴 T__T ),这个模式使用的频率很高,也可能是很多人最熟悉的设计模式,当然单例模式也算是最简单的设计模式之一吧,简单归简单,但是在实际使用的时候也会有一些坑. PS:对技术感兴趣的同鞋加群544645972一起交流 设计模式总目录 java/android 设计模式学习笔记目录 特点 确保某一个类只有一个实例,而且自行实例化并向整个系统提供这个实例. 单例模式的使用很广泛,比如:线程池(threadpool).缓存(cache).对

java/android 设计模式学习笔记(7)---装饰者模式

这篇将会介绍装饰者模式(Decorator Pattern),装饰者模式也称为包装模式(Wrapper Pattern),结构型模式之一,其使用一种对客户端透明的方式来动态的扩展对象的功能,同时它也是继承关系的一种替代方案之一,但比继承更加灵活.在现实生活中也可以看到很多装饰者模式的例子,或者可以大胆的说装饰者模式无处不在,就拿一件东西来说,可以给它披上无数层不一样的外壳,但是这件东西还是这件东西,外壳不过是用来扩展这个东西的功能而已,这就是装饰者模式,装饰者的这个角色也许各不相同但是被装饰的对

java/android 设计模式学习笔记(12)---组合模式

这篇我们来介绍一下组合模式(Composite Pattern),它也称为部分整体模式(Part-Whole Pattern),结构型模式之一.组合模式比较简单,它将一组相似的对象看作一个对象处理,并根据一个树状结构来组合对象,然后提供一个统一的方法去访问相应的对象,以此忽略掉对象与对象集合之间的差别.这个最典型的例子就是数据结构中的树了,如果一个节点有子节点,那么它就是枝干节点,如果没有子节点,那么它就是叶子节点,那么怎么把枝干节点和叶子节点统一当作一种对象处理呢?这就需要用到组合模式了. 转

java/android 设计模式学习笔记(9)---代理模式

这篇博客我们来介绍一下代理模式(Proxy Pattern),代理模式也成为委托模式,是一个非常重要的设计模式,不少设计模式也都会有代理模式的影子.代理在我们日常生活中也很常见,比如上网时连接的代理服务器地址,更比如我们平时租房子,将找房子的过程代理给中介等等,都是代理模式在日常生活中的使用例子. 代理模式中的代理对象能够连接任何事物:一个网络连接,一个占用很多内存的大对象,一个文件,或者是一些复制起来代价很高甚至根本不可能复制的一些资源.总之,代理是一个由客户端调用去访问幕后真正服务的包装对象

java/android 设计模式学习笔记(6)---适配器模式

这篇来介绍一下适配器模式(Adapter Pattern),适配器模式在开发中使用的频率也是很高的,像 ListView 和 RecyclerView 的 Adapter 等都是使用的适配器模式.在我们的实际生活中也有很多类似于适配器的例子,比如香港的插座和大陆的插座就是两种格式的,为了能够成功适配,一般会在中间加上一个电源适配器,形如: 这样就能够将原来不符合的现有系统和目标系统通过适配器成功连接. 说到底,适配器模式是将原来不兼容的两个类融合在一起,它有点类似于粘合剂,将不同的东西通过一种转