prevision->http://blog.csdn.net/icedcap/article/details/20779531
大家好,在上一篇博客中笔者主要介绍了ImageView 的官方API和ScaleType的八种属性并且附图讲解了八种属性对图片的缩放布局效果。
今天,将为大家介绍一下ImageView 一些常用的方法利用这些方法达到对图片不同的展示效果。(接上一讲标号)
(二)利用SeekBar实现图片透明度变化
ImageView 的protected boolean setAlpha(int alpha)方法是控制图片透明度的。具体如下:
透明度改变时执行。子类可以使用该方法指定透明度值,然后返回真; 在调用 onDraw() 时,使用该透明度值。如果返回假,则先在不可见的缓存中绘制视图, 完成该请求;看起来不错,但是可能相对于在子类中绘制要慢。默认实现返回假。参数alpha 的范围是(0…255)。
利用SeekBar拖拽来实现图片透明度的控制。主要用到OnSeekBarChangeListener的onProgressChanged(。。。)方法
class SeekBarListener implements OnSeekBarChangeListener {
@Override
public void onProgressChanged(SeekBar seekBar, int progress,
boolean fromUser) {
// TODO Auto-generated method stub
}
@Override
public void onStartTrackingTouch(SeekBar seekBar) {
// TODO Auto-generated method stub
}
@Override
public void onStopTrackingTouch(SeekBar seekBar) {
// TODO Auto-generated method stub
}
}
透明度int alpha的控制如下:
/**
* 透明度的控制
* @param offset 偏移量
*/
private static void setAlphaChange(int offset) {
// 透明度初始值
imageAlpha = 255;
if (offset >= 0) {
// 透明度减小
imageAlpha -= offset;
if (imageAlpha <= 0)
imageAlpha = 0;
iv.setAlpha(imageAlpha);
} else {
// 透明度增加
imageAlpha += offset;
if (imageAlpha >= 255)
imageAlpha = 255;
iv.setAlpha(imageAlpha);
}
}
(三)、相册循环播放效果(主要是一个循环算法)
代码如下:
private int currentImage = Integer.MAX_VALUE / 2;// 当前这张图片,设置一个很大的值,保证前后翻页不会出现异常
/**
* changePic
* @param i 向上(下)翻还
*/
private void changePic(int i) {
// 为了保证图片能够循环, 这里模运算是关键, 显示图片的下标始终是长度的模
if (i == R.id.button1) {
System.out.println("index==>" + currentImage % images.length);
currentImage -= 1;
iv.setImageResource(images[(--currentImage) % images.length]);
} else {
System.out.println("index==>" + currentImage % images.length);
currentImage += 1;
iv.setImageResource(images[(++currentImage) % images.length]);
}
}
翻图效果已经实现了循环。下面贴出上述方法执行时打印的images数组index:
好了今天就将这么多吧,下面贴出源代码下载地址:
http://download.csdn.net/detail/icedcap/7013935
NEXT->http://blog.csdn.net/icedcap/article/details/21041713