Android音视频任务列表之(一)——在 Android 平台绘制一张图片,使用至少 3 种不同的 API,ImageView,SurfaceView,自定义 View

一.使用ImageView绘制图片

1.在布局文件中添加ImageView控件

   <ImageView
        android:id="@+id/imageView"
        android:layout_width="120dp"
        android:layout_height="120dp"
       />

2.在Activity中找到控件并设置图片

 imageView= findViewById(R.id.imageView);
 imageView.setImageResource(R.drawable.girl);

二.使用SurfaceView绘制图片

1.在布局文件中添加CustomSurfaceView控件

   <com.ry.question1.CustomSurfaceView
        android:layout_width="120dp"
        android:layout_height="120dp"
         />

2.主要代码

private void initView() {
        mHolder=getHolder();
        mHolder.addCallback(this);
        setFocusable(true);
        setFocusableInTouchMode(true);
        this.setKeepScreenOn(true);
    }
    public CustomSurfaceView(Context context, AttributeSet attrs) {
        super(context, attrs);
        initView();
    }

    @Override
    public void surfaceCreated(@NonNull SurfaceHolder holder) {
        Paint paint = new Paint();
        paint.setAntiAlias(true);
        paint.setStyle(Paint.Style.STROKE);
        BitmapDrawable bd = (BitmapDrawable) getResources().getDrawable(R.drawable.girl);
        Bitmap   bitmap = bd.getBitmap();
        Canvas canvas = holder.lockCanvas();  // 先锁定当前surfaceView的画布
        canvas.drawBitmap(bitmap, 0, 0, paint); //执行绘制操作
        holder.unlockCanvasAndPost(canvas); // 解除锁定并显示在界面上
    }

三.使用自定义view绘制图片

1.布局

  <com.ry.question1.CustomView
        android:layout_width="120dp"
        android:layout_height="120dp"/>

2.主要代码

 @Override
    protected void onDraw(Canvas canvas) {
        Paint paint = new Paint();
        paint.setAntiAlias(true);
        paint.setStyle(Paint.Style.STROKE);
        BitmapDrawable bd = (BitmapDrawable) getResources().getDrawable(R.drawable.girl);
        Bitmap bitmap = bd.getBitmap();
        // 方式二:
        // Bitmap bitmap = BitmapFactory.decodeFile("/storage/emulated/0/wuqian.jpg");  // 获取bitmap

        canvas.drawBitmap(bitmap, 0, 0, paint); //执行绘制操作
        super.onDraw(canvas);
    }

四.显示效果

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
自定义一个 `ImageView` 并使用不同的 `Paint` 绘制图片,需要创建一个自定义的 `ImageView` 类并重写其中的 `onDraw()` 方法。在该方法中,可以使用不同的 `Paint` 对图片进行绘制。以下是一个简单的示例代码: ```java public class CustomImageView extends ImageView { private Paint paint1; private Paint paint2; public CustomImageView(Context context) { super(context); init(); } public CustomImageView(Context context, AttributeSet attrs) { super(context, attrs); init(); } public CustomImageView(Context context, AttributeSet attrs, int defStyleAttr) { super(context, attrs, defStyleAttr); init(); } private void init() { // 初始化两个不同的 Paint paint1 = new Paint(); paint1.setColor(Color.RED); paint1.setStyle(Paint.Style.FILL); paint2 = new Paint(); paint2.setColor(Color.BLUE); paint2.setStyle(Paint.Style.STROKE); paint2.setStrokeWidth(10); } @Override protected void onDraw(Canvas canvas) { // 获取当前 ImageView 中的 Drawable Drawable drawable = getDrawable(); // 如果 Drawable 为空,则直接返回 if (drawable == null) { return; } // 获取 Drawable 的宽和高 int width = drawable.getIntrinsicWidth(); int height = drawable.getIntrinsicHeight(); // 将 Drawable 绘制在 Canvas 上 drawable.setBounds(0, 0, width, height); drawable.draw(canvas); // 使用不同的 Paint 绘制边框和填充效果 canvas.drawRect(0, 0, width, height, paint1); canvas.drawRect(10, 10, width - 10, height - 10, paint2); } } ``` 在这个示例中,我们创建了一个 `CustomImageView` 类,重写了其中的 `onDraw()` 方法,并在该方法中使用两个不同的 `Paint` 绘制了一个边框和一个填充效果。你可以根据自己的需求修改 `Paint` 的属性,实现不同的效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值