Users can add this app profiler in the MainActivity to show the application timings within the Android systrace utility.experimental
parent
3a82c9eca1
commit
31bc6bf526
@ -0,0 +1,167 @@ |
|||||||
|
/* |
||||||
|
* Copyright (c) 2014 jMonkeyEngine |
||||||
|
* All rights reserved. |
||||||
|
* |
||||||
|
* Redistribution and use in source and binary forms, with or without |
||||||
|
* modification, are permitted provided that the following conditions are |
||||||
|
* met: |
||||||
|
* |
||||||
|
* * Redistributions of source code must retain the above copyright |
||||||
|
* notice, this list of conditions and the following disclaimer. |
||||||
|
* |
||||||
|
* * Redistributions in binary form must reproduce the above copyright |
||||||
|
* notice, this list of conditions and the following disclaimer in the |
||||||
|
* documentation and/or other materials provided with the distribution. |
||||||
|
* |
||||||
|
* * Neither the name of 'jMonkeyEngine' nor the names of its contributors |
||||||
|
* may be used to endorse or promote products derived from this software |
||||||
|
* without specific prior written permission. |
||||||
|
* |
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
||||||
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED |
||||||
|
* TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR |
||||||
|
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR |
||||||
|
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, |
||||||
|
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, |
||||||
|
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR |
||||||
|
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF |
||||||
|
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING |
||||||
|
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS |
||||||
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
||||||
|
*/ |
||||||
|
|
||||||
|
package com.jme3.app; |
||||||
|
|
||||||
|
import android.os.Build; |
||||||
|
import com.jme3.profile.AppProfiler; |
||||||
|
import com.jme3.profile.AppStep; |
||||||
|
import static com.jme3.profile.AppStep.BeginFrame; |
||||||
|
import static com.jme3.profile.AppStep.EndFrame; |
||||||
|
import static com.jme3.profile.AppStep.ProcessAudio; |
||||||
|
import static com.jme3.profile.AppStep.ProcessInput; |
||||||
|
import static com.jme3.profile.AppStep.QueuedTasks; |
||||||
|
import static com.jme3.profile.AppStep.RenderFrame; |
||||||
|
import static com.jme3.profile.AppStep.RenderMainViewPorts; |
||||||
|
import static com.jme3.profile.AppStep.RenderPostViewPorts; |
||||||
|
import static com.jme3.profile.AppStep.RenderPreviewViewPorts; |
||||||
|
import static com.jme3.profile.AppStep.SpatialUpdate; |
||||||
|
import static com.jme3.profile.AppStep.StateManagerRender; |
||||||
|
import static com.jme3.profile.AppStep.StateManagerUpdate; |
||||||
|
import com.jme3.profile.VpStep; |
||||||
|
import static com.jme3.profile.VpStep.BeginRender; |
||||||
|
import static com.jme3.profile.VpStep.EndRender; |
||||||
|
import static com.jme3.profile.VpStep.FlushQueue; |
||||||
|
import static com.jme3.profile.VpStep.PostFrame; |
||||||
|
import static com.jme3.profile.VpStep.PostQueue; |
||||||
|
import static com.jme3.profile.VpStep.RenderScene; |
||||||
|
import com.jme3.renderer.ViewPort; |
||||||
|
import com.jme3.renderer.queue.RenderQueue; |
||||||
|
|
||||||
|
/** |
||||||
|
* An AppProfiler implementation that integrates the |
||||||
|
* per-frame application-wide timings for update versus |
||||||
|
* render into the Android systrace utility. |
||||||
|
* |
||||||
|
* <p>This profiler uses the Android Trace class which is only supported |
||||||
|
* on Android SDK rev 18 and higher (ver 4.3 and higher). If the |
||||||
|
* device is running a version < rev 18, the logging will |
||||||
|
* be skipped.</p> |
||||||
|
* |
||||||
|
* <p>In the MainActivity class, add the following:</p> |
||||||
|
* <pre><code> |
||||||
|
* {@literal @}Override |
||||||
|
* public void onCreate(Bundle savedInstanceState) { |
||||||
|
* super.onCreate(savedInstanceState); |
||||||
|
* app.setAppProfiler(new DefaultAndroidProfiler()); |
||||||
|
* } |
||||||
|
* </code></pre> |
||||||
|
* Start the Android systrace utility and run the application to |
||||||
|
* see the detailed timings of the application. |
||||||
|
* |
||||||
|
* @author iwgeric |
||||||
|
*/ |
||||||
|
public class DefaultAndroidProfiler implements AppProfiler { |
||||||
|
private int androidApiLevel = Build.VERSION.SDK_INT; |
||||||
|
|
||||||
|
public void appStep(AppStep appStep) { |
||||||
|
if (androidApiLevel >= 18) { |
||||||
|
switch(appStep) { |
||||||
|
case BeginFrame: |
||||||
|
android.os.Trace.beginSection("Frame"); |
||||||
|
break; |
||||||
|
case QueuedTasks: |
||||||
|
android.os.Trace.beginSection("QueuedTask"); |
||||||
|
break; |
||||||
|
case ProcessInput: |
||||||
|
android.os.Trace.endSection(); |
||||||
|
android.os.Trace.beginSection("ProcessInput"); |
||||||
|
break; |
||||||
|
case ProcessAudio: |
||||||
|
android.os.Trace.endSection(); |
||||||
|
android.os.Trace.beginSection("ProcessAudio"); |
||||||
|
break; |
||||||
|
case StateManagerUpdate: |
||||||
|
android.os.Trace.endSection(); |
||||||
|
android.os.Trace.beginSection("StateManagerUpdate"); |
||||||
|
break; |
||||||
|
case SpatialUpdate: |
||||||
|
android.os.Trace.endSection(); |
||||||
|
android.os.Trace.beginSection("SpatialUpdate"); |
||||||
|
break; |
||||||
|
case StateManagerRender: |
||||||
|
android.os.Trace.endSection(); |
||||||
|
android.os.Trace.beginSection("StateManagerRender"); |
||||||
|
break; |
||||||
|
case RenderFrame: |
||||||
|
android.os.Trace.endSection(); |
||||||
|
android.os.Trace.beginSection("RenderFrame"); |
||||||
|
break; |
||||||
|
case RenderPreviewViewPorts: |
||||||
|
android.os.Trace.beginSection("RenderPreviewViewPorts"); |
||||||
|
break; |
||||||
|
case RenderMainViewPorts: |
||||||
|
android.os.Trace.endSection(); |
||||||
|
android.os.Trace.beginSection("RenderMainViewPorts"); |
||||||
|
break; |
||||||
|
case RenderPostViewPorts: |
||||||
|
android.os.Trace.endSection(); |
||||||
|
android.os.Trace.beginSection("RenderPostViewPorts"); |
||||||
|
break; |
||||||
|
case EndFrame: |
||||||
|
android.os.Trace.endSection(); |
||||||
|
android.os.Trace.endSection(); |
||||||
|
android.os.Trace.endSection(); |
||||||
|
break; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
public void vpStep(VpStep vpStep, ViewPort vp, RenderQueue.Bucket bucket) { |
||||||
|
if (androidApiLevel >= 18) { |
||||||
|
switch (vpStep) { |
||||||
|
case BeginRender: |
||||||
|
android.os.Trace.beginSection("Render: " + vp.getName()); |
||||||
|
break; |
||||||
|
case RenderScene: |
||||||
|
android.os.Trace.beginSection("RenderScene: " + vp.getName()); |
||||||
|
break; |
||||||
|
case PostQueue: |
||||||
|
android.os.Trace.endSection(); |
||||||
|
android.os.Trace.beginSection("PostQueue: " + vp.getName()); |
||||||
|
break; |
||||||
|
case FlushQueue: |
||||||
|
android.os.Trace.endSection(); |
||||||
|
android.os.Trace.beginSection("FlushQueue: " + vp.getName()); |
||||||
|
break; |
||||||
|
case PostFrame: |
||||||
|
android.os.Trace.endSection(); |
||||||
|
android.os.Trace.beginSection("PostFrame: " + vp.getName()); |
||||||
|
break; |
||||||
|
case EndRender: |
||||||
|
android.os.Trace.endSection(); |
||||||
|
android.os.Trace.endSection(); |
||||||
|
break; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
} |
Loading…
Reference in new issue