Commit ea3a7dc1 authored by Clément Stenac's avatar Clément Stenac

* wizard.cpp : - TTL and SAP support

	       - Sanity checks for transcode output file

* Modules.am : Added new "icons" to dist
parent 4b3cc9ce
...@@ -31,4 +31,7 @@ EXTRA_DIST += \ ...@@ -31,4 +31,7 @@ EXTRA_DIST += \
bitmaps/slow.xpm \ bitmaps/slow.xpm \
bitmaps/fast.xpm \ bitmaps/fast.xpm \
bitmaps/playlist.xpm \ bitmaps/playlist.xpm \
bitmaps/speaker.xpm bitmaps/speaker.xpm \
bitmaps/shuffle.xpm \
bitmaps/repeat.xpm \
bitmaps/loop.xpm
...@@ -50,7 +50,7 @@ enum ...@@ -50,7 +50,7 @@ enum
MoreInfoStreaming_Event, MoreInfoStreaming_Event,
MoreInfoTranscode_Event, MoreInfoTranscode_Event,
Open_Event,Choose_Event, Open_Event , Choose_Event ,
ListView_Event, ListView_Event,
InputRadio0_Event, InputRadio1_Event, InputRadio0_Event, InputRadio1_Event,
PartialEnable_Event, PartialEnable_Event,
...@@ -63,10 +63,13 @@ enum ...@@ -63,10 +63,13 @@ enum
EncapRadio4_Event, EncapRadio5_Event, EncapRadio4_Event, EncapRadio5_Event,
EncapRadio6_Event, EncapRadio7_Event, EncapRadio6_Event, EncapRadio7_Event,
EncapRadio8_Event, EncapRadio9_Event, EncapRadio8_Event, EncapRadio9_Event,
EncapRadio10_Event, EncapRadio11_Event,
VideoEnable_Event, VideoCodec_Event,VideoBitrate_Event, VideoEnable_Event, VideoCodec_Event,VideoBitrate_Event,
AudioEnable_Event, AudioCodec_Event,AudioBitrate_Event, AudioEnable_Event, AudioCodec_Event,AudioBitrate_Event,
SAP_Event,
}; };
#define TEXTWIDTH 55 #define TEXTWIDTH 55
...@@ -152,11 +155,24 @@ END_EVENT_TABLE() ...@@ -152,11 +155,24 @@ END_EVENT_TABLE()
#define EXTRATRANSCODE_TEXT _("In this page, you will define a few " \ #define EXTRATRANSCODE_TEXT _("In this page, you will define a few " \
"additionnal parameters for your transcoding" ) "additionnal parameters for your transcoding" )
#define CHOOSE_OUTFILE _("You must choose a file to save to")
/* Streaming 2 */ /* Streaming 2 */
#define EXTRASTREAMING_TITLE _("Additional streaming options") #define EXTRASTREAMING_TITLE _("Additional streaming options")
#define EXTRASTREAMING_TEXT _("In this page, you will define a few " \ #define EXTRASTREAMING_TEXT _("In this page, you will define a few " \
"additionnal parameters for your stream" ) "additionnal parameters for your stream" )
#define TTL _("Define the TTL (Time-To-Live) of the stream. This parameter " \
"is the maximum number of routers your stream can go through. " \
"If you don't know what it means, or if you want to stream on " \
"your local network only, leave this setting to 1." )
#define SAP _("When streaming using UDP, you can announce your streams " \
"using the SAP/SDP announcing protocol. This way, the clients " \
"won't have to type in the multicast address, it will appear " \
"in their playlist if they enable the SAP extra interface.\n" \
"If you want to give a name to your stream, enter it here, " \
"else, a default name will be used" )
/***************************************************************************** /*****************************************************************************
* All the pages of the wizard, declaration * All the pages of the wizard, declaration
...@@ -360,9 +376,11 @@ public: ...@@ -360,9 +376,11 @@ public:
wxWizardPage *next); wxWizardPage *next);
virtual wxWizardPage *GetPrev() const; virtual wxWizardPage *GetPrev() const;
virtual wxWizardPage *GetNext() const; virtual wxWizardPage *GetNext() const;
void OnWizardPageChanging( wxWizardEvent& event );
protected: protected:
DECLARE_EVENT_TABLE() DECLARE_EVENT_TABLE()
void wizTranscodeExtraPage::OnSelectFile(wxCommandEvent&); void wizTranscodeExtraPage::OnSelectFile(wxCommandEvent&);
wxTextCtrl *file_text;
WizardDialog *p_parent; WizardDialog *p_parent;
wxWizardPage *p_prev; wxWizardPage *p_prev;
wxWizardPage *p_next; wxWizardPage *p_next;
...@@ -370,6 +388,7 @@ protected: ...@@ -370,6 +388,7 @@ protected:
BEGIN_EVENT_TABLE(wizTranscodeExtraPage, wxWizardPage) BEGIN_EVENT_TABLE(wizTranscodeExtraPage, wxWizardPage)
EVT_BUTTON( Open_Event, wizTranscodeExtraPage::OnSelectFile) EVT_BUTTON( Open_Event, wizTranscodeExtraPage::OnSelectFile)
EVT_WIZARD_PAGE_CHANGING(-1, wizTranscodeExtraPage::OnWizardPageChanging)
END_EVENT_TABLE() END_EVENT_TABLE()
/* Additional settings for streaming */ /* Additional settings for streaming */
...@@ -380,14 +399,23 @@ public: ...@@ -380,14 +399,23 @@ public:
wxWizardPage *next); wxWizardPage *next);
virtual wxWizardPage *GetPrev() const; virtual wxWizardPage *GetPrev() const;
virtual wxWizardPage *GetNext() const; virtual wxWizardPage *GetNext() const;
void OnWizardPageChanging(wxWizardEvent&);
void OnSAP( wxCommandEvent&);
wxCheckBox *sap_checkbox;
wxTextCtrl *sap_text;
protected: protected:
friend class wizEncapPage;
DECLARE_EVENT_TABLE() DECLARE_EVENT_TABLE()
WizardDialog *p_parent; WizardDialog *p_parent;
wxWizardPage *p_prev; wxWizardPage *p_prev;
wxWizardPage *p_next; wxWizardPage *p_next;
wxSpinCtrl *ttl_spin;
}; };
BEGIN_EVENT_TABLE(wizStreamingExtraPage, wxWizardPage) BEGIN_EVENT_TABLE(wizStreamingExtraPage, wxWizardPage)
EVT_CHECKBOX( SAP_Event, wizStreamingExtraPage::OnSAP )
EVT_WIZARD_PAGE_CHANGING(-1, wizStreamingExtraPage::OnWizardPageChanging)
END_EVENT_TABLE() END_EVENT_TABLE()
...@@ -1101,9 +1129,25 @@ void wizEncapPage::OnWizardPageChanging(wxWizardEvent& event) ...@@ -1101,9 +1129,25 @@ void wizEncapPage::OnWizardPageChanging(wxWizardEvent& event)
} }
} }
p_parent->SetMux( encaps_array[i_mux].psz_mux ); p_parent->SetMux( encaps_array[i_mux].psz_mux );
if( p_parent->GetAction() == ACTION_STREAM )
{
if( strstr( p_parent->method, "udp" ))
{
((wizStreamingExtraPage *)GetNext())->sap_checkbox->Enable();
((wizStreamingExtraPage *)GetNext())->sap_text->Enable(false);
}
else
{
((wizStreamingExtraPage *)GetNext())->sap_checkbox->Enable( false );
((wizStreamingExtraPage *)GetNext())->sap_text->Enable( false );
}
}
return; return;
} }
void wizEncapPage::OnEncapChange(wxEvent& event) void wizEncapPage::OnEncapChange(wxEvent& event)
{ {
i_mux = event.GetId() - EncapRadio0_Event; i_mux = event.GetId() - EncapRadio0_Event;
...@@ -1162,11 +1206,23 @@ wizTranscodeExtraPage::wizTranscodeExtraPage( wxWizard *parent, ...@@ -1162,11 +1206,23 @@ wizTranscodeExtraPage::wizTranscodeExtraPage( wxWizard *parent,
/* Create the texts */ /* Create the texts */
pageHeader( this, mainSizer, EXTRATRANSCODE_TITLE, EXTRATRANSCODE_TEXT ); pageHeader( this, mainSizer, EXTRATRANSCODE_TITLE, EXTRATRANSCODE_TEXT );
mainSizer->Add( new wxStaticText( this, -1, mainSizer->Add( 0, 0, 1 );
wxFlexGridSizer *sizer = new wxFlexGridSizer( 2, 2, 1 );
sizer->Add( new wxStaticText( this, -1,
wxU(_("Select the file to save to") ) ), wxU(_("Select the file to save to") ) ),
0, wxALL, 5 ); 0, wxALL, 5 );
sizer->Add( 0, 0, 1 );
mainSizer->Add( new wxButton( this, Open_Event, wxU("Choose") ) ); file_text = new wxTextCtrl( this, -1, wxU(""), wxDefaultPosition,
wxSize( 150, -1 ) );
sizer->Add( file_text, 0, wxALL, 5 );
sizer->Add( new wxButton( this, Open_Event, wxU("Choose") ) );
mainSizer->Add( sizer, 0, 0, 0) ;
mainSizer->Add( 0, 0, 1 );
SetSizer(mainSizer); SetSizer(mainSizer);
mainSizer->Fit(this); mainSizer->Fit(this);
} }
...@@ -1180,11 +1236,23 @@ void wizTranscodeExtraPage::OnSelectFile( wxCommandEvent &event) ...@@ -1180,11 +1236,23 @@ void wizTranscodeExtraPage::OnSelectFile( wxCommandEvent &event)
{ {
if( file_dialog->GetFilename().mb_str() ) if( file_dialog->GetFilename().mb_str() )
{ {
p_parent->SetTranscodeOut( (char*)file_dialog->GetFilename(). file_text->SetValue( file_dialog->GetFilename() );
c_str() );
} }
} }
}
void wizTranscodeExtraPage::OnWizardPageChanging( wxWizardEvent& event )
{
if( event.GetDirection() && file_text->GetValue().IsEmpty() )
{
wxMessageBox( wxU( CHOOSE_OUTFILE ), wxU( ERROR_MSG ),
wxICON_WARNING | wxOK, this->p_parent );
event.Veto();
}
if( event.GetDirection() )
{
p_parent->SetTranscodeOut( (char *)file_text->GetValue().c_str());
}
} }
wxWizardPage *wizTranscodeExtraPage::GetPrev() const { return p_prev; } wxWizardPage *wizTranscodeExtraPage::GetPrev() const { return p_prev; }
...@@ -1205,10 +1273,62 @@ wizStreamingExtraPage::wizStreamingExtraPage( wxWizard *parent, ...@@ -1205,10 +1273,62 @@ wizStreamingExtraPage::wizStreamingExtraPage( wxWizard *parent,
/* Create the texts */ /* Create the texts */
pageHeader( this, mainSizer, EXTRASTREAMING_TITLE, EXTRASTREAMING_TEXT ); pageHeader( this, mainSizer, EXTRASTREAMING_TITLE, EXTRASTREAMING_TEXT );
mainSizer->Add( 0, 0, 1 );
wxFlexGridSizer *sizer = new wxFlexGridSizer( 2,2,1) ;
/* TTL */
sizer->Add( new wxStaticText( this, -1, wxU(_("Time-To-Live (TTL)"))),
0, wxALL, 5 );
ttl_spin = new wxSpinCtrl( this, -1, "", wxDefaultPosition, wxDefaultSize,
0, 1, 255, 1 );
ttl_spin->SetToolTip(wxU(_(TTL) ) ) ;
sizer->Add( ttl_spin, 0, wxALL , 5 );
/* SAP announce */
sap_checkbox = new wxCheckBox( this, SAP_Event, wxU(_("SAP Announce")) );
sap_checkbox->SetToolTip( wxU(_( SAP ) ) );
sizer->Add( sap_checkbox, 0, 0 , 0 );
sap_text = new wxTextCtrl( this, -1, wxU(""), wxDefaultPosition,
wxSize(100,25) );
sap_text->SetToolTip( wxU(_( SAP ) ) );
sizer->Add( sap_text, 0, wxALL , 5 );
mainSizer->Add(sizer, 0, wxALL, 5 );
mainSizer->Add( 0, 0, 1 );
SetSizer(mainSizer); SetSizer(mainSizer);
mainSizer->Fit(this); mainSizer->Fit(this);
} }
void wizStreamingExtraPage::OnSAP( wxCommandEvent &event )
{
sap_text->Enable( event.IsChecked() );
}
void wizStreamingExtraPage::OnWizardPageChanging(wxWizardEvent& event)
{
if( sap_checkbox->IsChecked() )
{
if( sap_text->GetValue().IsEmpty() )
{
p_parent->SetSAP( true, NULL );
}
else
{
p_parent->SetSAP( true,
(const char *)sap_text->GetValue().mb_str() );
}
}
else
{
p_parent->SetSAP( false, NULL );
}
p_parent->SetTTL( ttl_spin->GetValue() );
}
wxWizardPage *wizStreamingExtraPage::GetPrev() const { return p_prev; } wxWizardPage *wizStreamingExtraPage::GetPrev() const { return p_prev; }
wxWizardPage *wizStreamingExtraPage::GetNext() const {return p_next; } wxWizardPage *wizStreamingExtraPage::GetNext() const {return p_next; }
...@@ -1229,12 +1349,13 @@ wxWizard( _p_parent, -1, wxU(_("Streaming/Transcoding Wizard")), wxNullBitmap, w ...@@ -1229,12 +1349,13 @@ wxWizard( _p_parent, -1, wxU(_("Streaming/Transcoding Wizard")), wxNullBitmap, w
{ {
/* Initializations */ /* Initializations */
p_intf = _p_intf; p_intf = _p_intf;
SetPageSize(wxSize(400,350)); SetPageSize(wxSize(400,420));
/* Initialize structure */ /* Initialize structure */
i_action = 0; i_action = 0;
i_from = 0; i_from = 0;
i_to = 0; i_to = 0;
i_ttl = 1;
vb = 0; vb = 0;
ab = 0; ab = 0;
acodec=NULL; acodec=NULL;
...@@ -1284,6 +1405,27 @@ void WizardDialog::SetMrl( const char *mrl ) ...@@ -1284,6 +1405,27 @@ void WizardDialog::SetMrl( const char *mrl )
this->mrl = strdup( mrl ); this->mrl = strdup( mrl );
} }
void WizardDialog::SetTTL( int i_ttl )
{
this->i_ttl = i_ttl;
}
void WizardDialog::SetSAP( bool b_enabled, const char *psz_text )
{
this->b_sap = b_enabled;
if( b_enabled )
{
if( psz_text != NULL )
{
this->psz_sap_name = strdup( psz_text );
}
else
{
this->psz_sap_name = NULL;
}
}
}
void WizardDialog::SetPartial( int i_from, int i_to ) void WizardDialog::SetPartial( int i_from, int i_to )
{ {
this->i_from = i_from; this->i_from = i_from;
...@@ -1384,17 +1526,44 @@ void WizardDialog::Run() ...@@ -1384,17 +1526,44 @@ void WizardDialog::Run()
msg_Dbg( p_intf, "Starting stream of %s to %s using %s, encap %s", msg_Dbg( p_intf, "Starting stream of %s to %s using %s, encap %s",
mrl, address, method, mux); mrl, address, method, mux);
i_size = 40 + strlen(mux) + strlen(address); if( b_sap )
psz_opt = (char *)malloc( i_size * sizeof(char) ); {
sprintf( psz_opt, ":sout=#standard{mux=%s,url=%s,access=%s}", char *psz_sap_option = NULL;
if( psz_sap_name )
{
psz_sap_option = (char *) malloc( strlen( psz_sap_name )
+ 15 );
sprintf( psz_sap_option, "sap,name=\"%s\"",psz_sap_name );
}
else
{
psz_sap_option = (char *) malloc( 10 );
sprintf( psz_sap_option, "sap" );
}
i_size = 40 + strlen(mux) + strlen(address) +
strlen( psz_sap_option);
psz_opt = (char *)malloc( i_size * sizeof(char) );
sprintf( psz_opt,
":sout=#standard{mux=%s,url=%s,access=%s,%s}",
mux, address,method, psz_sap_option);
msg_Dbg( p_intf, "Sap enabled: %s", psz_sap_option);
if( psz_sap_option ) free( psz_sap_option );
}
else
{
i_size = 40 + strlen(mux) + strlen(address);
psz_opt = (char *)malloc( i_size * sizeof(char) );
sprintf( psz_opt, ":sout=#standard{mux=%s,url=%s,access=%s}",
mux, address,method); mux, address,method);
}
} }
playlist_t *p_playlist = (playlist_t *)vlc_object_find( p_intf, playlist_t *p_playlist = (playlist_t *)vlc_object_find( p_intf,
VLC_OBJECT_PLAYLIST, FIND_ANYWHERE); VLC_OBJECT_PLAYLIST, FIND_ANYWHERE);
if( p_playlist ) if( p_playlist )
{ {
playlist_item_t *p_item = playlist_ItemNew( p_playlist, mrl, ITEM_NAME ); playlist_item_t *p_item = playlist_ItemNew( p_playlist, mrl,
ITEM_NAME );
playlist_ItemAddOption( p_item, psz_opt); playlist_ItemAddOption( p_item, psz_opt);
if( i_from != 0) if( i_from != 0)
{ {
...@@ -1409,6 +1578,11 @@ void WizardDialog::Run() ...@@ -1409,6 +1578,11 @@ void WizardDialog::Run()
sprintf( psz_to, "stop-time=%i", i_to); sprintf( psz_to, "stop-time=%i", i_to);
playlist_ItemAddOption( p_item, psz_to); playlist_ItemAddOption( p_item, psz_to);
} }
char psz_ttl[20];
sprintf( psz_ttl, "ttl=%i",i_ttl );
playlist_ItemAddOption( p_item, psz_ttl );
playlist_AddItem( p_playlist, p_item, PLAYLIST_GO, PLAYLIST_END ); playlist_AddItem( p_playlist, p_item, PLAYLIST_GO, PLAYLIST_END );
vlc_object_release(p_playlist); vlc_object_release(p_playlist);
} }
......
...@@ -578,19 +578,24 @@ public: ...@@ -578,19 +578,24 @@ public:
virtual ~WizardDialog(); virtual ~WizardDialog();
void SetTranscode( char *vcodec, int vb, char *acodec,int ab); void SetTranscode( char *vcodec, int vb, char *acodec,int ab);
void SetMrl( const char *mrl ); void SetMrl( const char *mrl );
void SetTTL( int i_ttl );
void SetPartial( int, int ); void SetPartial( int, int );
void SetStream( char *method, char *address ); void SetStream( char *method, char *address );
void SetTranscodeOut( char *address ); void SetTranscodeOut( char *address );
void SetAction( int i_action ); void SetAction( int i_action );
int GetAction(); int GetAction();
void SetSAP( bool b_enabled, const char *psz_name );
void SetMux( char *mux ); void SetMux( char *mux );
void Run(); void Run();
int i_action; int i_action;
char *method;
private: protected:
int vb,ab; int vb,ab;
int i_from, i_to; int i_from, i_to, i_ttl;
char *vcodec,*acodec,*method,*address,*mrl,*mux; char *vcodec , *acodec , *address , *mrl , *mux ;
char *psz_sap_name;
bool b_sap;
DECLARE_EVENT_TABLE(); DECLARE_EVENT_TABLE();
intf_thread_t *p_intf; intf_thread_t *p_intf;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment