sound/src/main/java/org/netbeans/html/sound/spi/AudioEnvironment.java
author Jaroslav Tulach <jtulach@netbeans.org>
Tue, 26 Aug 2014 18:13:30 +0200
changeset 838 bdc3d696dd4a
parent 835 sound/src/main/java/org/apidesign/html/sound/spi/AudioEnvironment.java@14fcf4844fad
permissions -rw-r--r--
During the API review process (bug 246133) the reviewers decided that in order to include html4j to NetBeans Platform, we need to stop using org.apidesign namespace and switch to NetBeans one. Repackaging all SPI packages into org.netbeans.html.smthng.spi.
toni@107
     1
/**
jaroslav@358
     2
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
toni@107
     3
 *
jaroslav@551
     4
 * Copyright 2013-2014 Oracle and/or its affiliates. All rights reserved.
toni@107
     5
 *
jaroslav@358
     6
 * Oracle and Java are registered trademarks of Oracle and/or its affiliates.
jaroslav@358
     7
 * Other names may be trademarks of their respective owners.
toni@107
     8
 *
jaroslav@358
     9
 * The contents of this file are subject to the terms of either the GNU
jaroslav@358
    10
 * General Public License Version 2 only ("GPL") or the Common
jaroslav@358
    11
 * Development and Distribution License("CDDL") (collectively, the
jaroslav@358
    12
 * "License"). You may not use this file except in compliance with the
jaroslav@358
    13
 * License. You can obtain a copy of the License at
jaroslav@358
    14
 * http://www.netbeans.org/cddl-gplv2.html
jaroslav@358
    15
 * or nbbuild/licenses/CDDL-GPL-2-CP. See the License for the
jaroslav@358
    16
 * specific language governing permissions and limitations under the
jaroslav@358
    17
 * License.  When distributing the software, include this License Header
jaroslav@358
    18
 * Notice in each file and include the License file at
jaroslav@358
    19
 * nbbuild/licenses/CDDL-GPL-2-CP.  Oracle designates this
jaroslav@358
    20
 * particular file as subject to the "Classpath" exception as provided
jaroslav@358
    21
 * by Oracle in the GPL Version 2 section of the License file that
jaroslav@358
    22
 * accompanied this code. If applicable, add the following below the
jaroslav@358
    23
 * License Header, with the fields enclosed by brackets [] replaced by
jaroslav@358
    24
 * your own identifying information:
jaroslav@358
    25
 * "Portions Copyrighted [year] [name of copyright owner]"
jaroslav@358
    26
 *
jaroslav@358
    27
 * Contributor(s):
jaroslav@358
    28
 *
jaroslav@358
    29
 * The Original Software is NetBeans. The Initial Developer of the Original
jaroslav@551
    30
 * Software is Oracle. Portions Copyright 2013-2014 Oracle. All Rights Reserved.
jaroslav@358
    31
 *
jaroslav@358
    32
 * If you wish your version of this file to be governed by only the CDDL
jaroslav@358
    33
 * or only the GPL Version 2, indicate your decision by adding
jaroslav@358
    34
 * "[Contributor] elects to include this software in this distribution
jaroslav@358
    35
 * under the [CDDL or GPL Version 2] license." If you do not indicate a
jaroslav@358
    36
 * single choice of license, a recipient has the option to distribute
jaroslav@358
    37
 * your version of this file under either the CDDL, the GPL Version 2 or
jaroslav@358
    38
 * to extend the choice of license to its licensees as provided above.
jaroslav@358
    39
 * However, if you add GPL Version 2 code and therefore, elected the GPL
jaroslav@358
    40
 * Version 2 license, then the option applies only if the new code is
jaroslav@358
    41
 * made subject to such option by the copyright holder.
toni@107
    42
 */
jtulach@838
    43
package org.netbeans.html.sound.spi;
toni@107
    44
jtulach@740
    45
import net.java.html.BrwsrCtx;
jtulach@838
    46
import org.netbeans.html.context.spi.Contexts;
jtulach@740
    47
jaroslav@537
    48
/** Basic interface for sound playback providers. Register your implementation
jaroslav@537
    49
 * in a way {@link java.util.ServiceLoader} can find it - e.g. use
jtulach@740
    50
 * {@link org.openide.util.lookup.ServiceProvider} annotation. Possibly
jtulach@740
    51
 * one can register the provider into {@link Contexts#newBuilder()}, in
jtulach@740
    52
 * case the implementation is somehow associated 
jtulach@740
    53
 * with the actual {@link BrwsrCtx} (works since version 0.8.3).
toni@107
    54
 *
toni@107
    55
 * @author antonepple
jaroslav@537
    56
 * @param <Audio> custom type representing the internal audio state
toni@107
    57
 */
jaroslav@223
    58
public interface AudioEnvironment<Audio> {
jaroslav@537
    59
    /** Checks if the provided URL can be a supported audio stream 
jaroslav@537
    60
     * and if so, it create an object to represent it. The created object
jaroslav@537
    61
     * will be used in future callbacks to other methods of this interface
jaroslav@537
    62
     * (like {@link #play(java.lang.Object)}).
jaroslav@537
    63
     * @param src the URL pointing to the media stream
jaroslav@537
    64
     * @return an internal representation object or <code>null</code> if this
jaroslav@537
    65
     *   environment does not know how to handle such stream
jaroslav@537
    66
     */
jaroslav@223
    67
    public Audio create(String src);
toni@107
    68
jaroslav@537
    69
    /** Starts playback of the audio.
jaroslav@537
    70
     * 
jaroslav@537
    71
     * @param a the internal representation of the audio as created by {@link #create(java.lang.String)} method.
jaroslav@537
    72
     */
jaroslav@223
    73
    public void play(Audio a);
toni@107
    74
jaroslav@537
    75
    /** Pauses playback of the audio.
jaroslav@537
    76
     * 
jaroslav@537
    77
     * @param a the internal representation of the audio as created by {@link #create(java.lang.String)} method.
jaroslav@537
    78
     */
jaroslav@223
    79
    public void pause(Audio a);
toni@107
    80
jaroslav@537
    81
    /** Changes volume for the playback of the audio.
jaroslav@537
    82
     * 
jaroslav@537
    83
     * @param a the internal representation of the audio as created by {@link #create(java.lang.String)} method.
jaroslav@537
    84
     * @param volume value between 0.0 and 1.0
jaroslav@537
    85
     */
jaroslav@223
    86
    public void setVolume(Audio a, double volume);
jaroslav@537
    87
jaroslav@537
    88
    /** Checks whether given audio is supported
jaroslav@537
    89
     * 
jtulach@835
    90
     * @param a the internal representation of the audio as created by {@link #create(java.lang.String)} method.
jaroslav@537
    91
     * @return <code>true</code> or <code>false</code>
jaroslav@537
    92
     */
jaroslav@248
    93
    public boolean isSupported(Audio a);
toni@107
    94
}