亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 系統 > Android > 正文

Android測量每秒幀數Frames Per Second (FPS)的方法

2020-04-11 11:24:07
字體:
來源:轉載
供稿:網友

本文實例講述了Android測量每秒幀數Frames Per Second (FPS)的方法。分享給大家供大家參考。具體如下:

MainThread.java:

package net.obviam.droidz;import java.text.DecimalFormat;import android.graphics.Canvas;import android.util.Log;import android.view.SurfaceHolder;/** * @author impaler * * The Main thread which contains the game loop. The thread must have access to * the surface view and holder to trigger events every game tick. */public class MainThread extends Thread { private static final String TAG = MainThread.class.getSimpleName(); // desired fps private final static int MAX_FPS = 50; // maximum number of frames to be skipped private final static int MAX_FRAME_SKIPS = 5; // the frame period private final static int FRAME_PERIOD = 1000 / MAX_FPS; // Stuff for stats */ private DecimalFormat df = new DecimalFormat("0.##"); // 2 dp // we'll be reading the stats every second private final static int STAT_INTERVAL = 1000; //ms // the average will be calculated by storing // the last n FPSs private final static int FPS_HISTORY_NR = 10; // last time the status was stored private long lastStatusStore = 0; // the status time counter private long statusIntervalTimer = 0l; // number of frames skipped since the game started private long totalFramesSkipped   = 0l; // number of frames skipped in a store cycle (1 sec) private long framesSkippedPerStatCycle = 0l; // number of rendered frames in an interval private int frameCountPerStatCycle = 0; private long totalFrameCount = 0l; // the last FPS values private double fpsStore[]; // the number of times the stat has been read private long statsCount = 0; // the average FPS since the game started private double averageFps = 0.0; // Surface holder that can access the physical surface private SurfaceHolder surfaceHolder; // The actual view that handles inputs // and draws to the surface private MainGamePanel gamePanel; // flag to hold game state private boolean running; public void setRunning(boolean running) {  this.running = running; } public MainThread(SurfaceHolder surfaceHolder, MainGamePanel gamePanel) {  super();  this.surfaceHolder = surfaceHolder;  this.gamePanel = gamePanel; } @Override public void run() {  Canvas canvas;  Log.d(TAG, "Starting game loop");  // initialise timing elements for stat gathering  initTimingElements();  long beginTime;  // the time when the cycle begun  long timeDiff;  // the time it took for the cycle to execute  int sleepTime;  // ms to sleep (<0 if we're behind)  int framesSkipped; // number of frames being skipped   sleepTime = 0;  while (running) {   canvas = null;   // try locking the canvas for exclusive pixel editing   // in the surface   try {    canvas = this.surfaceHolder.lockCanvas();    synchronized (surfaceHolder) {     beginTime = System.currentTimeMillis();     framesSkipped = 0; // resetting the frames skipped     // update game state     this.gamePanel.update();     // render state to the screen     // draws the canvas on the panel     this.gamePanel.render(canvas);     // calculate how long did the cycle take     timeDiff = System.currentTimeMillis() - beginTime;     // calculate sleep time     sleepTime = (int)(FRAME_PERIOD - timeDiff);     if (sleepTime > 0) {      // if sleepTime > 0 we're OK      try {       // send the thread to sleep for a short period       // very useful for battery saving       Thread.sleep(sleepTime);      } catch (InterruptedException e) {}     }     while (sleepTime < 0 && framesSkipped < MAX_FRAME_SKIPS) {      // we need to catch up      this.gamePanel.update(); // update without rendering      sleepTime += FRAME_PERIOD; // add frame period to check if in next frame      framesSkipped++;     }     if (framesSkipped > 0) {      Log.d(TAG, "Skipped:" + framesSkipped);     }     // for statistics     framesSkippedPerStatCycle += framesSkipped;     // calling the routine to store the gathered statistics     storeStats();    }   } finally {    // in case of an exception the surface is not left in    // an inconsistent state    if (canvas != null) {     surfaceHolder.unlockCanvasAndPost(canvas);    }   } // end finally  } } /**  * The statistics - it is called every cycle, it checks if time since last  * store is greater than the statistics gathering period (1 sec) and if so  * it calculates the FPS for the last period and stores it.  *  * It tracks the number of frames per period. The number of frames since  * the start of the period are summed up and the calculation takes part  * only if the next period and the frame count is reset to 0.  */ private void storeStats() {  frameCountPerStatCycle++;  totalFrameCount++;  // check the actual time  statusIntervalTimer += (System.currentTimeMillis() - statusIntervalTimer);  if (statusIntervalTimer >= lastStatusStore + STAT_INTERVAL) {   // calculate the actual frames pers status check interval   double actualFps = (double)(frameCountPerStatCycle / (STAT_INTERVAL / 1000));   //stores the latest fps in the array   fpsStore[(int) statsCount % FPS_HISTORY_NR] = actualFps;   // increase the number of times statistics was calculated   statsCount++;   double totalFps = 0.0;   // sum up the stored fps values   for (int i = 0; i < FPS_HISTORY_NR; i++) {    totalFps += fpsStore[i];   }   // obtain the average   if (statsCount < FPS_HISTORY_NR) {    // in case of the first 10 triggers    averageFps = totalFps / statsCount;   } else {    averageFps = totalFps / FPS_HISTORY_NR;   }   // saving the number of total frames skipped   totalFramesSkipped += framesSkippedPerStatCycle;   // resetting the counters after a status record (1 sec)   framesSkippedPerStatCycle = 0;   statusIntervalTimer = 0;   frameCountPerStatCycle = 0;   statusIntervalTimer = System.currentTimeMillis();   lastStatusStore = statusIntervalTimer;//   Log.d(TAG, "Average FPS:" + df.format(averageFps));   gamePanel.setAvgFps("FPS: " + df.format(averageFps));  } } private void initTimingElements() {  // initialise timing elements  fpsStore = new double[FPS_HISTORY_NR];  for (int i = 0; i < FPS_HISTORY_NR; i++) {   fpsStore[i] = 0.0;  }  Log.d(TAG + ".initTimingElements()", "Timing elements for stats initialised"); }}

希望本文所述對大家的java程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美激情一二区| 92看片淫黄大片欧美看国产片| 亚洲国模精品一区| 日韩av电影手机在线| 久久久av网站| 亚洲精品久久久久久久久| 日韩有码视频在线| 韩国精品美女www爽爽爽视频| 热99精品只有里视频精品| 亚洲第一精品福利| 欧美国产日本高清在线| 亚洲精品久久久久久久久久久| 欧美有码在线视频| 69国产精品成人在线播放| 尤物yw午夜国产精品视频明星| www日韩中文字幕在线看| 国产亚洲精品久久久久久牛牛| 国产精品视频精品视频| 久久国产精品影片| 国产一区二区三区三区在线观看| 欧美一区二区三区免费视| 国产精品99久久久久久久久久久久| 欧美在线视频在线播放完整版免费观看| 91精品国产一区| 欧美电影免费在线观看| 久久网福利资源网站| 久久久久久久久亚洲| 国产伦精品一区二区三区精品视频| 中文字幕成人精品久久不卡| 欧美激情国产精品| 欧美日韩第一视频| 欧美黑人又粗大| 视频在线一区二区| 亚洲精品免费网站| www.午夜精品| 91国产美女在线观看| 中文字幕欧美精品日韩中文字幕| 国产成人精品a视频一区www| 久久亚洲国产精品| 欧美激情精品久久久久久大尺度| 亚洲三级黄色在线观看| 亚洲欧美国产精品va在线观看| 亚洲精品欧美一区二区三区| 日本免费一区二区三区视频观看| 亚洲奶大毛多的老太婆| 亚洲欧美激情精品一区二区| 欧美在线视频免费观看| 日韩av一卡二卡| 亚洲热线99精品视频| 亚洲精品国产综合久久| 国产主播在线一区| 国产精品视频男人的天堂| 成人激情视频小说免费下载| 91av在线免费观看视频| 欧美性猛交xxxxx免费看| 日韩在线观看网址| 久久亚洲精品一区二区| 欧美在线视频免费观看| 日韩精品在线视频| 色先锋资源久久综合5566| 精品国产老师黑色丝袜高跟鞋| 亚洲免费电影一区| 精品丝袜一区二区三区| 一区二区三区天堂av| 3344国产精品免费看| …久久精品99久久香蕉国产| 一本色道久久88综合亚洲精品ⅰ| 高清欧美性猛交xxxx黑人猛交| 久久天天躁夜夜躁狠狠躁2022| 久久这里只有精品99| 成人97在线观看视频| 亚洲免费伊人电影在线观看av| 亚洲国产精品专区久久| 欧美视频中文字幕在线| 精品亚洲国产成av人片传媒| 中文字幕日韩有码| 亚洲女人天堂网| 欧美日韩一区二区免费视频| 精品亚洲一区二区三区| 在线不卡国产精品| 日本亚洲欧美三级| 亚洲天堂第一页| 国产精品海角社区在线观看| 欧美日韩精品在线观看| 最近中文字幕mv在线一区二区三区四区| 久久91精品国产91久久跳| 久热精品视频在线| 国产成人福利视频| 国语自产精品视频在线看抢先版图片| 在线视频国产日韩| 91精品国产91久久久久福利| 亚洲国产精品嫩草影院久久| 国产精品女人久久久久久| 久久精品国产视频| 久久视频免费在线播放| 91免费版网站入口| 国产丝袜一区视频在线观看| 久久久久久久久久久成人| 欧美在线免费观看| 欧美最猛性xxxxx(亚洲精品)| 亚洲欧美综合精品久久成人| 国产精品777| 欧洲成人免费aa| 日韩精品视频在线免费观看| 欧美成人激情在线| 欧美猛交ⅹxxx乱大交视频| 日韩亚洲精品视频| 久久精视频免费在线久久完整在线看| 九九热最新视频//这里只有精品| 国内精品久久久久| 久久久这里只有精品视频| 一色桃子一区二区| 成人h片在线播放免费网站| 日韩在线观看成人| 久久精品国产96久久久香蕉| 日韩www在线| 日韩av综合网站| 亚洲人成电影网| 国产中文欧美精品| 亚洲电影免费观看高清完整版在线| 日韩av中文字幕在线播放| 国产精品一区二区三区久久| 欧美成人免费va影院高清| 欧美日韩在线观看视频小说| 久久久噜噜噜久久久| 91精品国产高清久久久久久久久| 欧美日韩在线视频一区| 秋霞午夜一区二区| 日韩成人在线视频| 91九色国产视频| 亚洲美女又黄又爽在线观看| yellow中文字幕久久| 日韩美女毛茸茸| 91精品国产91久久久久久最新| 国产综合在线观看视频| 中文字幕一区电影| 日韩av片免费在线观看| 91精品国产高清久久久久久91| 亚洲国产高潮在线观看| 欧美视频一区二区三区…| 国产婷婷色综合av蜜臀av| 国产精品入口免费视| 亚洲成人网在线| 日韩中文综合网| 国产午夜精品视频| 亚洲男人天堂视频| 日韩电影中文字幕在线观看| 日韩精品在线视频美女| 日韩精品视频在线播放| 国产精品扒开腿做| 久久夜精品va视频免费观看| 国产中文字幕日韩| 91网在线免费观看| 欧美超级乱淫片喷水| 北条麻妃99精品青青久久| 国产欧美日韩中文字幕| 国产精品露脸自拍| 国产精品成av人在线视午夜片| 久久久久这里只有精品| 亚洲精品一区中文| 在线播放国产一区中文字幕剧情欧美| 国产91九色视频| 欧日韩不卡在线视频| 欧美有码在线观看视频|