Added restart on resize - kind of works

master
callum_linden 2016-05-09 17:11:10 -07:00
parent e11ab0240a
commit d15da19231
1 changed files with 132 additions and 209 deletions

View File

@ -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")
{
@ -297,128 +342,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()