Commit 94d20dd3 authored by Felix Paul Kühne's avatar Felix Paul Kühne

* ALL: basic skeleton for a streaming-wizard (refs #13)

    
    done:
    - all items are included with complete l10n support
    - checkboxes and select-file-buttons behave as they are supposed to
    
    todo:
    - implementation of the logic, i.e. handling of the collected values, respective manipulation of the GUI, start of the stream
    - move some arrays to an external header file
    - some GUI things (e.g. radio buttons on page 2, etc. - see FIXMEs)
    - implementation of some help-dialogues (it might be necessary to create a re-usable window in the nib for that, since NSAlert is Panther and Tiger only)
    - l10n string fixes (both in OSX and WX)
    => most of the work still needs to be done
parent 362e6fdf
...@@ -159,6 +159,9 @@ EXTRA_DIST += \ ...@@ -159,6 +159,9 @@ EXTRA_DIST += \
extras/MacOSX/Resources/English.lproj/Preferences.nib/classes.nib \ extras/MacOSX/Resources/English.lproj/Preferences.nib/classes.nib \
extras/MacOSX/Resources/English.lproj/Preferences.nib/info.nib \ extras/MacOSX/Resources/English.lproj/Preferences.nib/info.nib \
extras/MacOSX/Resources/English.lproj/Preferences.nib/keyedobjects.nib \ extras/MacOSX/Resources/English.lproj/Preferences.nib/keyedobjects.nib \
extras/MacOSX/Resources/English.lproj/Wizard.nib/classes.nib \
extras/MacOSX/Resources/English.lproj/Wizard.nib/info.nib \
extras/MacOSX/Resources/English.lproj/Wizard.nib/keyedobjects.nib \
extras/MacOSX/Resources/English.lproj/InfoPlist.strings \ extras/MacOSX/Resources/English.lproj/InfoPlist.strings \
extras/MacOSX/Resources/a52.icns \ extras/MacOSX/Resources/a52.icns \
extras/MacOSX/Resources/aac.icns \ extras/MacOSX/Resources/aac.icns \
...@@ -532,6 +535,8 @@ VLC-release.app: vlc ...@@ -532,6 +535,8 @@ VLC-release.app: vlc
vout.h \ vout.h \
voutqt.m \ voutqt.m \
voutgl.m \ voutgl.m \
wizard.h \
wizard.m \
vout.m; do \ vout.m; do \
cp "$(srcdir)/modules/gui/macosx/$$i" \ cp "$(srcdir)/modules/gui/macosx/$$i" \
$(top_builddir)/tmp/modules/gui/macosx; \ $(top_builddir)/tmp/modules/gui/macosx; \
...@@ -629,6 +634,8 @@ VLC.app: vlc ...@@ -629,6 +634,8 @@ VLC.app: vlc
vout.h \ vout.h \
voutqt.m \ voutqt.m \
voutgl.m \ voutgl.m \
wizard.h \
wizard.m \
vout.m; do \ vout.m; do \
cp "$(srcdir)/modules/gui/macosx/$$i" \ cp "$(srcdir)/modules/gui/macosx/$$i" \
$(top_builddir)/tmp/modules/gui/macosx; \ $(top_builddir)/tmp/modules/gui/macosx; \
......
...@@ -113,6 +113,7 @@ ...@@ -113,6 +113,7 @@
openRecentItem = id; openRecentItem = id;
openWebsite = id; openWebsite = id;
reportABug = id; reportABug = id;
showWizard = id;
timesliderUpdate = id; timesliderUpdate = id;
togglePlaylist = id; togglePlaylist = id;
viewAbout = id; viewAbout = id;
......
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
<plist version="1.0"> <plist version="1.0">
<dict> <dict>
<key>IBDocumentLocation</key> <key>IBDocumentLocation</key>
<string>101 241 496 270 0 0 800 578 </string> <string>91 42 496 270 0 0 800 578 </string>
<key>IBEditorPositions</key> <key>IBEditorPositions</key>
<dict> <dict>
<key>1617</key> <key>1617</key>
...@@ -11,7 +11,7 @@ ...@@ -11,7 +11,7 @@
<key>2197</key> <key>2197</key>
<string>214 442 596 144 0 0 1024 746 </string> <string>214 442 596 144 0 0 1024 746 </string>
<key>29</key> <key>29</key>
<string>72 702 419 44 0 0 1024 746 </string> <string>205 505 419 44 0 0 800 578 </string>
<key>915</key> <key>915</key>
<string>730 416 178 211 0 0 1024 746 </string> <string>730 416 178 211 0 0 1024 746 </string>
</dict> </dict>
...@@ -21,6 +21,7 @@ ...@@ -21,6 +21,7 @@
<array/> <array/>
<key>IBOpenObjects</key> <key>IBOpenObjects</key>
<array> <array>
<integer>29</integer>
<integer>2029</integer> <integer>2029</integer>
<integer>21</integer> <integer>21</integer>
</array> </array>
......
{
IBClasses = (
{CLASS = FirstResponder; LANGUAGE = ObjC; SUPERCLASS = NSObject; },
{
ACTIONS = {
cancelRun = id;
nextTab = id;
prevTab = id;
"t1_mrInfo_streaming" = id;
"t1_mrInfo_transcode" = id;
"t2_addNewStream" = id;
"t2_chooseStreamOrPlst" = id;
"t2_enableExtract" = id;
"t3_addressEntered" = id;
"t4_AudCdcChanged" = id;
"t4_VidCdcChanged" = id;
"t4_enblAudTrnscd" = id;
"t4_enblVidTrnscd" = id;
"t6_enblSapAnnce" = id;
"t6_mrInfo_sap" = id;
"t6_mrInfo_ttl" = id;
"t7_selectTrnscdDestFile" = id;
};
CLASS = VLCWizard;
LANGUAGE = ObjC;
OUTLETS = {
"o_btn_backward" = id;
"o_btn_cancel" = id;
"o_btn_forward" = id;
"o_t1_btn_mrInfo_strmg" = id;
"o_t1_btn_mrInfo_trnscd" = id;
"o_t1_rdo_streaming" = id;
"o_t1_rdo_transcode" = id;
"o_t1_txt_notice" = id;
"o_t1_txt_text" = id;
"o_t1_txt_title" = id;
"o_t2_box_prtExtrct" = id;
"o_t2_btn_chooseFile" = id;
"o_t2_ckb_enblPartExtrct" = id;
"o_t2_fld_pathToNewStrm" = id;
"o_t2_fld_prtExtrctFrom" = id;
"o_t2_fld_prtExtrctTo" = id;
"o_t2_rdo_exstPlstItm" = id;
"o_t2_rdo_newStrm" = id;
"o_t2_tbl_plst" = id;
"o_t2_text" = id;
"o_t2_title" = id;
"o_t2_txt_prtExtrctFrom" = id;
"o_t2_txt_prtExtrctTo" = id;
"o_t3_box_dest" = id;
"o_t3_box_strmgMthd" = id;
"o_t3_fld_address" = id;
"o_t3_matrix_stmgMhd" = id;
"o_t3_txt_destInfo" = id;
"o_t3_txt_text" = id;
"o_t3_txt_title" = id;
"o_t4_box_audio" = id;
"o_t4_box_video" = id;
"o_t4_ckb_audio" = id;
"o_t4_ckb_video" = id;
"o_t4_pop_audioBitrate" = id;
"o_t4_pop_audioCodec" = id;
"o_t4_pop_videoBitrate" = id;
"o_t4_pop_videoCodec" = id;
"o_t4_text" = id;
"o_t4_title" = id;
"o_t4_txt_bitrateAudio" = id;
"o_t4_txt_bitrateVideo" = id;
"o_t4_txt_codecAudio" = id;
"o_t4_txt_codecVideo" = id;
"o_t4_txt_hintAudio" = id;
"o_t4_txt_hintVideo" = id;
"o_t5_matrix_encap" = id;
"o_t5_text" = id;
"o_t5_title" = id;
"o_t6_btn_mrInfo_sap" = id;
"o_t6_btn_mrInfo_ttl" = id;
"o_t6_ckb_sap" = id;
"o_t6_fld_sap" = id;
"o_t6_fld_ttl" = id;
"o_t6_text" = id;
"o_t6_title" = id;
"o_t6_txt_ttl" = id;
"o_t7_btn_chooseFile" = id;
"o_t7_fld_filePath" = id;
"o_t7_text" = id;
"o_t7_title" = id;
"o_t7_txt_saveFileTo" = id;
"o_tab_pageHolder" = id;
"o_wizard_window" = id;
};
SUPERCLASS = NSObject;
}
);
IBVersion = 1;
}
\ No newline at end of file
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple Computer//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>IBDocumentLocation</key>
<string>62 303 356 241 0 0 800 578 </string>
<key>IBFramework Version</key>
<string>364.0</string>
<key>IBLockedObjects</key>
<array>
<integer>6</integer>
<integer>14</integer>
<integer>10</integer>
</array>
<key>IBOpenObjects</key>
<array>
<integer>6</integer>
</array>
<key>IBSystem Version</key>
<string>7W98</string>
</dict>
</plist>
...@@ -812,6 +812,7 @@ ...@@ -812,6 +812,7 @@
DCA00AA9075F948800E6BF46, DCA00AA9075F948800E6BF46,
DCF358BB077F10BA007DB450, DCF358BB077F10BA007DB450,
DCA693C30789DF8700139EC6, DCA693C30789DF8700139EC6,
DCFCCDB9085CE18F001E36AF,
); );
isa = PBXResourcesBuildPhase; isa = PBXResourcesBuildPhase;
runOnlyForDeploymentPostprocessing = 0; runOnlyForDeploymentPostprocessing = 0;
...@@ -892,6 +893,8 @@ ...@@ -892,6 +893,8 @@
8ED6C28803E2EB1C0059A3A7, 8ED6C28803E2EB1C0059A3A7,
8E9CA1A506D7DEE800B7186C, 8E9CA1A506D7DEE800B7186C,
8E9CA1A606D7DEE800B7186C, 8E9CA1A606D7DEE800B7186C,
DC769AB8085DF0DB001A838D,
DC769AB7085DF0DB001A838D,
); );
isa = PBXGroup; isa = PBXGroup;
name = Classes; name = Classes;
...@@ -2154,6 +2157,24 @@ ...@@ -2154,6 +2157,24 @@
//DC2 //DC2
//DC3 //DC3
//DC4 //DC4
DC769AB7085DF0DB001A838D = {
fileEncoding = 5;
isa = PBXFileReference;
lastKnownFileType = sourcecode.c.objc;
name = wizard.m;
path = "/Users/felix/Desktop/Programming/VideoLAN/vlc-trunk/modules/gui/macosx/wizard.m";
refType = 0;
sourceTree = "<absolute>";
};
DC769AB8085DF0DB001A838D = {
fileEncoding = 5;
isa = PBXFileReference;
lastKnownFileType = sourcecode.c.h;
name = wizard.h;
path = "/Users/felix/Desktop/Programming/VideoLAN/vlc-trunk/modules/gui/macosx/wizard.h";
refType = 0;
sourceTree = "<absolute>";
};
DCA00AA7075F948800E6BF46 = { DCA00AA7075F948800E6BF46 = {
children = ( children = (
DCA00AA8075F948800E6BF46, DCA00AA8075F948800E6BF46,
...@@ -2238,12 +2259,37 @@ ...@@ -2238,12 +2259,37 @@
F74F13EA02C2A79C01EE194C, F74F13EA02C2A79C01EE194C,
DCF358B9077F10BA007DB450, DCF358B9077F10BA007DB450,
DCA693C10789DF8700139EC6, DCA693C10789DF8700139EC6,
DCFCCDB7085CE18F001E36AF,
); );
isa = PBXGroup; isa = PBXGroup;
name = nibs; name = nibs;
refType = 4; refType = 4;
sourceTree = "<group>"; sourceTree = "<group>";
}; };
DCFCCDB7085CE18F001E36AF = {
children = (
DCFCCDB8085CE18F001E36AF,
);
isa = PBXVariantGroup;
name = Wizard.nib;
path = "";
refType = 4;
sourceTree = "<group>";
};
DCFCCDB8085CE18F001E36AF = {
isa = PBXFileReference;
lastKnownFileType = wrapper.nib;
name = English;
path = Resources/English.lproj/Wizard.nib;
refType = 4;
sourceTree = "<group>";
};
DCFCCDB9085CE18F001E36AF = {
fileRef = DCFCCDB7085CE18F001E36AF;
isa = PBXBuildFile;
settings = {
};
};
//DC0 //DC0
//DC1 //DC1
//DC2 //DC2
......
...@@ -28,5 +28,7 @@ SOURCES_macosx = \ ...@@ -28,5 +28,7 @@ SOURCES_macosx = \
voutqt.m \ voutqt.m \
voutgl.m \ voutgl.m \
vout.h \ vout.h \
wizard.h \
wizard.m \
$(NULL) $(NULL)
...@@ -90,7 +90,9 @@ struct intf_sys_t ...@@ -90,7 +90,9 @@ struct intf_sys_t
id o_prefs; /* VLCPrefs */ id o_prefs; /* VLCPrefs */
id o_about; /* VLAboutBox */ id o_about; /* VLAboutBox */
id o_open; /* VLCOpen */ id o_open; /* VLCOpen */
id o_wizard; /* VLCWizard */
BOOL nib_open_loaded; /* reference to the open-nib */ BOOL nib_open_loaded; /* reference to the open-nib */
BOOL nib_wizard_loaded; /* reference to the wizard-nib */
IBOutlet id o_window; /* main window */ IBOutlet id o_window; /* main window */
IBOutlet id o_playlist_view;/* playlist view */ IBOutlet id o_playlist_view;/* playlist view */
...@@ -154,6 +156,7 @@ struct intf_sys_t ...@@ -154,6 +156,7 @@ struct intf_sys_t
IBOutlet id o_mi_open_net; IBOutlet id o_mi_open_net;
IBOutlet id o_mi_open_recent; IBOutlet id o_mi_open_recent;
IBOutlet id o_mi_open_recent_cm; IBOutlet id o_mi_open_recent_cm;
IBOutlet id o_mi_open_wizard;
IBOutlet id o_mu_edit; IBOutlet id o_mu_edit;
IBOutlet id o_mi_cut; IBOutlet id o_mi_cut;
...@@ -286,6 +289,8 @@ struct intf_sys_t ...@@ -286,6 +289,8 @@ struct intf_sys_t
- (IBAction)intfOpenDisc:(id)sender; - (IBAction)intfOpenDisc:(id)sender;
- (IBAction)intfOpenNet:(id)sender; - (IBAction)intfOpenNet:(id)sender;
- (IBAction)showWizard:(id)sender;
- (IBAction)viewAbout:(id)sender; - (IBAction)viewAbout:(id)sender;
- (IBAction)viewPreferences:(id)sender; - (IBAction)viewPreferences:(id)sender;
- (IBAction)closeError:(id)sender; - (IBAction)closeError:(id)sender;
......
...@@ -38,6 +38,7 @@ ...@@ -38,6 +38,7 @@
#include "controls.h" #include "controls.h"
#include "about.h" #include "about.h"
#include "open.h" #include "open.h"
#include "wizard.h"
/***************************************************************************** /*****************************************************************************
* Local prototypes. * Local prototypes.
...@@ -296,6 +297,7 @@ static VLCMain *_o_sharedMainInstance = nil; ...@@ -296,6 +297,7 @@ static VLCMain *_o_sharedMainInstance = nil;
o_about = [[VLAboutBox alloc] init]; o_about = [[VLAboutBox alloc] init];
o_prefs = nil; o_prefs = nil;
o_open = [[VLCOpen alloc] init]; o_open = [[VLCOpen alloc] init];
o_wizard = [[VLCWizard alloc] init];
i_lastShownVolume = -1; i_lastShownVolume = -1;
return _o_sharedMainInstance; return _o_sharedMainInstance;
...@@ -459,6 +461,7 @@ static VLCMain *_o_sharedMainInstance = nil; ...@@ -459,6 +461,7 @@ static VLCMain *_o_sharedMainInstance = nil;
[o_mi_open_net setTitle: _NS("Open Network...")]; [o_mi_open_net setTitle: _NS("Open Network...")];
[o_mi_open_recent setTitle: _NS("Open Recent")]; [o_mi_open_recent setTitle: _NS("Open Recent")];
[o_mi_open_recent_cm setTitle: _NS("Clear Menu")]; [o_mi_open_recent_cm setTitle: _NS("Clear Menu")];
[o_mi_open_wizard setTitle: _NS("Wizard...")];
[o_mu_edit setTitle: _NS("Edit")]; [o_mu_edit setTitle: _NS("Edit")];
[o_mi_cut setTitle: _NS("Cut")]; [o_mi_cut setTitle: _NS("Cut")];
...@@ -1421,6 +1424,18 @@ static VLCMain *_o_sharedMainInstance = nil; ...@@ -1421,6 +1424,18 @@ static VLCMain *_o_sharedMainInstance = nil;
} }
} }
- (IBAction)showWizard:(id)sender
{
if (!nib_wizard_loaded)
{
nib_wizard_loaded = [NSBundle loadNibNamed:@"Wizard" owner:self];
[o_wizard initStrings];
[o_wizard showWizard];
} else {
[o_wizard showWizard];
}
}
- (IBAction)viewAbout:(id)sender - (IBAction)viewAbout:(id)sender
{ {
[o_about showPanel]; [o_about showPanel];
...@@ -1557,12 +1572,13 @@ static VLCMain *_o_sharedMainInstance = nil; ...@@ -1557,12 +1572,13 @@ static VLCMain *_o_sharedMainInstance = nil;
else else
{ {
o_rect.size.height = 500; o_rect.size.height = 500;
if ( o_rect.size.width == [o_window minSize].width )
{
o_rect.size.width = 500;
}
} }
if ( o_rect.size.width == [o_window minSize].width )
{
o_rect.size.width = 500;
}
o_rect.size.height = (o_size_with_playlist.height > 200) ? o_rect.size.height = (o_size_with_playlist.height > 200) ?
o_size_with_playlist.height : 500; o_size_with_playlist.height : 500;
o_rect.origin.x = [o_window frame].origin.x; o_rect.origin.x = [o_window frame].origin.x;
...@@ -1574,6 +1590,7 @@ static VLCMain *_o_sharedMainInstance = nil; ...@@ -1574,6 +1590,7 @@ static VLCMain *_o_sharedMainInstance = nil;
{ {
/* make small */ /* make small */
o_rect.size.height = [o_window minSize].height; o_rect.size.height = [o_window minSize].height;
o_rect.size.width = [o_window minSize].width;
o_rect.origin.x = [o_window frame].origin.x; o_rect.origin.x = [o_window frame].origin.x;
/* Calculate the position of the lower right corner after resize */ /* Calculate the position of the lower right corner after resize */
o_rect.origin.y = [o_window frame].origin.y + o_rect.origin.y = [o_window frame].origin.y +
......
/*****************************************************************************
* wizard.h: MacOS X Streaming Wizard
*****************************************************************************
* Copyright (C) 2005 VideoLAN
* $Id$
*
* Authors: Felix Khne <fkuehne@users.sf.net>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111, USA.
*****************************************************************************/
/*****************************************************************************
* VLCWizard
*****************************************************************************/
#import <Cocoa/Cocoa.h>
@interface VLCWizard : NSObject
{
IBOutlet id o_btn_backward;
IBOutlet id o_btn_cancel;
IBOutlet id o_btn_forward;
IBOutlet id o_t1_btn_mrInfo_strmg;
IBOutlet id o_t1_btn_mrInfo_trnscd;
IBOutlet id o_t1_rdo_streaming;
IBOutlet id o_t1_rdo_transcode;
IBOutlet id o_t1_txt_notice;
IBOutlet id o_t1_txt_text;
IBOutlet id o_t1_txt_title;
IBOutlet id o_t2_box_prtExtrct;
IBOutlet id o_t2_ckb_enblPartExtrct;
IBOutlet id o_t2_btn_chooseFile;
IBOutlet id o_t2_fld_pathToNewStrm;
IBOutlet id o_t2_fld_prtExtrctFrom;
IBOutlet id o_t2_fld_prtExtrctTo;
IBOutlet id o_t2_rdo_exstPlstItm;
IBOutlet id o_t2_rdo_newStrm;
IBOutlet id o_t2_tbl_plst;
IBOutlet id o_t2_text;
IBOutlet id o_t2_title;
IBOutlet id o_t2_txt_prtExtrctFrom;
IBOutlet id o_t2_txt_prtExtrctTo;
IBOutlet id o_t3_box_dest;
IBOutlet id o_t3_box_strmgMthd;
IBOutlet id o_t3_fld_address;
IBOutlet id o_t3_matrix_stmgMhd;
IBOutlet id o_t3_txt_destInfo;
IBOutlet id o_t3_txt_text;
IBOutlet id o_t3_txt_title;
IBOutlet id o_t4_box_audio;
IBOutlet id o_t4_box_video;
IBOutlet id o_t4_ckb_audio;
IBOutlet id o_t4_ckb_video;
IBOutlet id o_t4_pop_audioBitrate;
IBOutlet id o_t4_pop_audioCodec;
IBOutlet id o_t4_pop_videoBitrate;
IBOutlet id o_t4_pop_videoCodec;
IBOutlet id o_t4_text;
IBOutlet id o_t4_title;
IBOutlet id o_t4_txt_audioBitrate;
IBOutlet id o_t4_txt_videoBitrate;
IBOutlet id o_t4_txt_audioCodec;
IBOutlet id o_t4_txt_videoCodec;
IBOutlet id o_t4_txt_hintAudio;
IBOutlet id o_t4_txt_hintVideo;
IBOutlet id o_t5_matrix_encap;
IBOutlet id o_t5_text;
IBOutlet id o_t5_title;
IBOutlet id o_t6_ckb_sap;
IBOutlet id o_t6_fld_sap;
IBOutlet id o_t6_fld_ttl;
IBOutlet id o_t6_text;
IBOutlet id o_t6_title;
IBOutlet id o_t6_txt_ttl;
IBOutlet id o_t6_btn_mrInfo_ttl;
IBOutlet id o_t6_btn_mrInfo_sap;
IBOutlet id o_t7_btn_chooseFile;
IBOutlet id o_t7_fld_filePath;
IBOutlet id o_t7_text;
IBOutlet id o_t7_title;
IBOutlet id o_t7_txt_saveFileTo;
IBOutlet id o_tab_pageHolder;
IBOutlet id o_wizard_window;
}
- (IBAction)cancelRun:(id)sender;
- (IBAction)nextTab:(id)sender;
- (IBAction)prevTab:(id)sender;
- (IBAction)t1_mrInfo_streaming:(id)sender;
- (IBAction)t1_mrInfo_transcode:(id)sender;
- (IBAction)t2_addNewStream:(id)sender;
- (IBAction)t2_chooseStreamOrPlst:(id)sender;
- (IBAction)t2_enableExtract:(id)sender;
- (IBAction)t3_addressEntered:(id)sender;
- (IBAction)t4_AudCdcChanged:(id)sender;
- (IBAction)t4_enblAudTrnscd:(id)sender;
- (IBAction)t4_enblVidTrnscd:(id)sender;
- (IBAction)t4_VidCdcChanged:(id)sender;
- (IBAction)t6_enblSapAnnce:(id)sender;
- (IBAction)t6_mrInfo_ttl:(id)sender;
- (IBAction)t6_mrInfo_sap:(id)sender;
- (IBAction)t7_selectTrnscdDestFile:(id)sender;
+ (VLCWizard *)sharedInstance;
- (void)showWizard;
@end
This diff is collapsed.
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