当前位置: 编程技术>移动开发
本页文章导读:
▪一张图片覆盖在另一个图片下 一张图片覆盖在另一个图片上
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/gallerylayout"
android:layout_width="fill_parent"
android:layout_height="fill_parent">
<Gallery
.........
▪ 批量取得资源 & UI线程的刷新 批量获得资源 & UI线程的刷新
wo-09 10-22 dfeixtay ori[size=large][/size]华丽的暂时忘了!通过函数**,可以实现从资源文件夹中读入指定名称格式和类型的文件,再通过for循环遍历,可以生成int.........
▪ 应用PorterDuffXfermode实现遮罩层 使用PorterDuffXfermode实现遮罩层
最近在开发一个小游戏中,用到一个显示当前进度的进度条,如下图所示
由于中间黄色部分是进度条区域,带有一定的弧度而不是规则的长方形。刚开始想偷懒.........
[1]一张图片覆盖在另一个图片下
来源: 互联网 发布时间: 2014-02-18
一张图片覆盖在另一个图片上
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/gallerylayout" android:layout_width="fill_parent" android:layout_height="fill_parent"> <Gallery android:id="@+id/overview" android:layout_width="fill_parent" android:layout_height="wrap_content" /> <ImageView android:id="@+id/navigmaske" android:background="#0000" android:src="/blog_article/@drawable/a2/index.html" android:scaleType="fitXY" android:layout_alignTop="@id/overview" android:layout_alignBottom="@id/overview" android:layout_width="fill_parent" android:layout_height="wrap_content" /> </RelativeLayout>
android:background="#0000"
android:src="/blog_article/@drawable/a2/index.html"
注意这两个就行了 图片是png透明的
[2] 批量取得资源 & UI线程的刷新
来源: 互联网 发布时间: 2014-02-18
批量获得资源 & UI线程的刷新
wo-09 10-22 dfeixtay ori
[size=large][/size]
华丽的暂时忘了!
通过函数**,可以实现从资源文件夹中读入指定名称格式和类型的文件,再通过for循环遍历,可以生成int[]的资源数组,方便使用,这个之前我找了好久,一度以为不支持,今天看书,偶然翻到。
UI的刷新,ListView的刷新什么的,道理都一样,通常需要动态的时候启动一个线程,获取刷新用的数据,之后通过invalidate通知UI线程即主线程更新UI,但是,invalidate不能用在获取数据的线程里,因为它是个不安全的线程,一般是将invalidate写在handler里面,通过message传递,达到执行的目的。
也可以在获取数据的线程里使用postInvalidate(),好像效果是一样的。
wo-09 10-22 dfeixtay ori
[size=large][/size]
华丽的暂时忘了!
通过函数**,可以实现从资源文件夹中读入指定名称格式和类型的文件,再通过for循环遍历,可以生成int[]的资源数组,方便使用,这个之前我找了好久,一度以为不支持,今天看书,偶然翻到。
UI的刷新,ListView的刷新什么的,道理都一样,通常需要动态的时候启动一个线程,获取刷新用的数据,之后通过invalidate通知UI线程即主线程更新UI,但是,invalidate不能用在获取数据的线程里,因为它是个不安全的线程,一般是将invalidate写在handler里面,通过message传递,达到执行的目的。
也可以在获取数据的线程里使用postInvalidate(),好像效果是一样的。
[3] 应用PorterDuffXfermode实现遮罩层
来源: 互联网 发布时间: 2014-02-18
使用PorterDuffXfermode实现遮罩层
使用两张图片也可以哈,不过这样貌似可以节省一点图片空间
最近在开发一个小游戏中,用到一个显示当前进度的进度条,如下图所示
由于中间黄色部分是进度条区域,带有一定的弧度而不是规则的长方形。刚开始想偷懒用了很多办法来实现效果都不理想。后来想到使用遮罩层可以非常方便的实现这个功能。
可以通过修改Paint的Xfermode来实现遮罩的效果。Xfermode的功能非常强大,在API DEMO的Graphics中的最后一项有demo。看一下怎么实现我们的这个进度条吧。
首先用图片处理软件制作一个和中间黄色区域相同的图形,我们将在代码中设置它做为遮罩。
View的draw方法
public void draw(Canvas canvas) { //背景部分,也就是上面的图形 Bitmap background = BitmapFactory.decodeResource(getResources(), R.drawable.guage); //遮罩,就是提取来部分 Bitmap mask = BitmapFactory.decodeResource(getResources(), R.drawable.mask); canvas.drawColor(Color.WHITE); canvas.drawBitmap(background, 0, 0, null); Paint paint = new Paint(); paint.setFilterBitmap(false); int x = 0; int y = 0; // draw the src/dst example into our offscreen bitmap int sc = canvas.saveLayer(x, y, x + background.getWidth(), y + background.getHeight(), null, Canvas.MATRIX_SAVE_FLAG | Canvas.CLIP_SAVE_FLAG | Canvas.HAS_ALPHA_LAYER_SAVE_FLAG | Canvas.FULL_COLOR_LAYER_SAVE_FLAG | Canvas.CLIP_TO_LAYER_SAVE_FLAG); // canvas.drawBitmap(mDstB, 0, 0, paint); canvas.drawRect(0, 0, background.getWidth() / 2, background .getHeight(), paint); paint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.SRC_IN)); // canvas.drawBitmap(mSrcB, 0, 0, paint); canvas.drawBitmap(mask, 0f, 0f, paint); paint.setXfermode(null); canvas.restoreToCount(sc); }
只用控制绘制的矩形的长度就可以实现进度条的效果了。
1 楼
yinxiangjake
2010-10-26
为什么不直接使用两张长方形透明的图片,不就好了
2 楼
lonesane
2010-11-03
yinxiangjake 写道
为什么不直接使用两张长方形透明的图片,不就好了
使用两张图片也可以哈,不过这样貌似可以节省一点图片空间
3 楼
justin8335
2011-03-20
很好,这个技巧不错。收藏
4 楼
jiyuan18
2012-03-30
楼主高手!解决了我一大问题
最新技术文章: