How to define a triangle layout like this image in android?

前端 未结 3 516
梦毁少年i
梦毁少年i 2021-01-03 18:51

How to create a layout like shown in image?

3条回答
  •  [愿得一人]
    2021-01-03 19:27

    Use this code :

    1. Create TriangleImageView.java class in Java folder :

    public class TriangleImageView extends ImageView {
    
        public TriangleImageView(Context ctx, AttributeSet attrs) {
            super(ctx, attrs);
        }
    
        @Override
        protected void onDraw(Canvas canvas) {
    
            Drawable drawable = getDrawable();
    
            if (drawable == null) {
                return;
            }
    
            if (getWidth() == 0 || getHeight() == 0) {
                return;
            }
            Bitmap b = ((BitmapDrawable) drawable).getBitmap();
            Bitmap bitmap = b.copy(Bitmap.Config.ARGB_8888, true);
    
            int w = getWidth(), h = getHeight();
    
            Bitmap roundBitmap = getRoundedCroppedBitmap(bitmap, w);
            canvas.drawBitmap(roundBitmap, 0, 0, null);
    
        }
    
        public static Bitmap getRoundedCroppedBitmap(Bitmap bitmap, int radius) {
            Bitmap finalBitmap;
            if (bitmap.getWidth() != radius || bitmap.getHeight() != radius)
                finalBitmap = Bitmap.createScaledBitmap(bitmap, radius, radius,
                        false);
            else
                finalBitmap = bitmap;
            Bitmap output = Bitmap.createBitmap(finalBitmap.getWidth(),
                    finalBitmap.getHeight(), Config.ARGB_8888);
            Canvas canvas = new Canvas(output);
    
            Paint paint = new Paint();
            final Rect rect = new Rect(0, 0, finalBitmap.getWidth(),
                    finalBitmap.getHeight());
    
            Point point1_draw = new Point(75, 0);
            Point point2_draw = new Point(0, 180);
            Point point3_draw = new Point(180, 180);
    
            Path path = new Path();
            path.moveTo(point1_draw.x, point1_draw.y);
            path.lineTo(point2_draw.x, point2_draw.y);
            path.lineTo(point3_draw.x, point3_draw.y);
            path.lineTo(point1_draw.x, point1_draw.y);
            path.close();
            canvas.drawARGB(0, 0, 0, 0);
            paint.setColor(Color.parseColor("#BAB399"));
            canvas.drawPath(path, paint);
            paint.setXfermode(new PorterDuffXfermode(Mode.SRC_IN));
            canvas.drawBitmap(finalBitmap, rect, rect, paint);
    
            return output;
        }
    
    }
    
    1. In Acitivity Use this code :

    private imageViewTriangle;

        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);
    
            imageViewTriangle=(ImageView)findViewById(R.id.imageView_triangle);
    
            Bitmap icon = BitmapFactory.decodeResource(getResources(), R.drawable.images);
            imageViewTriangle.setImageBitmap(icon);
    
        }
    
    1. Output is :

    Modify it as your need.

    Note : ImageView is define in comment because it give me trouble to improve formatting ..

提交回复
热议问题