jdk/src/java.desktop/share/classes/com/sun/media/sound/ModelStandardIndexedDirector.java
author serb
Mon, 15 Aug 2016 20:08:55 +0300
changeset 40444 afabcfc2f3ef
parent 25859 3317bb8137f4
permissions -rw-r--r--
8163949: Cleanup of classes which are related to JavaSound Reviewed-by: prr
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
6502
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
     1
/*
18215
b2afd66ce6db 8006328: Improve robustness of sound classes
serb
parents: 6503
diff changeset
     2
 * Copyright (c) 2010, 2013, Oracle and/or its affiliates. All rights reserved.
6502
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
     4
 *
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
     7
 * published by the Free Software Foundation.  Oracle designates this
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
     8
 * particular file as subject to the "Classpath" exception as provided
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
     9
 * by Oracle in the LICENSE file that accompanied this code.
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    10
 *
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    11
 * This code is distributed in the hope that it will be useful, but WITHOUT
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    12
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    13
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    14
 * version 2 for more details (a copy is included in the LICENSE file that
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    15
 * accompanied this code).
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    16
 *
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    17
 * You should have received a copy of the GNU General Public License version
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    18
 * 2 along with this work; if not, write to the Free Software Foundation,
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    19
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    20
 *
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    21
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    22
 * or visit www.oracle.com if you need additional information or have any
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    23
 * questions.
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    24
 */
40444
afabcfc2f3ef 8163949: Cleanup of classes which are related to JavaSound
serb
parents: 25859
diff changeset
    25
6502
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    26
package com.sun.media.sound;
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    27
19369
1b53b14758ee 8005980: [findbugs] More com.sun.media.sound.* warnings
serb
parents: 18215
diff changeset
    28
import java.util.Arrays;
1b53b14758ee 8005980: [findbugs] More com.sun.media.sound.* warnings
serb
parents: 18215
diff changeset
    29
6502
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    30
/**
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    31
 * A standard indexed director who chooses performers
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    32
 * by there keyfrom,keyto,velfrom,velto properties.
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    33
 *
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    34
 * @author Karl Helgason
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    35
 */
18215
b2afd66ce6db 8006328: Improve robustness of sound classes
serb
parents: 6503
diff changeset
    36
