Java imageView与屏幕不正确匹配

Java imageView与屏幕不正确匹配,java,android,imageview,Java,Android,Imageview,我是一个全新的android应用程序编写者,我面临着一个问题,我的ImageView无法显示我的全貌,即使屏幕上还有空间。 似乎我的观点有一些左右的填充事件,如果不是这样的话 行为: 这是我的原图: 在这里,您可以找到实际显示在我的屏幕上的图片: 正如你所看到的,我的照片没有完全显示出来 代码 这是我的ImageView代码: class DrawableImageView extends ImageView implements FlutterView.OnTouchListener {

我是一个全新的android应用程序编写者,我面临着一个问题,我的ImageView无法显示我的全貌,即使屏幕上还有空间。 似乎我的观点有一些左右的填充事件,如果不是这样的话

行为:

这是我的原图:

在这里,您可以找到实际显示在我的屏幕上的图片:

正如你所看到的,我的照片没有完全显示出来

代码

这是我的ImageView代码:

class DrawableImageView extends ImageView implements FlutterView.OnTouchListener
{
   float downx = 0;
   float downy = 0;
   float upx = 0;
   float upy = 0;
   boolean draw = false;

   Canvas canvas;
   Paint paint;
   Matrix matrix;

   public DrawableImageView(Context context)
   {
       super(context);
       setOnTouchListener(this);
   }

   public DrawableImageView(Context context, AttributeSet attrs)
   {
       super(context, attrs);
       setOnTouchListener(this);
   }

   public DrawableImageView(Context context, AttributeSet attrs,
                            int defStyleAttr)
   {
       super(context, attrs, defStyleAttr);
       setOnTouchListener(this);
   }



   public void setNewImage(Bitmap alteredBitmap, Bitmap bmp)
   {
       canvas = new Canvas(alteredBitmap );
       paint = new Paint();
       paint.setColor(Color.RED);
       paint.setStrokeWidth(5);
       matrix = new Matrix();
       canvas.drawBitmap(bmp, matrix, paint);

       setImageBitmap(alteredBitmap);
   }

   public void setDraw(boolean newvalue)  {
       draw = newvalue;
       this.postInvalidate();
   }

   @Override
   public boolean onTouch(View v, MotionEvent event)
   {
       int action = event.getAction();

      if(draw) {
          switch (action)
          {
              case MotionEvent.ACTION_DOWN:
                  downx = getPointerCoords(event)[0];//event.getX();
                  downy = getPointerCoords(event)[1];//event.getY();
                  break;
              case MotionEvent.ACTION_MOVE:
                  upx = getPointerCoords(event)[0];//event.getX();
                  upy = getPointerCoords(event)[1];//event.getY();
                  canvas.drawLine(downx, downy, upx, upy, paint);
                  invalidate();
                  downx = upx;
                  downy = upy;
                  break;
              case MotionEvent.ACTION_UP:
                  upx = getPointerCoords(event)[0];//event.getX();
                  upy = getPointerCoords(event)[1];//event.getY();
                  canvas.drawLine(downx, downy, upx, upy, paint);
                  invalidate();
                  break;
              case MotionEvent.ACTION_CANCEL:
                  break;
              default:
                  break;
          }
      }
       return true;
   }

   final float[] getPointerCoords(MotionEvent e)
   {
       final int index = e.getActionIndex();
       final float[] coords = new float[] { e.getX(index), e.getY(index) };
       Matrix matrix = new Matrix();
       getImageMatrix().invert(matrix);
       matrix.postTranslate(getScrollX(), getScrollY());
       matrix.mapPoints(coords);
       return coords;
   }
}

以下是我实际视图的代码:

public class Markup implements PlatformView, MethodChannel.MethodCallHandler {
    private MethodChannel methodChannel;
    DrawableImageView choosenImageView;
    Bitmap alteredBitmap;

    private Bitmap bitmap;


    Markup(final Context context, int id, Object args, BinaryMessenger messenger, final PluginRegistry.Registrar registrar) {
        methodChannel = new MethodChannel(messenger, "plugins.smartapps.flutter_markup/markup_" + id);
        methodChannel.setMethodCallHandler(this);

        DisplayMetrics metrics = context.getResources().getDisplayMetrics();
        int width = metrics.widthPixels;
        int height = metrics.heightPixels;

        bitmap = BitmapFactory.decodeFile((String) args);
        bitmap = bitmap.copy(Bitmap.Config.ARGB_8888, true);
        choosenImageView = new DrawableImageView(context);
        choosenImageView.setMaxWidth(width);
        choosenImageView.setMaxHeight(height);
        choosenImageView.setAdjustViewBounds(true);
        choosenImageView.setScaleType(ImageView.ScaleType.FIT_CENTER);


        //scaleBitmap(bitmap);
        alteredBitmap = Bitmap.createBitmap(bitmap.getHeight(), bitmap.getWidth(), bitmap.getConfig());
        choosenImageView.setNewImage(alteredBitmap, bitmap);
    }


    @Override
    public View getView() {
        return choosenImageView;
    }


    @Override
    public void dispose() {
    }

}



我知道我的帖子我很喜欢,但是有人知道为什么会这样吗

谢谢大家!

试试这个:

<ImageView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:adjustViewBounds="true"
android:scaleType="fitXY" or  android:scaleType="centerCrop" //add this property 
/>


将图像视图的比例类型更改为“居中”或“剪裁”_XY@darwin通过这样做,我的imageView现在实际上是全屏显示,但图片仍然没有完全显示是的,这是预期的行为,因为分辨率(我指的是纵横比)您正在运行的应用程序的设备与图像的设备不同。如果您希望图像在屏幕上占据全部空间,则图像和屏幕的纵横比应相同。@darwin右侧,但如果您在原始图片中看到图片右侧是女性。然后,如果您看到跑步应用程序的屏幕截图,即使有空间渲染,女性也不会再出现。您的解决方案非常适合删除白色边框,但它不会改变我的全貌未显示的事实。是否添加了adjustViewBounds=“true”?