Я играл только один раз с функциями холста отрисовки и затем переключил все на opengl, но логика осталась прежней (я думаю).
В первом выпуске вы захотите сохранить постоянное соотношение от одного телефона к другому.
в моем приложении я добавляю эффект «черной полосы» с каждой стороны.
в onSurfaceChanged вы захотите рассчитать коэффициент, этот коэффициент позволит вам определить, сколько места вы должны удалить с каждой стороны, чтобы сохранить согласованный аспект вашего чертежа. это даст вам дельта X или Y для применения ко всем вашим розыгрышам
следующий код - это то, что я адаптировал из версии ogl, поэтому его, возможно, нужно немного подправить
@Override
public void onSurfaceChanged(int w, int h){
float ratioPhysicScreen = nativeScreenResoltionW/nativeScreenResoltionH;
float ratioWanted = GameView.getWidth()/GameView.getHeight();
if(ratioWanted>ratioPhysicScreen){
newHeight = (int) (w*GameView.getHeight()/GameView.getWidth());
newWidth = w;
deltaY = (int) ((h-newHeight)/2);
deltaX = 0;
}else{
newWidth = (int) (h/GameView.getHeight()*GameView.getWidth());
newHeight = h;
deltaX = (int) ((w-newWidth)/2);
deltaY = 0;
}
тогда вы также захотите нарисовать свои картины на холсте, зная, что на холсте есть и размер, и реальный размер, и разница между изображениями. ) и image.getScaledWidth (canvas), который дает вам размер элемента в dp, который означает, насколько он будет отображаться на экране). посмотрите на пример внизу.
public class MainMenuView extends PixelRainView{
private Bitmap bmpPlay = null;
private float playLeft = 0;
private float playRight = 0;
private float playBottom = 0;
private float playTop = 0;
public MainMenuView(Context context, AttributeSet attrs) {
super(context,attrs);
}
@Override
public void unLoadBitmaps() {
super.unLoadBitmaps();
if(bmpPlay != null){
bmpPlay.recycle();
bmpPlay = null;
}
}
@Override
protected void onDraw(Canvas canvas) {
super.onDraw(canvas);
if(bmpPlay == null){
bmpPlay = getBitmapFromRessourceID(R.drawable.play_bt);
playLeft = (this.getWidth()-bmpPlay.getScaledWidth(canvas))/2;
playRight = playLeft + bmpPlay.getScaledWidth(canvas);
playTop = (this.getHeight()-bmpPlay.getScaledHeight(canvas))/2;
playBottom = playTop+bmpPlay.getScaledHeight(canvas);
}
canvas.drawBitmap(bmpPlay,playLeft, playTop, null);
}
}
@Override
protected void onSizeChanged(int w, int h, int oldw, int oldh) {
super.onSizeChanged(w, h, oldw, oldh);
}
@Override
public boolean onTouchEvent(MotionEvent event) {
if(event.getAction() == MotionEvent.ACTION_DOWN){
float x = event.getX();
float y = event.getY();
//test central button
if(x>playLeft && x<playRight && y<playBottom && y>playTop){
Log.e("jason", "touched play");
PixelRainView.changeView(R.layout.composedlayoutgroup);
}
return super.onTouchEvent(event);
}
}
Это должно решить все ваши проблемы с соотношением пластин
Я бы предложил opengl, потому что это упростит вашу потребность в постоянном аспекте, но я думаю, что это не вариант ^^
Надеюсь, это вам достаточно поможет