1*90c8c64dSAndroid Build Coastguard Worker /* 2*90c8c64dSAndroid Build Coastguard Worker * Copyright (C) 2015 The Android Open Source Project 3*90c8c64dSAndroid Build Coastguard Worker * 4*90c8c64dSAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License"); 5*90c8c64dSAndroid Build Coastguard Worker * you may not use this file except in compliance with the License. 6*90c8c64dSAndroid Build Coastguard Worker * You may obtain a copy of the License at 7*90c8c64dSAndroid Build Coastguard Worker * 8*90c8c64dSAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0 9*90c8c64dSAndroid Build Coastguard Worker * 10*90c8c64dSAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software 11*90c8c64dSAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS, 12*90c8c64dSAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13*90c8c64dSAndroid Build Coastguard Worker * See the License for the specific language governing permissions and 14*90c8c64dSAndroid Build Coastguard Worker * limitations under the License. 15*90c8c64dSAndroid Build Coastguard Worker */ 16*90c8c64dSAndroid Build Coastguard Worker 17*90c8c64dSAndroid Build Coastguard Worker package com.example.android.midiscope; 18*90c8c64dSAndroid Build Coastguard Worker 19*90c8c64dSAndroid Build Coastguard Worker import android.media.midi.MidiDeviceService; 20*90c8c64dSAndroid Build Coastguard Worker import android.media.midi.MidiDeviceStatus; 21*90c8c64dSAndroid Build Coastguard Worker import android.media.midi.MidiReceiver; 22*90c8c64dSAndroid Build Coastguard Worker 23*90c8c64dSAndroid Build Coastguard Worker import com.example.android.common.midi.MidiFramer; 24*90c8c64dSAndroid Build Coastguard Worker 25*90c8c64dSAndroid Build Coastguard Worker import java.io.IOException; 26*90c8c64dSAndroid Build Coastguard Worker 27*90c8c64dSAndroid Build Coastguard Worker /** 28*90c8c64dSAndroid Build Coastguard Worker * Virtual MIDI Device that logs messages to a ScopeLogger. 29*90c8c64dSAndroid Build Coastguard Worker */ 30*90c8c64dSAndroid Build Coastguard Worker 31*90c8c64dSAndroid Build Coastguard Worker public class MidiScope extends MidiDeviceService { 32*90c8c64dSAndroid Build Coastguard Worker 33*90c8c64dSAndroid Build Coastguard Worker private static ScopeLogger mScopeLogger; 34*90c8c64dSAndroid Build Coastguard Worker private MidiReceiver mInputReceiver = new MyReceiver(); 35*90c8c64dSAndroid Build Coastguard Worker private static MidiFramer mDeviceFramer; 36*90c8c64dSAndroid Build Coastguard Worker 37*90c8c64dSAndroid Build Coastguard Worker @Override onGetInputPortReceivers()38*90c8c64dSAndroid Build Coastguard Worker public MidiReceiver[] onGetInputPortReceivers() { 39*90c8c64dSAndroid Build Coastguard Worker return new MidiReceiver[] { mInputReceiver }; 40*90c8c64dSAndroid Build Coastguard Worker } 41*90c8c64dSAndroid Build Coastguard Worker getScopeLogger()42*90c8c64dSAndroid Build Coastguard Worker public static ScopeLogger getScopeLogger() { 43*90c8c64dSAndroid Build Coastguard Worker return mScopeLogger; 44*90c8c64dSAndroid Build Coastguard Worker } 45*90c8c64dSAndroid Build Coastguard Worker setScopeLogger(ScopeLogger logger)46*90c8c64dSAndroid Build Coastguard Worker public static void setScopeLogger(ScopeLogger logger) { 47*90c8c64dSAndroid Build Coastguard Worker if (logger != null) { 48*90c8c64dSAndroid Build Coastguard Worker // Receiver that prints the messages. 49*90c8c64dSAndroid Build Coastguard Worker LoggingReceiver loggingReceiver = new LoggingReceiver(logger); 50*90c8c64dSAndroid Build Coastguard Worker mDeviceFramer = new MidiFramer(loggingReceiver); 51*90c8c64dSAndroid Build Coastguard Worker } 52*90c8c64dSAndroid Build Coastguard Worker mScopeLogger = logger; 53*90c8c64dSAndroid Build Coastguard Worker } 54*90c8c64dSAndroid Build Coastguard Worker 55*90c8c64dSAndroid Build Coastguard Worker private static class MyReceiver extends MidiReceiver { 56*90c8c64dSAndroid Build Coastguard Worker @Override onSend(byte[] data, int offset, int count, long timestamp)57*90c8c64dSAndroid Build Coastguard Worker public void onSend(byte[] data, int offset, int count, 58*90c8c64dSAndroid Build Coastguard Worker long timestamp) throws IOException { 59*90c8c64dSAndroid Build Coastguard Worker if (mScopeLogger != null) { 60*90c8c64dSAndroid Build Coastguard Worker // Send raw data to be parsed into discrete messages. 61*90c8c64dSAndroid Build Coastguard Worker mDeviceFramer.send(data, offset, count, timestamp); 62*90c8c64dSAndroid Build Coastguard Worker } 63*90c8c64dSAndroid Build Coastguard Worker } 64*90c8c64dSAndroid Build Coastguard Worker } 65*90c8c64dSAndroid Build Coastguard Worker 66*90c8c64dSAndroid Build Coastguard Worker /** 67*90c8c64dSAndroid Build Coastguard Worker * This will get called when clients connect or disconnect. 68*90c8c64dSAndroid Build Coastguard Worker * Log device information. 69*90c8c64dSAndroid Build Coastguard Worker */ 70*90c8c64dSAndroid Build Coastguard Worker @Override onDeviceStatusChanged(MidiDeviceStatus status)71*90c8c64dSAndroid Build Coastguard Worker public void onDeviceStatusChanged(MidiDeviceStatus status) { 72*90c8c64dSAndroid Build Coastguard Worker if (mScopeLogger != null) { 73*90c8c64dSAndroid Build Coastguard Worker if (status.isInputPortOpen(0)) { 74*90c8c64dSAndroid Build Coastguard Worker mScopeLogger.log("=== connected ==="); 75*90c8c64dSAndroid Build Coastguard Worker String text = MidiPrinter.formatDeviceInfo( 76*90c8c64dSAndroid Build Coastguard Worker status.getDeviceInfo()); 77*90c8c64dSAndroid Build Coastguard Worker mScopeLogger.log(text); 78*90c8c64dSAndroid Build Coastguard Worker } else { 79*90c8c64dSAndroid Build Coastguard Worker mScopeLogger.log("--- disconnected ---"); 80*90c8c64dSAndroid Build Coastguard Worker } 81*90c8c64dSAndroid Build Coastguard Worker } 82*90c8c64dSAndroid Build Coastguard Worker } 83*90c8c64dSAndroid Build Coastguard Worker } 84