IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 移动开发 -> Android 图片显示依附位置(上下左右及中心位置) -> 正文阅读

[移动开发]Android 图片显示依附位置(上下左右及中心位置)

1.说明:在 ImageView 的ScaleType.FIT_CENTER?基础上拓展

package com.example.view;

import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Matrix;
import android.graphics.Rect;
import android.graphics.drawable.Drawable;
import android.util.AttributeSet;
import android.util.Log;

import androidx.annotation.Nullable;
import androidx.appcompat.widget.AppCompatImageView;

public class FitScaleImageView extends AppCompatImageView {
    private String TAG = getClass().getName();
    private FitScaleType mFitScaleType = FitScaleType.FIT_CENTER;//默认 中心位置

    public FitScaleImageView(Context context) {
        this(context, null);
    }

    public FitScaleImageView(Context context, @Nullable AttributeSet attrs) {
        this(context, attrs, 0);
    }

    public FitScaleImageView(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {
        super(context, attrs, defStyleAttr);
    }

    @Override
    protected void onDraw(Canvas canvas) {
        setScaleType(ScaleType.FIT_CENTER);//设置固定缩放模式
        Drawable drawable = getDrawable();
        Matrix imageMatrix = getImageMatrix();
        if (drawable != null && imageMatrix != null) {
            float[] mv = new float[9];
            imageMatrix.getValues(mv);
            Rect bounds = drawable.getBounds();
            if (getWidth() > bounds.width() && getHeight() > bounds.height()) {
                mv[Matrix.MSCALE_X] = 1;
                mv[Matrix.MSCALE_Y] = 1;
            }
            float scaleWidth = bounds.width() * mv[Matrix.MSCALE_X];
            float scaleHeight = bounds.height() * mv[Matrix.MSCALE_Y];
            switch (mFitScaleType) {
                case FIT_CENTER_HORIZONTAL_TOP:
                    mv[Matrix.MTRANS_X] = (getWidth() - scaleWidth) / 2;
                    mv[Matrix.MTRANS_Y] = 0;
                    imageMatrix.setValues(mv);
                    break;
                case FIT_CENTER_HORIZONTAL_BOTTOM:
                    mv[Matrix.MTRANS_X] = (getWidth() - scaleWidth) / 2;
                    mv[Matrix.MTRANS_Y] = getHeight() - scaleHeight;
                    imageMatrix.setValues(mv);
                    break;
                case FIT_CENTER_VERTICAL_LEFT:
                    mv[Matrix.MTRANS_X] = 0;
                    mv[Matrix.MTRANS_Y] = (getHeight() - scaleHeight) / 2;
                    imageMatrix.setValues(mv);
                    break;
                case FIT_CENTER_VERTICAL_RIGHT:
                    mv[Matrix.MTRANS_X] = getWidth() - scaleWidth;
                    mv[Matrix.MTRANS_Y] = (getHeight() - scaleHeight) / 2;
                    imageMatrix.setValues(mv);
                    break;
                case FIT_LEFT_TOP:
                    mv[Matrix.MTRANS_X] = 0;
                    mv[Matrix.MTRANS_Y] = 0;
                    imageMatrix.setValues(mv);
                    break;
                case FIT_LEFT_BOTTOM:
                    mv[Matrix.MTRANS_X] = 0;
                    mv[Matrix.MTRANS_Y] = getHeight() - scaleHeight;
                    imageMatrix.setValues(mv);
                    break;
                case FIT_RIGHT_TOP:
                    mv[Matrix.MTRANS_X] = getWidth() - scaleWidth;
                    mv[Matrix.MTRANS_Y] = 0;
                    imageMatrix.setValues(mv);
                    break;
                case FIT_RIGHT_BOTTOM:
                    mv[Matrix.MTRANS_X] = getWidth() - scaleWidth;
                    mv[Matrix.MTRANS_Y] = getHeight() - scaleHeight;
                    imageMatrix.setValues(mv);
                    break;
                case FIT_CENTER:
                    mv[Matrix.MTRANS_X] = (getWidth() - scaleWidth) / 2;
                    mv[Matrix.MTRANS_Y] = (getHeight() - scaleHeight) / 2;
                    imageMatrix.setValues(mv);
                    break;
            }
            super.onDraw(canvas);
            Log.e(TAG, "MSCALE_X=" + mv[Matrix.MSCALE_X] + ",MSCALE_Y=" + mv[Matrix.MSCALE_Y] + ",MTRANS_X=" + mv[Matrix.MTRANS_X] + ",MTRANS_Y=" + mv[Matrix.MTRANS_Y] + "," + ",bd=" + bounds.toString() + ",cw=" + getWidth() + ",ch=" + getHeight() + ",scaleWidth=" + scaleWidth + ",scaleHeight=" + scaleHeight);
        } else {
            super.onDraw(canvas);
        }

    }

    /**
     * 设置 图片依附位置
     * @param fitScaleType 依附类型
     */
    public void setFitScaleType(FitScaleType fitScaleType) {
        mFitScaleType = fitScaleType;
    }

    public enum FitScaleType {
        /**
         * 依附 左上角
         */
        FIT_LEFT_TOP(0),
        /**
         * 依附 左下角
         */
        FIT_LEFT_BOTTOM(1),
        /**
         * 依附 右上角
         */
        FIT_RIGHT_TOP(2),
        /**
         * 依附 右下角
         */
        FIT_RIGHT_BOTTOM(3),
        /**
         * 依附 顶部且横向居中
         */
        FIT_CENTER_HORIZONTAL_TOP(4),
        /**
         * 依附 底部且横向居中
         */
        FIT_CENTER_HORIZONTAL_BOTTOM(5),
        /**
         * 依附 左边且垂直居中
         */
        FIT_CENTER_VERTICAL_LEFT(6),
        /**
         * 依附 右边且垂直居中
         */
        FIT_CENTER_VERTICAL_RIGHT(7),
        /**
         * 依附 中心位置
         */
        FIT_CENTER(8);

        FitScaleType(int ni) {
            nativeInt = ni;
        }

        final int nativeInt;
    }

}

  移动开发 最新文章
Vue3装载axios和element-ui
android adb cmd
【xcode】Xcode常用快捷键与技巧
Android开发中的线程池使用
Java 和 Android 的 Base64
Android 测试文字编码格式
微信小程序支付
安卓权限记录
知乎之自动养号
【Android Jetpack】DataStore
上一篇文章      下一篇文章      查看所有文章
加:2021-08-14 14:11:29  更:2021-08-14 14:11:42 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/19 0:45:45-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码