Android ImageView不包裹缩放图像

问题描述 投票:0回答:1

我在可滚动视图中有一个ImageView。

<jp.vuph.TwoDScrollView
    android:id="@+id/two_d_scroll_view"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="@android:color/white">
    <RelativeLayout
        android:id="@+id/layout_drawing"
        android:orientation="horizontal"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content">
        <ImageView
            android:id="@+id/image_view_main"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:scaleType="matrix"
            android:layout_alignParentLeft="true"
            android:layout_alignParentStart="true"
            android:adjustViewBounds="true"
            android:contentDescription="@string/contentDescription"/>
    </RelativeLayout>
</jp.vuph.TwoDScrollView>

当我缩放图像时,ImageView不会扭曲所有缩放的图像,所以我看不到它的一部分。这是我的代码

private class ScaleGestureListener implements ScaleGestureDetector.OnScaleGestureListener {

    @Override
    public boolean onScale(ScaleGestureDetector detector) {
        d = mImageViewMain.getDrawable();
        mScale *= detector.getScaleFactor();

        float xDiff = initialFocalPoints[0] - currentFocalPoints[0];
        float yDiff = initialFocalPoints[1] - currentFocalPoints[1];

        matrix.setScale(mScale, mScale, currentFocalPoints[0], currentFocalPoints[1]);
        matrix.postTranslate(xDiff, yDiff);
        mImageViewMain.setImageMatrix(matrix);
        return true;
    }

    @Override
    public boolean onScaleBegin(ScaleGestureDetector detector) {
        float startX = detector.getFocusX();
        float startY = detector.getFocusY();

        initialFocalPoints = new float[]{startX, startY};
        Matrix inverseTransformMatrix = new Matrix();
        if(matrix.invert(inverseTransformMatrix))
        inverseTransformMatrix.mapPoints(currentFocalPoints, initialFocalPoints);
        return true;
    }

    @Override
    public void onScaleEnd(ScaleGestureDetector detector) {
        return;
    }

是否有可能使Imageview包裹所有缩放的图像?我尝试了很多方法,但仍然无法做到这一点。

android imageview zoom android-imageview scale
1个回答
0
投票

如果我是对的,这就是正在发生的事情:你正在放大一个焦点,然后当你缩小另一个焦点时,你会看到图像边缘周围的空白区域,因为它没有居中。

我必须在我的自定义捏缩图像视图中处理这个问题。需要发生的是需要根据ImageView本身的边界检查变换图像的边界,如果任何边界在ImageView内,则需要添加额外的平移以校正空白区域。

为此,我使用Matrix.mapRect()来预览图像变换的样子。

这些是属性,因此您只需分配一次RectF

        RectF imageRect = new RectF(0, 0, bitmap.getIntrinsicWidth(), bitmap.getIntrinsicHeight());

        RectF viewRect = new RectF(0, 0, mImageViewMain.getWidth(), mImageViewMain.getHeight());

        RectF transform = new RectF();

请注意,在测量完所有内容之前,您无法执行此操作。

onScale()setScale()之后但在postTranslate()之前将以下代码放在mImageViewMain.setImageMatrix(matrix);

        matrix.mapRect(transform, imageRect);  // dst, src

        // for this code to work, your matrix scaleX/Y can never be less that 1.0

        float xAdj = 0F;
        float yAdj = 0F;
        if (transform.left > 0) {  // blank space on left
            xAdj = - transform.left;
        } else if (transform.right < mImageViewMain.getWidth()) { // on right
            xAdj = mImageViewMain.getWidth() - transform.right;
        }

        if (transform.top > 0) { // blank space on top
            yAdj = - transform.top;
        } else if (transform.bottom < mImageViewMain.getHeight()) { // on bottom
            yAdj = mImageViewMain.getHeight() - transform.bottom;
        }

        matrix.postScale(xAdj, yAdj);

那段代码可能不完全正确,但你明白了。使用matrix.mapRect()查看是否有空格,然后调用matrix.postScale()来修复空格。

我遗漏了代码的部分是你必须进行一些更奇特的计算,因为图像的纵横比可能与ImageView的纵横比不匹配,所以有时候你想要边界在里面,但在那种情况下你必须进行调整,使图像居中。这只是很多数学。

© www.soinside.com 2019 - 2024. All rights reserved.