gpt4 book ai didi

android - 如何圆角 ImageView 仅在侧面适合 Android 中的父布局?

转载 作者:太空宇宙 更新时间:2023-11-03 13:50:51 24 4
gpt4 key购买 nike

我是 Android 初学者。现在我正在学习如何正确设计 Android 应用程序。但是我在使用 ImageView 时遇到了问题。我想圆化 ImageView 的角,但只针对一侧。

这张图片是我想要得到的:

enter image description here

如您所见,只有 ImageView 的左侧角是圆角以适合父 View 。

这就是我现在得到的:

enter image description here

这是我的 ListView 行的 XML 布局:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:background="@drawable/list_row_bg"
android:orientation="horizontal"
android:layout_width="match_parent"
android:layout_height="match_parent">

<LinearLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content">
<ImageView
android:background="@color/colorPrimary"
android:id="@+id/row_image"
android:scaleType="fitCenter"
android:layout_width="100dp"
android:layout_height="100dp" />
</LinearLayout>

<LinearLayout
android:padding="@dimen/list_item_content_padding"
android:orientation="vertical"
android:layout_weight="1"
android:layout_width="wrap_content"
android:layout_height="wrap_content">

<TextView
android:id="@+id/row_title"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />

<TextView
android:id="@+id/row_duration"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />

<TextView
android:id="@+id/row_file_size"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />

<TextView
android:id="@+id/row_description"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />

</LinearLayout>
</LinearLayout>

我关注了this tutorial .但是 ImageView 包含填充。但是当我删除填充时,它无法正常工作。

最佳答案

我认为您应该在加载图像时应用转换。例如,如果您使用 picasso 加载图像,您可以应用此转换:

基类:

public class RoundedCornersBitmap implements Transformation {

private static final float DEFAULT_RADIUS = 5.f;
private static final int DEFAULT_BORDER_COLOR = Color.WHITE;
private static final int DEFAULT_STROKE_WIDTH = 3;

protected float mCornerRadius;
protected int mBorderColor;
protected int mStrokeWidth;

@Override
public String key() {
return "roundedCorners()";
}

public RoundedCornersBitmap() {
mCornerRadius = DEFAULT_RADIUS;
mBorderColor = DEFAULT_BORDER_COLOR;
mStrokeWidth = DEFAULT_STROKE_WIDTH;
}

public RoundedCornersBitmap(float cornderRadius, int borderColor, int strokeWidth) {
mCornerRadius = cornderRadius;
mBorderColor = borderColor;
mStrokeWidth = strokeWidth;
}

@Override
public Bitmap transform(Bitmap bitmap) {
Bitmap output = Bitmap.createBitmap(bitmap.getWidth(), bitmap.getHeight(), Config.ARGB_8888);
Canvas canvas = new Canvas(output);
final Paint paint = new Paint();
final Rect rect = new Rect(mStrokeWidth, mStrokeWidth, (bitmap.getWidth() - mStrokeWidth), bitmap.getHeight()
- mStrokeWidth);
final RectF rectF = new RectF(0, 0, bitmap.getWidth(), bitmap.getHeight());

paint.setAntiAlias(true);
paint.setColor(mBorderColor);
paint.setStrokeWidth(3);

canvas.drawARGB(0, 0, 0, 0);
canvas.drawRoundRect(rectF, mCornerRadius, mCornerRadius, paint);
//canvas.drawCircle(bitmap.getWidth() / 2, bitmap.getHeight() / 2, bitmap.getWidth() / 2, paint);

paint.setXfermode(new PorterDuffXfermode(Mode.SRC_IN));
canvas.drawBitmap(bitmap, rect, rect, paint);
bitmap.recycle();
return output;
}

/**
* @return the mCornerRadius
*/
public float getCornerRadius() {
return mCornerRadius;
}

/**
* @param mCornerRadius
* the mCornerRadius to set
*/
public void setCornerRadius(float mCornerRadius) {
this.mCornerRadius = mCornerRadius;
}

/**
* @return the mBorderColor
*/
public int getBorderColor() {
return mBorderColor;
}

/**
* @param mBorderColor
* the mBorderColor to set
*/
public void setBorderColor(int mBorderColor) {
this.mBorderColor = mBorderColor;
}

/**
* @return the mStrokeWidth
*/
public int getStrokeWidth() {
return mStrokeWidth;
}

/**
* @param mStrokeWidth
* the mStrokeWidth to set
*/
public void setStrokeWidth(int mStrokeWidth) {
this.mStrokeWidth = mStrokeWidth;
}

}

左圆角位图:

public class LeftRoundedCornersBitmap extends RoundedCornersBitmap {

public LeftRoundedCornersBitmap() {
super();
}

public LeftRoundedCornersBitmap(float cornderRadius, int borderColor, int strokeWidth) {
super(cornderRadius, borderColor, strokeWidth);
}

@Override
public Bitmap transform(Bitmap bitmap) {
Bitmap output = Bitmap.createBitmap(bitmap.getWidth(), bitmap.getHeight(), Config.ARGB_8888);
Canvas canvas = new Canvas(output);

final Paint paint = new Paint();
final Rect rect = new Rect(mStrokeWidth, mStrokeWidth, (bitmap.getWidth() - mStrokeWidth), bitmap.getHeight()
- mStrokeWidth);
final RectF rectF = new RectF(rect);
final Rect topRightRect = new Rect(bitmap.getWidth() / 2, 0, bitmap.getWidth(), bitmap.getHeight() / 2);
final Rect bottomRect = new Rect(bitmap.getWidth() / 2, bitmap.getHeight() / 2, bitmap.getWidth(), bitmap.getHeight());

paint.setAntiAlias(true);
paint.setColor(mBorderColor);
paint.setStrokeWidth(3);

canvas.drawARGB(0, 0, 0, 0);
canvas.drawRoundRect(rectF, mCornerRadius, mCornerRadius, paint);
canvas.drawRect(topRightRect, paint);
canvas.drawRect(bottomRect, paint);

paint.setXfermode(new PorterDuffXfermode(Mode.SRC_IN));
canvas.drawBitmap(bitmap, rect, rect, paint);
bitmap.recycle();
return output;
}
}

gradle 文件中的 Picasso 依赖:

compile 'com.squareup.picasso:picasso:2.5.2'

例子:

Picasso.with(context).load(imageUrl).transform(new LeftRoundedCornersBitmap()).into(youImageView);

关于android - 如何圆角 ImageView 仅在侧面适合 Android 中的父布局?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35172127/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com