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