summaryrefslogtreecommitdiff
path: root/indra/media_plugins
diff options
context:
space:
mode:
Diffstat (limited to 'indra/media_plugins')
-rw-r--r--indra/media_plugins/libvlc/media_plugin_libvlc.cpp345
1 files changed, 134 insertions, 211 deletions
diff --git a/indra/media_plugins/libvlc/media_plugin_libvlc.cpp b/indra/media_plugins/libvlc/media_plugin_libvlc.cpp
index 47ba6f48b4..91744798e7 100644
--- a/indra/media_plugins/libvlc/media_plugin_libvlc.cpp
+++ b/indra/media_plugins/libvlc/media_plugin_libvlc.cpp
@@ -35,8 +35,7 @@
#include "media_plugin_base.h"
#include "vlc/vlc.h"
-
-#include <time.h>
+#include "vlc/libvlc_version.h"
////////////////////////////////////////////////////////////////////////////////
//
@@ -52,23 +51,26 @@ class MediaPluginLibVLC :
private:
bool init();
void update( F64 milliseconds );
- bool mFirstTime;
-
- time_t mLastUpdateTime;
- enum Constants { ENumObjects = 10 };
- unsigned char* mBackgroundPixels;
- int mColorR[ ENumObjects ];
- int mColorG[ ENumObjects ];
- int mColorB[ ENumObjects ];
- int mXpos[ ENumObjects ];
- int mYpos[ ENumObjects ];
- int mXInc[ ENumObjects ];
- int mYInc[ ENumObjects ];
- int mBlockSize[ ENumObjects ];
-
- libvlc_instance_t* gLibVLC = 0;
- libvlc_media_t* gLibVLCMedia = 0;
- libvlc_media_player_t* gLibVLCMediaPlayer = 0;
+
+
+ static void* lock(void* data, void** p_pixels);
+ void initVLC();
+ void playMedia(const std::string url);
+ void resetVLC();
+
+ libvlc_instance_t* gLibVLC;
+ libvlc_media_t* gLibVLCMedia;
+ libvlc_media_player_t* gLibVLCMediaPlayer;
+
+
+ //float mCurVideoPosition;
+
+ struct gVLCContext
+ {
+ unsigned char* texture_pixels;
+ libvlc_media_player_t* mp;
+ };
+ struct gVLCContext gVLCCallbackContext;
};
////////////////////////////////////////////////////////////////////////////////
@@ -76,15 +78,18 @@ class MediaPluginLibVLC :
MediaPluginLibVLC::MediaPluginLibVLC( LLPluginInstance::sendMessageFunction host_send_func, void *host_user_data ) :
MediaPluginBase( host_send_func, host_user_data )
{
- mFirstTime = true;
mTextureWidth = 64;
mTextureHeight = 64;
mWidth = 0;
mHeight = 0;
mDepth = 4;
mPixels = 0;
- mLastUpdateTime = 0;
- mBackgroundPixels = 0;
+
+ gLibVLC = 0;
+ gLibVLCMedia = 0;
+ gLibVLCMediaPlayer = 0;
+
+ //mCurVideoPosition = 0;
}
////////////////////////////////////////////////////////////////////////////////
@@ -93,6 +98,88 @@ MediaPluginLibVLC::~MediaPluginLibVLC()
{
}
+/////////////////////////////////////////////////////////////////////////////////
+//
+void* MediaPluginLibVLC::lock(void* data, void** p_pixels)
+{
+ struct gVLCContext* context = (gVLCContext*)data;
+
+ *p_pixels = context->texture_pixels;
+
+ return NULL;
+}
+
+////////////////////////////////////////////////////////////////////////////////
+//
+void MediaPluginLibVLC::initVLC()
+{
+ char const* vlc_argv[] =
+ {
+ "--no-xlib",
+ };
+
+ int vlc_argc = sizeof(vlc_argv) / sizeof(*vlc_argv);
+ gLibVLC = libvlc_new(vlc_argc, vlc_argv);
+
+ if (!gLibVLC)
+ {
+ // TODO: do we need to do anything herE?
+ }
+}
+
+////////////////////////////////////////////////////////////////////////////////
+//
+void MediaPluginLibVLC::resetVLC()
+{
+ libvlc_media_player_stop(gLibVLCMediaPlayer);
+ libvlc_media_player_release(gLibVLCMediaPlayer);
+ libvlc_release(gLibVLC);
+}
+
+////////////////////////////////////////////////////////////////////////////////
+//
+void MediaPluginLibVLC::playMedia(const std::string url)
+{
+ std::string tmp_url = std::string("https://callum-linden.s3.amazonaws.com/sample_media/jb.mp4");
+
+ if (gLibVLCMediaPlayer)
+ {
+ libvlc_media_player_stop(gLibVLCMediaPlayer);
+ libvlc_media_player_release(gLibVLCMediaPlayer);
+ }
+
+ gLibVLCMedia = libvlc_media_new_location(gLibVLC, tmp_url.c_str());
+ if (!gLibVLCMedia)
+ {
+ printf("libvlc_media_new_location failed\n");
+ }
+ else
+ {
+ printf("libvlc_media_new_location ok\n");
+ }
+
+ gLibVLCMediaPlayer = libvlc_media_player_new_from_media(gLibVLCMedia);
+ if (!gLibVLCMediaPlayer)
+ {
+ printf("libvlc_media_player_new_from_media failed\n");
+ }
+ else
+ {
+ printf("libvlc_media_player_new_from_media ok...\n");
+ }
+
+ libvlc_media_release(gLibVLCMedia);
+
+ gVLCCallbackContext.texture_pixels = mPixels;
+ gVLCCallbackContext.mp = gLibVLCMediaPlayer;
+
+ libvlc_video_set_callbacks(gLibVLCMediaPlayer, lock, NULL, NULL, &gVLCCallbackContext);
+ libvlc_video_set_format(gLibVLCMediaPlayer, "RV32", mWidth, mHeight, mWidth * 4);
+ libvlc_media_player_play(gLibVLCMediaPlayer);
+
+ //libvlc_media_player_set_position(gLibVLCMediaPlayer, mCurVideoPosition);
+}
+
////////////////////////////////////////////////////////////////////////////////
//
void MediaPluginLibVLC::receiveMessage( const char* message_string )
@@ -108,54 +195,7 @@ void MediaPluginLibVLC::receiveMessage( const char* message_string )
{
if(message_name == "init")
{
- char const* vlc_argv[] =
- {
- "--no-xlib",
- };
-
- int vlc_argc = sizeof(vlc_argv) / sizeof(*vlc_argv);
- gLibVLC = libvlc_new(vlc_argc, vlc_argv);
-
- if (!gLibVLC)
- {
- }
-
- //if (gLibVLCMediaPlayer)
- //{
- // libvlc_media_player_stop(gLibVLCMediaPlayer);
- // libvlc_media_player_release(gLibVLCMediaPlayer);
- //}
-
- const char* url = "https://callum-linden.s3.amazonaws.com/sample_media/jb.mp4";
-
- gLibVLCMedia = libvlc_media_new_location(gLibVLC, url);
- if (!gLibVLCMedia)
- {
- printf("libvlc_media_new_location failed\n");
- }
- else
- {
- printf("libvlc_media_new_location ok\n");
- }
-
- gLibVLCMediaPlayer = libvlc_media_player_new_from_media(gLibVLCMedia);
- if (!gLibVLCMediaPlayer)
- {
- printf("libvlc_media_player_new_from_media failed\n");
- }
- else
- {
- printf("libvlc_media_player_new_from_media ok...\n");
- }
-
- libvlc_media_release(gLibVLCMedia);
-
-// gVLCCallbackContext.texture_pixels = gTexturePixels;
-// gVLCCallbackContext.mp = gLibVLCMediaPlayer;
-
-// libvlc_video_set_callbacks(gLibVLCMediaPlayer, lock, unlock, display, &gVLCCallbackContext);
- libvlc_video_set_format(gLibVLCMediaPlayer, "RV32", mTextureWidth, mTextureHeight, mTextureWidth * 4);
- libvlc_media_player_play(gLibVLCMediaPlayer);
+ initVLC();
LLPluginMessage message("base", "init_response");
LLSD versions = LLSD::emptyMap();
@@ -164,23 +204,25 @@ void MediaPluginLibVLC::receiveMessage( const char* message_string )
versions[LLPLUGIN_MESSAGE_CLASS_MEDIA_BROWSER] = LLPLUGIN_MESSAGE_CLASS_MEDIA_BROWSER_VERSION;
message.setValueLLSD("versions", versions);
- std::string plugin_version = "LibVLC plugin 0.0.0";
- message.setValue("plugin_version", plugin_version);
+ std::ostringstream s;
+ s << "LibVLC plugin ";
+ s << LIBVLC_VERSION_MAJOR;
+ s << ".";
+ s << LIBVLC_VERSION_MINOR;
+ s << ".";
+ s << LIBVLC_VERSION_REVISION;
+
+ message.setValue("plugin_version", s.str());
sendMessage(message);
}
else if(message_name == "idle")
{
- // no response is necessary here.
- F64 time = message_in.getValueReal("time");
-
- // Convert time to milliseconds for update()
- update((int)(time * 1000.0f));
+ // TODO move to VLC callback when VLC wants to draw a frame
+ setDirty(0, 0, mWidth, mHeight);
}
else if(message_name == "cleanup")
{
- libvlc_media_player_stop(gLibVLCMediaPlayer);
- libvlc_media_player_release(gLibVLCMediaPlayer);
- libvlc_release(gLibVLC);
+ resetVLC();
}
else if(message_name == "shm_added")
{
@@ -201,6 +243,13 @@ void MediaPluginLibVLC::receiveMessage( const char* message_string )
{
if(mPixels == iter->second.mAddress)
{
+ /// only do thisis URLs are the same if ( )
+ //mCurVideoPosition = libvlc_media_player_get_position(gLibVLCMediaPlayer);
+
+ libvlc_media_player_stop(gLibVLCMediaPlayer);
+ libvlc_media_player_release(gLibVLCMediaPlayer);
+ gLibVLCMediaPlayer = 0;
+
// This is the currently active pixel buffer. Make sure we stop drawing to it.
mPixels = NULL;
mTextureSegmentName.clear();
@@ -233,9 +282,9 @@ void MediaPluginLibVLC::receiveMessage( const char* message_string )
message.setValueS32("default_height", 1024);
message.setValueS32("depth", mDepth);
message.setValueU32("internalformat", GL_RGB);
- message.setValueU32("format", GL_RGBA);
+ message.setValueU32("format", GL_BGRA_EXT);
message.setValueU32("type", GL_UNSIGNED_BYTE);
- message.setValueBoolean("coords_opengl", true);
+ message.setValueBoolean("coords_opengl", false);
sendMessage(message);
}
else if(message_name == "size_change")
@@ -255,10 +304,11 @@ void MediaPluginLibVLC::receiveMessage( const char* message_string )
mPixels = (unsigned char*)iter->second.mAddress;
mWidth = width;
mHeight = height;
-
mTextureWidth = texture_width;
mTextureHeight = texture_height;
- };
+
+ playMedia("");
+ };
};
LLPluginMessage message(LLPLUGIN_MESSAGE_CLASS_MEDIA, "size_change_response");
@@ -268,10 +318,6 @@ void MediaPluginLibVLC::receiveMessage( const char* message_string )
message.setValueS32("texture_width", texture_width);
message.setValueS32("texture_height", texture_height);
sendMessage(message);
-
- mLastUpdateTime = 0;
- mFirstTime = true;
-
}
else if(message_name == "load_uri")
{
@@ -281,7 +327,6 @@ void MediaPluginLibVLC::receiveMessage( const char* message_string )
std::string event = message_in.getValue("event");
if(event == "down")
{
-
}
else if(event == "up")
{
@@ -299,128 +344,6 @@ void MediaPluginLibVLC::receiveMessage( const char* message_string )
////////////////////////////////////////////////////////////////////////////////
//
-void MediaPluginLibVLC::update( F64 milliseconds )
-{
- if ( mWidth < 1 || mWidth > 2048 || mHeight < 1 || mHeight > 2048 )
- return;
-
- if ( mPixels == 0 )
- return;
-
- if ( mFirstTime )
- {
- for( int n = 0; n < ENumObjects; ++n )
- {
- mXpos[ n ] = ( mWidth / 2 ) + rand() % ( mWidth / 16 ) - ( mWidth / 32 );
- mYpos[ n ] = ( mHeight / 2 ) + rand() % ( mHeight / 16 ) - ( mHeight / 32 );
-
- mColorR[ n ] = rand() % 0x60 + 0x60;
- mColorG[ n ] = rand() % 0x60 + 0x60;
- mColorB[ n ] = rand() % 0x60 + 0x60;
-
- mXInc[ n ] = 0;
- while ( mXInc[ n ] == 0 )
- mXInc[ n ] = rand() % 7 - 3;
-
- mYInc[ n ] = 0;
- while ( mYInc[ n ] == 0 )
- mYInc[ n ] = rand() % 9 - 4;
-
- mBlockSize[ n ] = rand() % 0x30 + 0x10;
- };
-
- delete [] mBackgroundPixels;
-
- mBackgroundPixels = new unsigned char[ mWidth * mHeight * mDepth ];
-
- mFirstTime = false;
- };
-
- if ( time( NULL ) > mLastUpdateTime + 3 )
- {
- const int num_squares = rand() % 20 + 4;
- int sqr1_r = rand() % 0x80 + 0x20;
- int sqr1_g = rand() % 0x80 + 0x20;
- int sqr1_b = rand() % 0x80 + 0x20;
- int sqr2_r = rand() % 0x80 + 0x20;
- int sqr2_g = rand() % 0x80 + 0x20;
- int sqr2_b = rand() % 0x80 + 0x20;
-
- for ( int y1 = 0; y1 < num_squares; ++y1 )
- {
- for ( int x1 = 0; x1 < num_squares; ++x1 )
- {
- int px_start = mWidth * x1 / num_squares;
- int px_end = ( mWidth * ( x1 + 1 ) ) / num_squares;
- int py_start = mHeight * y1 / num_squares;
- int py_end = ( mHeight * ( y1 + 1 ) ) / num_squares;
-
- for( int y2 = py_start; y2 < py_end; ++y2 )
- {
- for( int x2 = px_start; x2 < px_end; ++x2 )
- {
- int rowspan = mWidth * mDepth;
-
- if ( ( y1 % 2 ) ^ ( x1 % 2 ) )
- {
- mBackgroundPixels[ y2 * rowspan + x2 * mDepth + 0 ] = sqr1_r;
- mBackgroundPixels[ y2 * rowspan + x2 * mDepth + 1 ] = sqr1_g;
- mBackgroundPixels[ y2 * rowspan + x2 * mDepth + 2 ] = sqr1_b;
- }
- else
- {
- mBackgroundPixels[ y2 * rowspan + x2 * mDepth + 0 ] = sqr2_r;
- mBackgroundPixels[ y2 * rowspan + x2 * mDepth + 1 ] = sqr2_g;
- mBackgroundPixels[ y2 * rowspan + x2 * mDepth + 2 ] = sqr2_b;
- };
- };
- };
- };
- };
-
- time( &mLastUpdateTime );
- };
-
- memcpy( mPixels, mBackgroundPixels, mWidth * mHeight * mDepth );
-
- for( int n = 0; n < ENumObjects; ++n )
- {
- if ( rand() % 50 == 0 )
- {
- mXInc[ n ] = 0;
- while ( mXInc[ n ] == 0 )
- mXInc[ n ] = rand() % 7 - 3;
-
- mYInc[ n ] = 0;
- while ( mYInc[ n ] == 0 )
- mYInc[ n ] = rand() % 9 - 4;
- };
-
- if ( mXpos[ n ] + mXInc[ n ] < 0 || mXpos[ n ] + mXInc[ n ] >= mWidth - mBlockSize[ n ] )
- mXInc[ n ]= -mXInc[ n ];
-
- if ( mYpos[ n ] + mYInc[ n ] < 0 || mYpos[ n ] + mYInc[ n ] >= mHeight - mBlockSize[ n ] )
- mYInc[ n ]= -mYInc[ n ];
-
- mXpos[ n ] += mXInc[ n ];
- mYpos[ n ] += mYInc[ n ];
-
- for( int y = 0; y < mBlockSize[ n ]; ++y )
- {
- for( int x = 0; x < mBlockSize[ n ]; ++x )
- {
- mPixels[ ( mXpos[ n ] + x ) * mDepth + ( mYpos[ n ] + y ) * mDepth * mWidth + 0 ] = mColorR[ n ];
- mPixels[ ( mXpos[ n ] + x ) * mDepth + ( mYpos[ n ] + y ) * mDepth * mWidth + 1 ] = mColorG[ n ];
- mPixels[ ( mXpos[ n ] + x ) * mDepth + ( mYpos[ n ] + y ) * mDepth * mWidth + 2 ] = mColorB[ n ];
- };
- };
- };
-
- setDirty( 0, 0, mWidth, mHeight );
-};
-
-////////////////////////////////////////////////////////////////////////////////
-//
bool MediaPluginLibVLC::init()
{
LLPluginMessage message( LLPLUGIN_MESSAGE_CLASS_MEDIA, "name_text" );