Home | History | Annotate | Download | only in walt
      1 /*
      2  * Copyright (C) 2016 The Android Open Source Project
      3  *
      4  * Licensed under the Apache License, Version 2.0 (the "License");
      5  * you may not use this file except in compliance with the License.
      6  * You may obtain a copy of the License at
      7  *
      8  *      http://www.apache.org/licenses/LICENSE-2.0
      9  *
     10  * Unless required by applicable law or agreed to in writing, software
     11  * distributed under the License is distributed on an "AS IS" BASIS,
     12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
     13  * See the License for the specific language governing permissions and
     14  * limitations under the License.
     15  */
     16 
     17 package org.chromium.latency.walt;
     18 
     19 import android.content.BroadcastReceiver;
     20 import android.content.Context;
     21 import android.content.Intent;
     22 import android.os.Bundle;
     23 import android.support.v4.app.Fragment;
     24 import android.text.method.ScrollingMovementMethod;
     25 import android.view.LayoutInflater;
     26 import android.view.View;
     27 import android.view.ViewGroup;
     28 import android.widget.TextView;
     29 
     30 import java.util.Locale;
     31 
     32 public class MidiFragment extends Fragment
     33         implements View.OnClickListener, BaseTest.TestStateListener {
     34 
     35     private SimpleLogger logger;
     36     private TextView textView;
     37     private View startMidiInButton;
     38     private View startMidiOutButton;
     39     private HistogramChart latencyChart;
     40     private MidiTest midiTest;
     41 
     42     public MidiFragment() {
     43         // Required empty public constructor
     44     }
     45 
     46     @Override
     47     public View onCreateView(LayoutInflater inflater, ViewGroup container,
     48                              Bundle savedInstanceState) {
     49         logger = SimpleLogger.getInstance(getContext());
     50         midiTest = new MidiTest(getActivity());
     51         midiTest.setTestStateListener(this);
     52 
     53         final View view = inflater.inflate(R.layout.fragment_midi, container, false);
     54         textView = (TextView) view.findViewById(R.id.txt_box_midi);
     55         startMidiInButton = view.findViewById(R.id.button_start_midi_in);
     56         startMidiOutButton = view.findViewById(R.id.button_start_midi_out);
     57         latencyChart = (HistogramChart) view.findViewById(R.id.latency_chart);
     58         textView.setMovementMethod(new ScrollingMovementMethod());
     59         return view;
     60     }
     61 
     62     @Override
     63     public void onResume() {
     64         super.onResume();
     65 
     66         // Register this fragment class as the listener for some button clicks
     67         startMidiInButton.setOnClickListener(this);
     68         startMidiOutButton.setOnClickListener(this);
     69 
     70         textView.setText(logger.getLogText());
     71         logger.registerReceiver(logReceiver);
     72     }
     73 
     74     @Override
     75     public void onPause() {
     76         logger.unregisterReceiver(logReceiver);
     77         super.onPause();
     78     }
     79 
     80     @Override
     81     public void onClick(View v) {
     82         switch (v.getId()) {
     83             case R.id.button_start_midi_in:
     84                 disableButtons();
     85                 latencyChart.setVisibility(View.VISIBLE);
     86                 latencyChart.clearData();
     87                 latencyChart.setLegendEnabled(false);
     88                 latencyChart.getBarChart().getDescription().setText("MIDI Input Latency [ms]");
     89                 midiTest.testMidiIn();
     90                 break;
     91             case R.id.button_start_midi_out:
     92                 disableButtons();
     93                 latencyChart.setVisibility(View.VISIBLE);
     94                 latencyChart.clearData();
     95                 latencyChart.setLegendEnabled(false);
     96                 latencyChart.getBarChart().getDescription().setText("MIDI Output Latency [ms]");
     97                 midiTest.testMidiOut();
     98                 break;
     99         }
    100     }
    101 
    102     private void disableButtons() {
    103         startMidiInButton.setEnabled(false);
    104         startMidiOutButton.setEnabled(false);
    105     }
    106 
    107     private BroadcastReceiver logReceiver = new BroadcastReceiver() {
    108         @Override
    109         public void onReceive(Context context, Intent intent) {
    110             String msg = intent.getStringExtra("message");
    111             textView.append(msg + "\n");
    112         }
    113     };
    114 
    115     @Override
    116     public void onTestStopped() {
    117         if (!midiTest.deltasOutputTotal.isEmpty()) {
    118             latencyChart.setLegendEnabled(true);
    119             latencyChart.setLabel(String.format(
    120                     Locale.US, "Median=%.1f ms", Utils.median(midiTest.deltasOutputTotal)));
    121         } else if (!midiTest.deltasInputTotal.isEmpty()) {
    122             latencyChart.setLegendEnabled(true);
    123             latencyChart.setLabel(String.format(
    124                     Locale.US, "Median=%.1f ms", Utils.median(midiTest.deltasInputTotal)));
    125         }
    126         LogUploader.uploadIfAutoEnabled(getContext());
    127         startMidiInButton.setEnabled(true);
    128         startMidiOutButton.setEnabled(true);
    129     }
    130 
    131     @Override
    132     public void onTestStoppedWithError() {
    133         onTestStopped();
    134         latencyChart.setVisibility(View.GONE);
    135     }
    136 
    137     @Override
    138     public void onTestPartialResult(double value) {
    139         latencyChart.addEntry(value);
    140     }
    141 
    142     public static boolean hasMidi(Context context) {
    143         return context.getPackageManager().
    144                 hasSystemFeature("android.software.midi");
    145     }
    146 }
    147