首页 > 代码库 > android 图片水平重复平铺(repeat x)
android 图片水平重复平铺(repeat x)
《=用来重复显示的图
1.最简单方式
创建wave_repeat.xml
<?xml version="1.0" encoding="utf-8"?>
<bitmap xmlns:android="http://schemas.android.com/apk/res/android"
android:src="@drawable/wave"
android:tileMode="repeat" />
<bitmap xmlns:android="http://schemas.android.com/apk/res/android"
android:src="@drawable/wave"
android:tileMode="repeat" />
在layout中使用
<View
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@drawable/wave_repeat" />
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@drawable/wave_repeat" />
这种方式有一个问题,最后一张重复图片不一定是完整的图片可能只是一部分
效果图:(左右两条竖线是后来加的)
2.可确保最后一张重复图片是完整的,就是几个完整的一样的图片X轴重复
Resources res = context.getResources();
Bitmap bitmap = BitmapFactory.decodeResource(res, R.drawable.wave);
holder.viewWave.setImageBitmap(BitmapHelper.createRepeater(screenWidth, bitmap));//screenWidth为屏幕宽度(或显示图片的imageview宽度)
Bitmap bitmap = BitmapFactory.decodeResource(res, R.drawable.wave);
holder.viewWave.setImageBitmap(BitmapHelper.createRepeater(screenWidth, bitmap));//screenWidth为屏幕宽度(或显示图片的imageview宽度)
BitmapHelper.java 中的方法
public static Bitmap createRepeater(int width, Bitmap src) {
int count = (width + src.getWidth() - 1) / src.getWidth(); //计算出平铺填满所给width(宽度)最少需要的重复次数
Bitmap bitmap = Bitmap.createBitmap(src.getWidth()*count, src.getHeight(), Config.ARGB_8888);
Canvas canvas = new Canvas(bitmap);
for (int idx = 0; idx < count; ++idx) {
canvas.drawBitmap(src, idx * src.getWidth(), 0, null);
}
return bitmap;
}
int count = (width + src.getWidth() - 1) / src.getWidth(); //计算出平铺填满所给width(宽度)最少需要的重复次数
Bitmap bitmap = Bitmap.createBitmap(src.getWidth()*count, src.getHeight(), Config.ARGB_8888);
Canvas canvas = new Canvas(bitmap);
for (int idx = 0; idx < count; ++idx) {
canvas.drawBitmap(src, idx * src.getWidth(), 0, null);
}
return bitmap;
}
在layout中设置imageview的scaleType为fitXY
<ImageView
android:id="@+id/view_wave"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:scaleType="fitXY" />
android:id="@+id/view_wave"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:scaleType="fitXY" />
效果图:
android 图片水平重复平铺(repeat x)
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。