diff options
author | Zolnai Tamás <tamas.zolnai@collabora.com> | 2014-04-27 16:30:46 +0200 |
---|---|---|
committer | Zolnai Tamás <tamas.zolnai@collabora.com> | 2014-04-27 20:28:00 +0200 |
commit | 52b06dab6e53b7a25fd4d1dcebc3051afce4c5b4 (patch) | |
tree | 7adf7cc18ec9931c6387894dc9022f2accdeade2 /avmedia | |
parent | 79d75557100b696a02c3341f2e5277900cb3c4df (diff) |
OGLPlayer: use libgltf methods for playing 3D animation
By now this methods are unimplemented inside libgltf.
Change-Id: Ib7dfb1a053d11fc43fec26ec4f9195e7f64a8a74
Diffstat (limited to 'avmedia')
-rw-r--r-- | avmedia/source/opengl/oglplayer.cxx | 29 | ||||
-rw-r--r-- | avmedia/source/opengl/oglplayer.hxx | 1 |
2 files changed, 12 insertions, 18 deletions
diff --git a/avmedia/source/opengl/oglplayer.cxx b/avmedia/source/opengl/oglplayer.cxx index f6f8ab8b456a..3200f16bdd15 100644 --- a/avmedia/source/opengl/oglplayer.cxx +++ b/avmedia/source/opengl/oglplayer.cxx @@ -24,12 +24,13 @@ namespace avmedia { namespace ogl { OGLPlayer::OGLPlayer() : Player_BASE(m_aMutex) - , m_bIsPlaying(false) { } OGLPlayer::~OGLPlayer() { + // Comment out while it causes segmentation fault + // gltf_renderer_release(m_pHandle); } static bool lcl_LoadFile( glTFFile* io_pFile, const OUString& rURL) @@ -98,42 +99,37 @@ bool OGLPlayer::create( const OUString& rURL ) void SAL_CALL OGLPlayer::start() throw ( uno::RuntimeException, std::exception ) { osl::MutexGuard aGuard(m_aMutex); - // TODO: Start playing of gltf model (see com::sun::star::media::XPlayer) - m_bIsPlaying = true; + gltf_animation_start(m_pHandle); } void SAL_CALL OGLPlayer::stop() throw ( uno::RuntimeException, std::exception ) { osl::MutexGuard aGuard(m_aMutex); - // TODO: Stop playing of gltf model (see com::sun::star::media::XPlayer) - m_bIsPlaying = false; + gltf_animation_stop(m_pHandle); } sal_Bool SAL_CALL OGLPlayer::isPlaying() throw ( uno::RuntimeException, std::exception ) { osl::MutexGuard aGuard(m_aMutex); - // TODO: Check whether gltf model is played by now (see com::sun::star::media::XPlayer) - return m_bIsPlaying; + return (sal_Bool)gltf_animation_is_playing(m_pHandle); } double SAL_CALL OGLPlayer::getDuration() throw ( uno::RuntimeException, std::exception ) { osl::MutexGuard aGuard(m_aMutex); - // TODO: Get gltf's duration (see com::sun::star::media::XPlayer) - return 0.0; + return gltf_animation_get_duration(m_pHandle); } -void SAL_CALL OGLPlayer::setMediaTime( double /*fTime*/ ) throw ( uno::RuntimeException, std::exception ) +void SAL_CALL OGLPlayer::setMediaTime( double fTime ) throw ( uno::RuntimeException, std::exception ) { osl::MutexGuard aGuard(m_aMutex); - // TODO: Set player to the specified point (see com::sun::star::media::XPlayer) + gltf_animation_set_time(m_pHandle, fTime); } double SAL_CALL OGLPlayer::getMediaTime() throw ( ::com::sun::star::uno::RuntimeException, std::exception ) { osl::MutexGuard aGuard(m_aMutex); - // TODO: Get player current time position (see com::sun::star::media::XPlayer) - return 0.0; + return gltf_animation_get_time(m_pHandle); } double SAL_CALL OGLPlayer::getRate() throw ( uno::RuntimeException, std::exception ) @@ -143,17 +139,16 @@ double SAL_CALL OGLPlayer::getRate() throw ( uno::RuntimeException, std::excepti return 1.0; } -void SAL_CALL OGLPlayer::setPlaybackLoop( sal_Bool /*bSet*/ ) throw ( uno::RuntimeException, std::exception ) +void SAL_CALL OGLPlayer::setPlaybackLoop( sal_Bool bSet ) throw ( uno::RuntimeException, std::exception ) { osl::MutexGuard aGuard(m_aMutex); - // TODO: Set the playes replay itself when it ends (see com::sun::star::media::XPlayer) + gltf_animation_set_looping(m_pHandle, (int)bSet); } sal_Bool SAL_CALL OGLPlayer::isPlaybackLoop() throw ( uno::RuntimeException, std::exception ) { osl::MutexGuard aGuard(m_aMutex); - // TODO: Check whether playing will restart after it ends (see com::sun::star::media::XPlayer) - return false; + return (sal_Bool)gltf_animation_get_looping(m_pHandle); } void SAL_CALL OGLPlayer::setVolumeDB( sal_Int16 /*nVolumDB*/ ) throw ( uno::RuntimeException, std::exception ) diff --git a/avmedia/source/opengl/oglplayer.hxx b/avmedia/source/opengl/oglplayer.hxx index a40b43d808ac..1f1efce2440d 100644 --- a/avmedia/source/opengl/oglplayer.hxx +++ b/avmedia/source/opengl/oglplayer.hxx @@ -58,7 +58,6 @@ private: OUString m_sURL; glTFHandle* m_pHandle; OpenGLContext m_aContext; - bool m_bIsPlaying; }; } // namespace ogl |