无法动态添加自定义视图,WRAP_CONTENT为高度和宽度



我正在尝试将多个自定义视图添加到帧布局中,但它总是采用框架布局的整个宽度和高度。自定义视图仅包含一个50x50的图像,我希望能够在框架布局周围移动,但是随着自定义视图将整个空间和彼此重叠,我无法选择其他自定义视图,因此为什么要包装它。

这是我添加自定义视图的方式:

OverlayView overlayView = new OverlayView(EditorActivity.this, themeFilter.drawable);
frameLayout.addView(overlayView, 1, new FrameLayout.LayoutParams(FrameLayout.LayoutParams.WRAP_CONTENT, FrameLayout.LayoutParams.WRAP_CONTENT));

这是覆盖图:

public class OverlayView extends View {
    Bitmap bitmap;
    float x,y;
    float centerX, centerY;
    public OverlayView(Context context, int drawable) {
        super(context);
    bitmap = BitmapFactory.decodeResource(context.getResources(), drawable);
    centerX = (float)getWidth() /2;
    centerY = (float)getHeight() /2;
    x = centerX;
    y = centerY;
}
@Override
protected void onDraw(Canvas canvas) {
    super.onDraw(canvas);
    if (x != centerX && y != centerY) {
        canvas.drawBitmap(bitmap, x-bitmap.getWidth()/2, y-bitmap.getHeight()/2, null);
    } else {
        //INITIALIZE BITMAP ON CENTER OF SCREEN
        canvas.drawBitmap(bitmap, (float)getWidth()/2 - bitmap.getWidth()/2, (float)getHeight()/2 -bitmap.getHeight()/2, null);
    }
}
@Override
public boolean onTouchEvent(MotionEvent event) {
    switch(event.getAction()) {
        case MotionEvent.ACTION_DOWN :
            break;
        case MotionEvent.ACTION_MOVE :
            x = event.getX();
            y = event.getY();
            invalidate();
            break;
        case MotionEvent.ACTION_UP :
            x = event.getX();
            y = event.getY();
            invalidate();
    }
    return true;
}

}

现在我想的是保持原样。意思是,叠加视图在整个屏幕上都采用,我只需要在其他覆盖图之间切换焦点即可移动它们(我什至不知道这是否可能是可能的 - 在堆叠的叠加层之间切换焦点),但我担心浪费空间影响记忆和性能,因为图像仅为50x50。

在onMeasure()中计算覆盖图的大小。尝试此实现:

@Override
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) 
{
    int width = View.MeasureSpec.makeMeasureSpec(bitmap.getWidth(), MeasureSpec.EXACTLY);
    int height = View.MeasureSpec.makeMeasureSpec(bitmap.getHeight(), MeasureSpec.EXACTLY);
    setMeasuredDimension(width, height);
}

还可以查看此实现以进行命令。

相关内容

  • 没有找到相关文章

最新更新