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