Skip to content

Commit

Permalink
* skins2: support $t, $d, and $l in text controls. They do the same …
Browse files Browse the repository at this point in the history
…as $T, $D

   and $L, except that the hour is not printed if it is 0.
  • Loading branch information
ipkiss42 committed Nov 13, 2005
1 parent 3c5d89e commit b3d9b33
Show file tree
Hide file tree
Showing 4 changed files with 47 additions and 18 deletions.
1 change: 1 addition & 0 deletions modules/gui/skins2/src/bitmap_font.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,7 @@ BitmapFont::BitmapFont( intf_thread_t *pIntf, const GenericBitmap &rBitmap,
{
m_table['0'+i].m_xPos = i * m_width;
}
m_table[(size_t)' '].m_xPos = 10 * m_width;
m_table[(size_t)'-'].m_xPos = 11 * m_width;
}
else if( rType == "text" )
Expand Down
24 changes: 21 additions & 3 deletions modules/gui/skins2/utils/var_text.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -83,16 +83,31 @@ const UString VarText::get() const
temp.replace( pos, 2,
pVlcProc->getTimeVar().getAsStringCurrTime().c_str() );
}
while( (pos = temp.find( "$t" )) != UString::npos )
{
temp.replace( pos, 2,
pVlcProc->getTimeVar().getAsStringCurrTime(true).c_str() );
}
while( (pos = temp.find( "$L" )) != UString::npos )
{
temp.replace( pos, 2,
pVlcProc->getTimeVar().getAsStringTimeLeft().c_str() );
}
while( (pos = temp.find( "$l" )) != UString::npos )
{
temp.replace( pos, 2,
pVlcProc->getTimeVar().getAsStringTimeLeft(true).c_str() );
}
while( (pos = temp.find( "$D" )) != UString::npos )
{
temp.replace( pos, 2,
pVlcProc->getTimeVar().getAsStringDuration().c_str() );
}
while( (pos = temp.find( "$d" )) != UString::npos )
{
temp.replace( pos, 2,
pVlcProc->getTimeVar().getAsStringDuration(true).c_str() );
}
while( (pos = temp.find( "$V" )) != UString::npos )
{
temp.replace( pos, 2,
Expand Down Expand Up @@ -137,15 +152,18 @@ void VarText::set( const UString &rText )
{
pVarManager->getHelpText().addObserver( this );
}
if( m_text.find( "$T" ) != UString::npos )
if( m_text.find( "$T" ) != UString::npos ||
m_text.find( "$t" ) != UString::npos )
{
pVlcProc->getTimeVar().addObserver( this );
}
if( m_text.find( "$L" ) != UString::npos )
if( m_text.find( "$L" ) != UString::npos ||
m_text.find( "$l" ) != UString::npos )
{
pVlcProc->getTimeVar().addObserver( this );
}
if( m_text.find( "$D" ) != UString::npos )
if( m_text.find( "$D" ) != UString::npos ||
m_text.find( "$d" ) != UString::npos )
{
pVlcProc->getTimeVar().addObserver( this );
}
Expand Down
32 changes: 21 additions & 11 deletions modules/gui/skins2/vars/time.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -56,7 +56,7 @@ const string StreamTime::getAsStringPercent() const
}


const string StreamTime::getAsStringCurrTime() const
const string StreamTime::getAsStringCurrTime( bool bShortFormat ) const
{
if( getIntf()->p_sys->p_input == NULL )
{
Expand All @@ -73,11 +73,11 @@ const string StreamTime::getAsStringCurrTime() const
vlc_value_t time;
var_Get( getIntf()->p_sys->p_input, "time", &time );

return formatTime( time.i_time / 1000000 );
return formatTime( time.i_time / 1000000, bShortFormat );
}


const string StreamTime::getAsStringTimeLeft() const
const string StreamTime::getAsStringTimeLeft( bool bShortFormat ) const
{
if( getIntf()->p_sys->p_input == NULL )
{
Expand All @@ -95,11 +95,12 @@ const string StreamTime::getAsStringTimeLeft() const
var_Get( getIntf()->p_sys->p_input, "time", &time );
var_Get( getIntf()->p_sys->p_input, "length", &duration );

return formatTime( (duration.i_time - time.i_time) / 1000000 );
return formatTime( (duration.i_time - time.i_time) / 1000000,
bShortFormat );
}


const string StreamTime::getAsStringDuration() const
const string StreamTime::getAsStringDuration( bool bShortFormat ) const
{
if( getIntf()->p_sys->p_input == NULL )
{
Expand All @@ -116,17 +117,26 @@ const string StreamTime::getAsStringDuration() const
vlc_value_t time;
var_Get( getIntf()->p_sys->p_input, "length", &time );

return formatTime( time.i_time / 1000000 );
return formatTime( time.i_time / 1000000, bShortFormat );
}


const string StreamTime::formatTime( int seconds ) const
const string StreamTime::formatTime( int seconds, bool bShortFormat ) const
{
char *psz_time = new char[MSTRTIME_MAX_SIZE];
snprintf( psz_time, MSTRTIME_MAX_SIZE, "%d:%02d:%02d",
(int) (seconds / (60 * 60)),
(int) (seconds / 60 % 60),
(int) (seconds % 60) );
if( bShortFormat && (seconds < 60 * 60) )
{
snprintf( psz_time, MSTRTIME_MAX_SIZE, " %02d:%02d",
(int) (seconds / 60 % 60),
(int) (seconds % 60) );
}
else
{
snprintf( psz_time, MSTRTIME_MAX_SIZE, "%d:%02d:%02d",
(int) (seconds / (60 * 60)),
(int) (seconds / 60 % 60),
(int) (seconds % 60) );
}

string ret = psz_time;
delete[] psz_time;
Expand Down
8 changes: 4 additions & 4 deletions modules/gui/skins2/vars/time.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -42,15 +42,15 @@ class StreamTime: public VarPercent
/// Return a string containing a value from 0 to 100
virtual const string getAsStringPercent() const;
/// Return the current time formatted as a time display (h:mm:ss)
virtual const string getAsStringCurrTime() const;
virtual const string getAsStringCurrTime( bool bShortFormat = false ) const;
/// Return the time left formatted as a time display (h:mm:ss)
virtual const string getAsStringTimeLeft() const;
virtual const string getAsStringTimeLeft( bool bShortFormat = false ) const;
/// Return the duration formatted as a time display (h:mm:ss)
virtual const string getAsStringDuration() const;
virtual const string getAsStringDuration( bool bShortFormat = false ) const;

private:
/// Convert a number of seconds into "h:mm:ss" format
const string formatTime( int seconds ) const;
const string formatTime( int seconds, bool bShortFormat ) const;
};

#endif

0 comments on commit b3d9b33

Please sign in to comment.