public final class ModelStandardIndexedDirector implements ModelDirector {
6502
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    37
19369
1b53b14758ee 8005980: [findbugs] More com.sun.media.sound.* warnings
serb
parents: 18215
diff changeset
    38
    private final ModelPerformer[] performers;
1b53b14758ee 8005980: [findbugs] More com.sun.media.sound.* warnings
serb
parents: 18215
diff changeset
    39
    private final ModelDirectedPlayer player;
1b53b14758ee 8005980: [findbugs] More com.sun.media.sound.* warnings
serb
parents: 18215
diff changeset
    40
    private boolean noteOnUsed = false;
1b53b14758ee 8005980: [findbugs] More com.sun.media.sound.* warnings
serb
parents: 18215
diff changeset
    41
    private boolean noteOffUsed = false;
6502
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    42
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    43
    // Variables needed for index
19369
1b53b14758ee 8005980: [findbugs] More com.sun.media.sound.* warnings
serb
parents: 18215
diff changeset
    44
    private byte[][] trantables;
1b53b14758ee 8005980: [findbugs] More com.sun.media.sound.* warnings
serb
parents: 18215
diff changeset
    45
    private int[] counters;
1b53b14758ee 8005980: [findbugs] More com.sun.media.sound.* warnings
serb
parents: 18215
diff changeset
    46
    private int[][] mat;
6502
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    47
19369
1b53b14758ee 8005980: [findbugs] More com.sun.media.sound.* warnings
serb
parents: 18215
diff changeset
    48
    public ModelStandardIndexedDirector(final ModelPerformer[] performers,
1b53b14758ee 8005980: [findbugs] More com.sun.media.sound.* warnings
serb
parents: 18215
diff changeset
    49
                                        final ModelDirectedPlayer player) {
1b53b14758ee 8005980: [findbugs] More com.sun.media.sound.* warnings
serb
parents: 18215
diff changeset
    50
        this.performers = Arrays.copyOf(performers, performers.length);
6502
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    51
        this.player = player;
19369
1b53b14758ee 8005980: [findbugs] More com.sun.media.sound.* warnings
serb
parents: 18215
diff changeset
    52
        for (final ModelPerformer p : this.performers) {
6502
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    53
            if (p.isReleaseTriggered()) {
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    54
                noteOffUsed = true;
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    55
            } else {
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    56
                noteOnUsed = true;
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    57
            }
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    58
        }
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    59
        buildindex();
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    60
    }
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    61
6503
600ab3437bb8 6943053: Gervill: failures on invalid ranges and 14-bit banks
kalli
parents: 6502
diff changeset
    62
    private int[] lookupIndex(int x, int y) {
6502
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    63
        if ((x >= 0) && (x < 128) && (y >= 0) && (y < 128)) {
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    64
            int xt = trantables[0][x];
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    65
            int yt = trantables[1][y];
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    66
            if (xt != -1 && yt != -1) {
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    67
                return mat[xt + yt * counters[0]];
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    68
            }
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    69
        }
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    70
        return null;
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    71
    }
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    72
6503
600ab3437bb8 6943053: Gervill: failures on invalid ranges and 14-bit banks
kalli
parents: 6502
diff changeset
    73
    private int restrict(int value) {
600ab3437bb8 6943053: Gervill: failures on invalid ranges and 14-bit banks
kalli
parents: 6502
diff changeset
    74
        if(value < 0) return 0;
600ab3437bb8 6943053: Gervill: failures on invalid ranges and 14-bit banks
kalli
parents: 6502
diff changeset
    75
        if(value > 127) return 127;
600ab3437bb8 6943053: Gervill: failures on invalid ranges and 14-bit banks
kalli
parents: 6502
diff changeset
    76
        return value;
600ab3437bb8 6943053: Gervill: failures on invalid ranges and 14-bit banks
kalli
parents: 6502
diff changeset
    77
    }
600ab3437bb8 6943053: Gervill: failures on invalid ranges and 14-bit banks
kalli
parents: 6502
diff changeset
    78
6502
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    79
    private void buildindex() {
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    80
        trantables = new byte[2][129];
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    81
        counters = new int[trantables.length];
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    82
        for (ModelPerformer performer : performers) {
6503
600ab3437bb8 6943053: Gervill: failures on invalid ranges and 14-bit banks
kalli
parents: 6502
diff changeset
    83
            int keyFrom = performer.getKeyFrom();
600ab3437bb8 6943053: Gervill: failures on invalid ranges and 14-bit banks
kalli
parents: 6502
diff changeset
    84
            int keyTo = performer.getKeyTo();
600ab3437bb8 6943053: Gervill: failures on invalid ranges and 14-bit banks
kalli
parents: 6502
diff changeset
    85
            int velFrom = performer.getVelFrom();
600ab3437bb8 6943053: Gervill: failures on invalid ranges and 14-bit banks
kalli
parents: 6502
diff changeset
    86
            int velTo = performer.getVelTo();
600ab3437bb8 6943053: Gervill: failures on invalid ranges and 14-bit banks
kalli
parents: 6502
diff changeset
    87
            if (keyFrom > keyTo) continue;
600ab3437bb8 6943053: Gervill: failures on invalid ranges and 14-bit banks
kalli
parents: 6502
diff changeset
    88
            if (velFrom > velTo) continue;
600ab3437bb8 6943053: Gervill: failures on invalid ranges and 14-bit banks
kalli
parents: 6502
diff changeset
    89
            keyFrom = restrict(keyFrom);
600ab3437bb8 6943053: Gervill: failures on invalid ranges and 14-bit banks
kalli
parents: 6502
diff changeset
    90
            keyTo = restrict(keyTo);
600ab3437bb8 6943053: Gervill: failures on invalid ranges and 14-bit banks
kalli
parents: 6502
diff changeset
    91
            velFrom = restrict(velFrom);
600ab3437bb8 6943053: Gervill: failures on invalid ranges and 14-bit banks
kalli
parents: 6502
diff changeset
    92
            velTo = restrict(velTo);
600ab3437bb8 6943053: Gervill: failures on invalid ranges and 14-bit banks
kalli
parents: 6502
diff changeset
    93
            trantables[0][keyFrom] = 1;
600ab3437bb8 6943053: Gervill: failures on invalid ranges and 14-bit banks
kalli
parents: 6502
diff changeset
    94
            trantables[0][keyTo + 1] = 1;
600ab3437bb8 6943053: Gervill: failures on invalid ranges and 14-bit banks
kalli
parents: 6502
diff changeset
    95
            trantables[1][velFrom] = 1;
600ab3437bb8 6943053: Gervill: failures on invalid ranges and 14-bit banks
kalli
parents: 6502
diff changeset
    96
            trantables[1][velTo + 1] = 1;
6502
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    97
        }
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    98
        for (int d = 0; d < trantables.length; d++) {
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
    99
            byte[] trantable = trantables[d];
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   100
            int transize = trantable.length;
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   101
            for (int i = transize - 1; i >= 0; i--) {
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   102
                if (trantable[i] == 1) {
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   103
                    trantable[i] = -1;
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   104
                    break;
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   105
                }
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   106
                trantable[i] = -1;
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   107
            }
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   108
            int counter = -1;
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   109
            for (int i = 0; i < transize; i++) {
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   110
                if (trantable[i] != 0) {
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   111
                    counter++;
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   112
                    if (trantable[i] == -1)
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   113
                        break;
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   114
                }
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   115
                trantable[i] = (byte) counter;
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   116
            }
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   117
            counters[d] = counter;
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   118
        }
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   119
        mat = new int[counters[0] * counters[1]][];
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   120
        int ix = 0;
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   121
        for (ModelPerformer performer : performers) {
6503
600ab3437bb8 6943053: Gervill: failures on invalid ranges and 14-bit banks
kalli
parents: 6502
diff changeset
   122
            int keyFrom = performer.getKeyFrom();
600ab3437bb8 6943053: Gervill: failures on invalid ranges and 14-bit banks
kalli
parents: 6502
diff changeset
   123
            int keyTo = performer.getKeyTo();
600ab3437bb8 6943053: Gervill: failures on invalid ranges and 14-bit banks
kalli
parents: 6502
diff changeset
   124
            int velFrom = performer.getVelFrom();
600ab3437bb8 6943053: Gervill: failures on invalid ranges and 14-bit banks
kalli
parents: 6502
diff changeset
   125
            int velTo = performer.getVelTo();
600ab3437bb8 6943053: Gervill: failures on invalid ranges and 14-bit banks
kalli
parents: 6502
diff changeset
   126
            if (keyFrom > keyTo) continue;
600ab3437bb8 6943053: Gervill: failures on invalid ranges and 14-bit banks
kalli
parents: 6502
diff changeset
   127
            if (velFrom > velTo) continue;
600ab3437bb8 6943053: Gervill: failures on invalid ranges and 14-bit banks
kalli
parents: 6502
diff changeset
   128
            keyFrom = restrict(keyFrom);
600ab3437bb8 6943053: Gervill: failures on invalid ranges and 14-bit banks
kalli
parents: 6502
diff changeset
   129
            keyTo = restrict(keyTo);
600ab3437bb8 6943053: Gervill: failures on invalid ranges and 14-bit banks
kalli
parents: 6502
diff changeset
   130
            velFrom = restrict(velFrom);
600ab3437bb8 6943053: Gervill: failures on invalid ranges and 14-bit banks
kalli
parents: 6502
diff changeset
   131
            velTo = restrict(velTo);
600ab3437bb8 6943053: Gervill: failures on invalid ranges and 14-bit banks
kalli
parents: 6502
diff changeset
   132
            int x_from = trantables[0][keyFrom];
600ab3437bb8 6943053: Gervill: failures on invalid ranges and 14-bit banks
kalli
parents: 6502
diff changeset
   133
            int x_to = trantables[0][keyTo + 1];
600ab3437bb8 6943053: Gervill: failures on invalid ranges and 14-bit banks
kalli
parents: 6502
diff changeset
   134
            int y_from = trantables[1][velFrom];
600ab3437bb8 6943053: Gervill: failures on invalid ranges and 14-bit banks
kalli
parents: 6502
diff changeset
   135
            int y_to = trantables[1][velTo + 1];
6502
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   136
            if (x_to == -1)
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   137
                x_to = counters[0];
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   138
            if (y_to == -1)
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   139
                y_to = counters[1];
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   140
            for (int y = y_from; y < y_to; y++) {
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   141
                int i = x_from + y * counters[0];
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   142
                for (int x = x_from; x < x_to; x++) {
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   143
                    int[] mprev = mat[i];
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   144
                    if (mprev == null) {
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   145
                        mat[i] = new int[] { ix };
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   146
                    } else {
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   147
                        int[] mnew = new int[mprev.length + 1];
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   148
                        mnew[mnew.length - 1] = ix;
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   149
                        for (int k = 0; k < mprev.length; k++)
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   150
                            mnew[k] = mprev[k];
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   151
                        mat[i] = mnew;
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   152
                    }
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   153
                    i++;
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   154
                }
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   155
            }
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   156
            ix++;
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   157
        }
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   158
    }
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   159
40444
afabcfc2f3ef 8163949: Cleanup of classes which are related to JavaSound
serb
parents: 25859
diff changeset
   160
    @Override
6502
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   161
    public void close() {
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   162
    }
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   163
40444
afabcfc2f3ef 8163949: Cleanup of classes which are related to JavaSound
serb
parents: 25859
diff changeset
   164
    @Override
6502
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   165
    public void noteOff(int noteNumber, int velocity) {
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   166
        if (!noteOffUsed)
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   167
            return;
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   168
        int[] plist = lookupIndex(noteNumber, velocity);
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   169
        if(plist == null) return;
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   170
        for (int i : plist) {
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   171
            ModelPerformer p = performers[i];
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   172
            if (p.isReleaseTriggered()) {
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   173
                player.play(i, null);
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   174
            }
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   175
        }
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   176
    }
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   177
40444
afabcfc2f3ef 8163949: Cleanup of classes which are related to JavaSound
serb
parents: 25859
diff changeset
   178
    @Override
6502
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   179
    public void noteOn(int noteNumber, int velocity) {
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   180
        if (!noteOnUsed)
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   181
            return;
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   182
        int[] plist = lookupIndex(noteNumber, velocity);
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   183
        if(plist == null) return;
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   184
        for (int i : plist) {
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   185
            ModelPerformer p = performers[i];
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   186
            if (!p.isReleaseTriggered()) {
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   187
                player.play(i, null);
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   188
            }
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   189
        }
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   190
    }
13b20559a04a 6941027: Gervill update, April 2010
kalli
parents:
diff changeset
   191
}