IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)

SoundInstance QML Type

Play 3d audio content.

This type was introduced in Qt 5.0.

Article lu   fois.

L'auteur

Liens sociaux

Viadeo Twitter Facebook Share on Google+   

SoundInstance QML Type

  • Import Statement: import QtAudioEngine 1.1

  • Since: Qt 5.0

  • Inherits: Item

  • Group: SoundInstance is part of multimedia_audioengine

Detailed Description

There are two ways to create SoundInstance objects. You can obtain it by calling newInstance method of a Sound:

 
Sélectionnez
Rectangle {
    id:root
    color:"white"
    width: 300
    height: 500

    AudioEngine {
        id:audioengine

        AudioSample {
            name:"explosion01"
            source: "explosion-01.wav"
        }

        Sound {
            name:"explosion"
            PlayVariation {
                sample:"explosion01"
            }
        }
    }

    property variant soundEffect: audioengine.sounds["explosion"].newInstance();

    MouseArea {
        anchors.fill: parent
        onPressed: {
            root.soundEffect.play();
        }
    }
}

Or alternatively, you can explicitly define SoundInstance outside of AudioEngine for easier qml bindings:

 
Sélectionnez
Rectangle {
    id:root
    color:"white"
    width: 300
    height: 500

    AudioEngine {
        id:audioengine

        AudioSample {
            name:"explosion01"
            source: "explosion-01.wav"
        }

        Sound {
            name:"explosion"
            PlayVariation {
                sample:"explosion01"
            }
        }
    }

    Item {
        id: animator
        x: 10 + observer.percent * 100
        y: 20 + observer.percent * 80
        property real percent: 0
        SequentialAnimation on percent {
            loops: Animation.Infinite
            running: true
            NumberAnimation {
            duration: 8000
            from: 0
            to: 1
            }

        }
    }

    SoundInstance {
        id:soundEffect
        engine:audioengine
        sound:"explosion"
        position:Qt.vector3d(animator.x, animator.y, 0);
    }

    MouseArea {
        anchors.fill: parent
        onPressed: {
            soundEffect.play();
        }
    }
}

Property Documentation

 

direction : vector3d

This property holds the current 3d direction.

engine : QtAudioEngine::AudioEngine

This property holds the reference to AudioEngine, must be set only once.

gain : vector3d

This property holds the gain adjustment which will be used to modulate the audio output level from this SoundInstance.

pitch : vector3d

This property holds the pitch adjustment which will be used to modulate the audio pitch from this SoundInstance.

position : vector3d

This property holds the current 3d position.

sound : string

This property specifies which Sound this SoundInstance will use. Unlike some properties in other types, this property can be changed dynamically.

[read-only] state : enumeration

This property holds the current playback state. It can be one of:

Value

Description

StopppedState

The SoundInstance is not playing, and when playback begins next it will play from position zero.

PlayingState

The SoundInstance is playing the media.

PausedState

The SoundInstance is not playing, and when playback begins next it will play from the position that it was paused at.

velocity : vector3d

This property holds the current 3d velocity.

Signal Documentation

 

directionChanged()

This signal is emitted when direction is changed

The corresponding handler is onDirectionChanged.

The corresponding handler is onDirectionChanged.

gainChanged()

This signal is emitted when gain is changed

The corresponding handler is onGainChanged.

The corresponding handler is onGainChanged.

pitchChanged()

This signal is emitted when pitch is changed

The corresponding handler is onPitchChanged.

The corresponding handler is onPitchChanged.

positionChanged()

This signal is emitted when position is changed

The corresponding handler is onPositionChanged.

The corresponding handler is onPositionChanged.

soundChanged()

This signal is emitted when sound is changed

The corresponding handler is onSoundChanged.

The corresponding handler is onSoundChanged.

stateChanged(state)

This signal is emitted when state is changed

The corresponding handler is onStateChanged.

The corresponding handler is onStateChanged.

velocityChanged()

This signal is emitted when velocity is changed

The corresponding handler is onVelocityChanged.

The corresponding handler is onVelocityChanged.

Method Documentation

 

pause()

Pauses current playback.

play()

Starts playback.

stop()

Stops current playback.

Vous avez aimé ce tutoriel ? Alors partagez-le en cliquant sur les boutons suivants : Viadeo Twitter Facebook Share on Google+