2012-02-07 16 views
0

は、ここに表示される画面私はLoadingScreen.javaで作成したビットマップから、それへの投稿、その後FastRenderView.javaにおける表面図を作成している私は何をやっているどのようにアンドロイド画面を計算する?

Android Screen

の写真です。もちろんLoading Screenは、使用される多くの画面の1つです。

私の問題は、LoadingScreenで画面の正しいサイズを計算していないことです。ここに私を助けるために必要なファイルがあります。

別の言葉では、私はAndroidのゲームから画面のサイズを取得しています。これはLoading画面に送られ、ゲーム全体のビットマップが作成されます。このビットマップは黒色で、赤色のローディングバーがあります。それから私はビットマップを画面に読み込むFastレンダリングビューに読み込み画面から送ります。しかし、ビットマップは画面サイズよりはるかに小さいです。これをどうやって解決するのですか?

FastRenderView.java

package framework.impl; 

import android.graphics.Canvas; 
import android.graphics.Rect; 
import android.util.Log; 
import android.view.SurfaceHolder; 
import android.view.SurfaceView; 
import framework.Game; 

public class FastRenderView extends SurfaceView implements Runnable { 

    Game game; 
    Thread renderThread = null; 
    SurfaceHolder holder; 
    volatile boolean running = false; 

    public FastRenderView(AndroidGame game) { 
     super(game); 
     this.game = game; 
     this.holder = getHolder(); 
    } 

    @Override 
    public void run() { 
     Rect dstRect = new Rect(); 
     long startTime = System.nanoTime(); 
     while(running) { 
      if(!holder.getSurface().isValid()) { 
       continue; 
      } 

      float deltaTime = (System.nanoTime() - startTime)/1000000000.0f; 
      startTime = System.nanoTime(); 

      game.getScreen().update(deltaTime); 
      game.getScreen().present(deltaTime); 

      // Method 1 // 
      //this.game.getScreen().setCanvas(this.holder.lockCanvas()); 
      //this.holder.unlockCanvasAndPost(this.game.getScreen().getCurrentCanvas()); 

      // Method 2 // 
      Canvas canvas = this.holder.lockCanvas(); 
      canvas.drawARGB(255, 150, 150, 10); 
      canvas.drawBitmap(this.game.getScreen().getCurrentScreen(), 0, 0, null); 
      holder.unlockCanvasAndPost(canvas); 

      try { 
       Thread.sleep(100); 
      } catch(Exception e) { 
       e.printStackTrace(); 
      } 
     } 
    } 

    public void resume() { 
     running = true; 
     renderThread = new Thread(this); 
     renderThread.start(); 
    } 

    public void pause() { 
     running = false; 
     while(true) { 
      try { 
       renderThread.join(); 
       break; 
      } catch(Exception e) { 
       // retry 
      } 
     } 
    } 
} 

LoadingScreen.java

import android.graphics.Bitmap; 
import android.graphics.Bitmap.Config; 
import android.graphics.Canvas; 
import android.graphics.Color; 
import android.graphics.Paint; 
import android.graphics.Rect; 
import framework.Game; 
import framework.Screen; 

public class LoadingScreen extends Screen { 

    private int loadingPercent; 
    Canvas currentCanvas; 
    Bitmap currentScreen; 
    Paint paint; 

    public LoadingScreen(Game game) { 
     super(game); 
     this.currentScreen = Bitmap.createBitmap(this.game.getFrameWidth(), this.game.getFrameHeight(), Config.RGB_565); 
     this.game.getFastRenderView().run(); 
    } 

    @Override 
    public void update(float deltaTime) { 
     this.loadingPercent = 0; 
     Assets assets = game.getAssetsClass(); 
     this.loadingPercent = 33; 
     assets.plane = assets.fetchImage("image.png"); 
     this.loadingPercent = 66; 
     assets.plane_full = assets.fetchImage("image2.png"); 
     this.loadingPercent = 99; 
     //this.game.setScreen(new MainMenuScreen(this.game)); 
    } 

    @Override 
    public void present(float deltaTime) { 
     Bitmap picture = Bitmap.createBitmap(this.game.getFrameWidth(), this.game.getFrameHeight(), Config.RGB_565); 
     Canvas canvas = new Canvas(picture); 
     paint = new Paint(); 
     paint.setColor(Color.RED); 
     Rect darkRed = new Rect(10, 10, 4 * this.loadingPercent, 40); 
     canvas.drawRect(darkRed, paint); 
     this.currentCanvas = canvas; 
     this.currentScreen = picture; 
    } 

    @Override 
    public Bitmap getCurrentScreen() { 
     return this.currentScreen; 
    } 

    @Override 
    public void setCanvas(Canvas canvas) { 
     this.currentCanvas = canvas; 
    } 

    @Override 
    public Canvas getCurrentCanvas() { 
     return this.currentCanvas; 
    } 

    @Override 
    public void pause() { 

    } 

    @Override 
    public void resume() { 

    } 

    @Override 
    public void dispose() { 

    } 
} 

AndroidGame.java

package framework.impl; 

import android.app.Activity; 
import android.content.Context; 
import android.content.res.Configuration; 
import android.os.Bundle; 
import android.os.PowerManager; 
import android.os.PowerManager.WakeLock; 
import android.util.Log; 
import android.view.Window; 
import android.view.WindowManager; 
import framework.Audio; 
import framework.Game; 
import framework.Input; 
import framework.Screen; 
import tiny.bomber.Assets; 

public abstract class AndroidGame extends Activity implements Game { 

