Vous êtes sur la page 1sur 2

/*

* Copyright (C) 2015 The Android Open Source Project


*

* Licensed under the Apache License, Version 2.0 (the "License");

* you may not use this file except in compliance with the License.

* You may obtain a copy of the License at


*

* http://www.apache.org/licenses/LICENSE-2.0
*

* Unless required by applicable law or agreed to in writing, software

* distributed under the License is distributed on an "AS IS" BASIS,

* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.

* See the License for the specific language governing permissions and

* limitations under the License.

*/

package com.example.android.midiscope;

import android.media.midi.MidiDeviceService;

import android.media.midi.MidiDeviceStatus;

import android.media.midi.MidiReceiver;

import com.example.android.common.midi.MidiFramer;

import java.io.IOException;

/**

* Virtual MIDI Device that logs messages to a ScopeLogger.

*/

public class MidiScope extends MidiDeviceService {

private static ScopeLogger mScopeLogger;


private MidiReceiver mInputReceiver = new MyReceiver();

private static MidiFramer mDeviceFramer;

@Override
public MidiReceiver[] onGetInputPortReceivers() {
return new MidiReceiver[] { mInputReceiver };
}
public static ScopeLogger getScopeLogger() {
return mScopeLogger;
}

public static void setScopeLogger(ScopeLogger logger) {


if (logger != null) {
// Receiver that prints the messages.
LoggingReceiver loggingReceiver = new LoggingReceiver(logger);
mDeviceFramer = new MidiFramer(loggingReceiver);
}
mScopeLogger = logger;
}

private static class MyReceiver extends MidiReceiver {


@Override
public void onSend(byte[] data, int offset, int count,
long timestamp) throws IOException {
if (mScopeLogger != null) {
// Send raw data to be parsed into discrete messages.
mDeviceFramer.send(data, offset, count, timestamp);
}
}
}

/**
* This will get called when clients connect or disconnect.
* Log device information.
*/
@Override

public void onDeviceStatusChanged(MidiDeviceStatus status) {


if (mScopeLogger != null) {
if (status.isInputPortOpen(0)) {
mScopeLogger.log("=== connected ===");
String text = MidiPrinter.formatDeviceInfo(
status.getDeviceInfo());
mScopeLogger.log(text);
} else {
mScopeLogger.log("--- disconnected ---");
}
}
}
}

Vous aimerez peut-être aussi