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