    FastRenderView renderView; 
    int frameWidth; 
    int frameHeight; 
    Input input; 
    Audio audio; 
    Screen screen; 
    Assets assets; 
    WakeLock wakeLock; 

    @Override 
    public void onCreate(Bundle savedInstaneState) { 
     super.onCreate(savedInstaneState); 

     requestWindowFeature(Window.FEATURE_NO_TITLE); 
     getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN, WindowManager.LayoutParams.FLAG_FULLSCREEN); 

     boolean isLandscape = getResources().getConfiguration().orientation == Configuration.ORIENTATION_LANDSCAPE; 
     frameWidth = isLandscape ? 480 : 320; 
     frameHeight = isLandscape ? 320 : 480; 

     float scaleX = (float) frameWidth/getWindowManager().getDefaultDisplay().getWidth(); 
     float scaleY = (float) frameHeight/getWindowManager().getDefaultDisplay().getHeight(); 

     // Setup Globabl Variables // 
     renderView = new FastRenderView(this); 
     this.assets = new Assets(this.getAssets(), this.getResources()); 
     //input = new Input(); 
     //audio = new Audio(); 
     setContentView(renderView); 

     PowerManager powerManager = (PowerManager) getSystemService(Context.POWER_SERVICE); 
     wakeLock = powerManager.newWakeLock(PowerManager.FULL_WAKE_LOCK, "TinyBmoberGame"); 

     this.screen = this.getStartScreen(); 
    } 

    @Override 
    public void onResume() { 
     super.onResume(); 
     wakeLock.acquire(); 
     screen.resume(); 
     renderView.resume(); 
    } 

    @Override 
    public void onPause() { 
     super.onPause(); 
     wakeLock.release(); 
     renderView.pause(); 
     screen.pause(); 
    } 

    @Override 
    public void setScreen(Screen screen) { 
     this.screen = screen; 
    } 

    @Override 
    public Input getInput() { 
     return this.input; 
    } 

    @Override 
    public Audio getAudio() { 
     return this.audio; 
    } 

    @Override 
    public Screen getScreen() { 
     return this.screen; 
    } 

    @Override 
    public Assets getAssetsClass() { 
     return this.assets; 
    } 

    @Override 
    public FastRenderView getFastRenderView() { 
     return this.renderView; 
    } 

    @Override 
    public int getFrameWidth() { 
     return this.frameWidth; 
    } 

    @Override 
    public int getFrameHeight() { 
     return this.frameHeight; 
    } 

    public WakeLock getWakeLock() { 
     return this.wakeLock; 
    } 
} 

答えて

0

ハードウェアの制限のため、「本物」のフルスクリーンをセットカントそれ。

このメソッドを使用して画像を拡大するためにLoadingScreenが使用されました。

private Bitmap scaleImage(Bitmap picture) { 
     Matrix matrix = new Matrix(); 
     matrix.postScale(this.game.getScaleX(), this.game.getScaleY()); 
     Bitmap resizedPicture = Bitmap.createBitmap(picture, 0, 0, picture.getWidth(), picture.getHeight(), matrix, true); 
     return resizedPicture; 
    } 

ScaleXとScaleYを取得するには、AndroidGameに以下を追加する必要がありました。

@Override 
public float getScaleX() { 
    return this.scaleX; 
} 

@Override 
public float getScaleY() { 
    return this.scaleY; 
} 

Androidゲームでは、次のように変更して正しく調整しました。

boolean isLandscape = getResources().getConfiguration().orientation == Configuration.ORIENTATION_LANDSCAPE; 
     frameWidth = isLandscape ? 480 : 320; // Based on my standard 
     frameHeight = isLandscape ? 320 : 480; 

     scaleX = (float) frameWidth/getWindowManager().getDefaultDisplay().getWidth(); 
     scaleY = (float) frameHeight/getWindowManager().getDefaultDisplay().getHeight(); 
     if(scaleX < 1 || scaleY < 1) { 
      scaleX = (float) getWindowManager().getDefaultDisplay().getWidth()/frameWidth; 
      scaleY = (float) getWindowManager().getDefaultDisplay().getHeight()/frameHeight; 
     } 

最後に、LoadingScreenでは、以下のようにメソッドを変更しました。

@Override 
    public void present(float deltaTime) { 
     Bitmap picture = Bitmap.createBitmap(this.game.getFrameWidth(), this.game.getFrameHeight(), Config.RGB_565); 
     Canvas canvas = new Canvas(picture); 
     Log.i("Canvas", "Canvas Size: " + canvas.getWidth() + ", " + canvas.getHeight()); 
     paint = new Paint(); 
     paint.setColor(Color.RED); 
     Rect darkRed = new Rect((int) (480 * 0.02), (320/2), (int) (((480 - (480 * 0.02))/100) * this.loadingPercent), 50); 
     canvas.drawRect(darkRed, paint); 
     this.currentCanvas = canvas; 
     picture = this.scaleImage(picture); 
     this.currentScreen = picture; 
    } 

すべて正常に動作しています。 :)

1

あなたは

// display width 
int width = getResources().getDisplayMetrics().widthPixels 

// display height 
int height = getResources().getDisplayMetrics().heightPixels 
を使用することができます

か、DisplayMetricsオブジェクトをインスタンス化することができます:BTW

DisplayMetrics dm = new DisplayMetrics(); 
int width = dm.widthPixels; 
int height = dm.heightPixels; 

を:いくつかのデバイス上で、あなたはアンドレアスBfがためにそう+1の質問の一部に答え

+0

制限を検出するにはどうすればよいのですか? – Zeveso

+0

私はそれが不可能だと思います。関数は、開発者が物事を表示するためだけに使用できる画面サイズを返します。 – Andreas