Commit 6d4a1e16 authored by Felix Paul Kühne's avatar Felix Paul Kühne

* additional GUI-fixes

* implemented the streaming-method-tab correctly (forgot that previously...)
* implemented MRL-composition when transcoding (still needs to be done for streaming)
* fixed various other stuff here and there

not usable yet - work will be continued after July 21th

(refs #13)
parent f5e1e36c
...@@ -12,6 +12,7 @@ ...@@ -12,6 +12,7 @@
"t2_chooseStreamOrPlst" = id; "t2_chooseStreamOrPlst" = id;
"t2_enableExtract" = id; "t2_enableExtract" = id;
"t3_addressEntered" = id; "t3_addressEntered" = id;
"t3_strmMthdChanged" = id;
"t4_AudCdcChanged" = id; "t4_AudCdcChanged" = id;
"t4_VidCdcChanged" = id; "t4_VidCdcChanged" = id;
"t4_enblAudTrnscd" = id; "t4_enblAudTrnscd" = id;
...@@ -51,6 +52,7 @@ ...@@ -51,6 +52,7 @@
"o_t3_fld_address" = id; "o_t3_fld_address" = id;
"o_t3_matrix_stmgMhd" = id; "o_t3_matrix_stmgMhd" = id;
"o_t3_txt_destInfo" = id; "o_t3_txt_destInfo" = id;
"o_t3_txt_strgMthdInfo" = id;
"o_t3_txt_text" = id; "o_t3_txt_text" = id;
"o_t3_txt_title" = id; "o_t3_txt_title" = id;
"o_t4_box_audio" = id; "o_t4_box_audio" = id;
...@@ -88,6 +90,7 @@ ...@@ -88,6 +90,7 @@
"o_t8_fld_destination" = id; "o_t8_fld_destination" = id;
"o_t8_fld_encapFormat" = id; "o_t8_fld_encapFormat" = id;
"o_t8_fld_inptStream" = id; "o_t8_fld_inptStream" = id;
"o_t8_fld_mrl" = id;
"o_t8_fld_partExtract" = id; "o_t8_fld_partExtract" = id;
"o_t8_fld_sap" = id; "o_t8_fld_sap" = id;
"o_t8_fld_saveFileTo" = id; "o_t8_fld_saveFileTo" = id;
...@@ -98,6 +101,7 @@ ...@@ -98,6 +101,7 @@
"o_t8_txt_destination" = id; "o_t8_txt_destination" = id;
"o_t8_txt_encapFormat" = id; "o_t8_txt_encapFormat" = id;
"o_t8_txt_inputStream" = id; "o_t8_txt_inputStream" = id;
"o_t8_txt_mrl" = id;
"o_t8_txt_partExtract" = id; "o_t8_txt_partExtract" = id;
"o_t8_txt_sap" = id; "o_t8_txt_sap" = id;
"o_t8_txt_saveFileTo" = id; "o_t8_txt_saveFileTo" = id;
......
...@@ -15,8 +15,8 @@ ...@@ -15,8 +15,8 @@
</array> </array>
<key>IBOpenObjects</key> <key>IBOpenObjects</key>
<array> <array>
<integer>6</integer>
<integer>268</integer> <integer>268</integer>
<integer>6</integer>
</array> </array>
<key>IBSystem Version</key> <key>IBSystem Version</key>
<string>8C40</string> <string>8C40</string>
......
...@@ -444,7 +444,7 @@ static VLCMain *_o_sharedMainInstance = nil; ...@@ -444,7 +444,7 @@ static VLCMain *_o_sharedMainInstance = nil;
[o_msgs_btn_crashlog setTitle: _NS("Open CrashLog")]; [o_msgs_btn_crashlog setTitle: _NS("Open CrashLog")];
/* main menu */ /* main menu */
[o_mi_about setTitle: _NS("About VLC media player")]; [o_mi_about setTitle: _NS("About VLC media player...")];
[o_mi_prefs setTitle: _NS("Preferences...")]; [o_mi_prefs setTitle: _NS("Preferences...")];
[o_mi_add_intf setTitle: _NS("Add Interface")]; [o_mi_add_intf setTitle: _NS("Add Interface")];
[o_mu_add_intf setTitle: _NS("Add Interface")]; [o_mu_add_intf setTitle: _NS("Add Interface")];
......
...@@ -70,6 +70,7 @@ ...@@ -70,6 +70,7 @@
IBOutlet id o_t3_txt_destInfo; IBOutlet id o_t3_txt_destInfo;
IBOutlet id o_t3_txt_text; IBOutlet id o_t3_txt_text;
IBOutlet id o_t3_txt_title; IBOutlet id o_t3_txt_title;
IBOutlet id o_t3_txt_strgMthdInfo;
/* page four ("Transcode 1") */ /* page four ("Transcode 1") */
IBOutlet id o_t4_box_audio; IBOutlet id o_t4_box_audio;
...@@ -122,6 +123,7 @@ ...@@ -122,6 +123,7 @@
IBOutlet id o_t8_fld_trnscdAudio; IBOutlet id o_t8_fld_trnscdAudio;
IBOutlet id o_t8_fld_trnscdVideo; IBOutlet id o_t8_fld_trnscdVideo;
IBOutlet id o_t8_fld_ttl; IBOutlet id o_t8_fld_ttl;
IBOutlet id o_t8_fld_mrl;
IBOutlet id o_t8_txt_destination; IBOutlet id o_t8_txt_destination;
IBOutlet id o_t8_txt_encapFormat; IBOutlet id o_t8_txt_encapFormat;
IBOutlet id o_t8_txt_inputStream; IBOutlet id o_t8_txt_inputStream;
...@@ -134,10 +136,13 @@ ...@@ -134,10 +136,13 @@
IBOutlet id o_t8_txt_trnscdAudio; IBOutlet id o_t8_txt_trnscdAudio;
IBOutlet id o_t8_txt_trnscdVideo; IBOutlet id o_t8_txt_trnscdVideo;
IBOutlet id o_t8_txt_ttl; IBOutlet id o_t8_txt_ttl;
IBOutlet id o_t8_txt_mrl;
NSMutableDictionary * o_userSelections; NSMutableDictionary * o_userSelections;
NSArray * o_videoCodecs; NSArray * o_videoCodecs;
NSArray * o_audioCodecs; NSArray * o_audioCodecs;
NSArray * o_encapFormats;
NSString * o_mrl;
} }
- (IBAction)cancelRun:(id)sender; - (IBAction)cancelRun:(id)sender;
- (IBAction)nextTab:(id)sender; - (IBAction)nextTab:(id)sender;
...@@ -148,6 +153,7 @@ ...@@ -148,6 +153,7 @@
- (IBAction)t2_chooseStreamOrPlst:(id)sender; - (IBAction)t2_chooseStreamOrPlst:(id)sender;
- (IBAction)t2_enableExtract:(id)sender; - (IBAction)t2_enableExtract:(id)sender;
- (IBAction)t3_addressEntered:(id)sender; - (IBAction)t3_addressEntered:(id)sender;
- (IBAction)t3_strmMthdChanged:(id)sender;
- (IBAction)t4_AudCdcChanged:(id)sender; - (IBAction)t4_AudCdcChanged:(id)sender;
- (IBAction)t4_enblAudTrnscd:(id)sender; - (IBAction)t4_enblAudTrnscd:(id)sender;
- (IBAction)t4_enblVidTrnscd:(id)sender; - (IBAction)t4_enblVidTrnscd:(id)sender;
...@@ -159,7 +165,9 @@ ...@@ -159,7 +165,9 @@
- (IBAction)wh_closeSheet:(id)sender; - (IBAction)wh_closeSheet:(id)sender;
+ (VLCWizard *)sharedInstance; + (VLCWizard *)sharedInstance;
- (void)showWizard; - (void)showWizard;
- (void)showSummary; - (void)showSummary;
- (void)resetWizard; - (void)resetWizard;
- (void)createMrl;
@end @end
...@@ -28,8 +28,9 @@ ...@@ -28,8 +28,9 @@
*****************************************************************************/ *****************************************************************************/
/* TODO: /* TODO:
- start of the streaming/transcoding - MRL composition when streaming
- l10n string fixes (both in OSX and WX) - putting the MRL and the next item to the playlist
- l10n string fixes (both in OSX and WX)
- fill the playlist-table on t2 - fill the playlist-table on t2
- implement l10n on t8? - implement l10n on t8?
- see FIXME's - see FIXME's
...@@ -157,6 +158,32 @@ static VLCWizard *_o_sharedInstance = nil; ...@@ -157,6 +158,32 @@ static VLCWizard *_o_sharedInstance = nil;
[o_t4_pop_audioCodec addItemWithTitle:[[o_audioCodecs objectAtIndex:x] objectAtIndex:0]]; [o_t4_pop_audioCodec addItemWithTitle:[[o_audioCodecs objectAtIndex:x] objectAtIndex:0]];
x = (x + 1); x = (x + 1);
} }
/* fill another global array with all information about the encap-formats
* note that the order of the formats inside the g. array is the same as on
* the encap-tab */
NSArray * o_ps;
NSArray * o_ts;
NSArray * o_mpeg;
NSArray * o_ogg;
NSArray * o_raw;
NSArray * o_asf;
NSArray * o_avi;
NSArray * o_mp4;
NSArray * o_mov;
NSArray * o_wav;
o_ps = [NSArray arrayWithObjects: @"ps", @"MPEG PS", _NS("MPEG Program Stream"), nil];
o_ts = [NSArray arrayWithObjects: @"ts", @"MPEG TS", _NS("MPEG Transport Stream"), nil];
o_mpeg = [NSArray arrayWithObjects: @"ps", @"MPEG 1", _NS("MPEG 1 Format"), nil];
o_ogg = [NSArray arrayWithObjects: @"ogg", @"OGG", @"OGG", nil];
o_raw = [NSArray arrayWithObjects: @"raw", @"RAW", @"RAW", nil];
o_asf = [NSArray arrayWithObjects: @"asf", @"ASF", @"ASF", nil];
o_avi = [NSArray arrayWithObjects: @"avi", @"AVI", @"AVI", nil];
o_mp4 = [NSArray arrayWithObjects: @"mp4", @"MP4", @"MPEG4", nil];
o_mov = [NSArray arrayWithObjects: @"mov", @"MOV", @"MOV", nil];
o_wav = [NSArray arrayWithObjects: @"wav", @"WAV", @"WAV", nil];
o_encapFormats = [[NSArray alloc] initWithObjects: o_ps, o_ts, o_mpeg, o_ogg, o_raw, o_asf, o_avi, o_mp4, o_mov, o_wav, nil];
} }
- (void)showWizard - (void)showWizard
...@@ -253,6 +280,7 @@ static VLCWizard *_o_sharedInstance = nil; ...@@ -253,6 +280,7 @@ static VLCWizard *_o_sharedInstance = nil;
[o_t3_txt_destInfo setStringValue: _NS("Enter the address of the computer to stream to")]; [o_t3_txt_destInfo setStringValue: _NS("Enter the address of the computer to stream to")];
[[o_t3_matrix_stmgMhd cellAtRow:1 column:0] setTitle: _NS("UDP Unicast")]; [[o_t3_matrix_stmgMhd cellAtRow:1 column:0] setTitle: _NS("UDP Unicast")];
[[o_t3_matrix_stmgMhd cellAtRow:1 column:1] setTitle: _NS("UDP Multicast")]; [[o_t3_matrix_stmgMhd cellAtRow:1 column:1] setTitle: _NS("UDP Multicast")];
[o_t3_txt_strgMthdInfo setStringValue: _NS("Use this to stream to a single computer")];
/* page four ("Transcode 1") */ /* page four ("Transcode 1") */
[o_t4_title setStringValue: _NS("Transcode")]; [o_t4_title setStringValue: _NS("Transcode")];
...@@ -428,18 +456,31 @@ static VLCWizard *_o_sharedInstance = nil; ...@@ -428,18 +456,31 @@ static VLCWizard *_o_sharedInstance = nil;
} }
/* store the destination and check whether is it empty */ /* store the destination and check whether is it empty */
if( [[o_t3_fld_address stringValue] isEqualToString: @""] ) if(! [o_mode isEqualToString: _NS("HTTP")] )
{ /* complain to the user that "" is no valid dest. */ {
[o_wh_txt_title setStringValue: _NS("No valid destination")]; /* empty field is valid for HTTP */
[o_wh_txt_text setStringValue: _NS("You need to enter " \
"a valid destination you want to stream to. Enter either a " \ if( [[o_t3_fld_address stringValue] isEqualToString: @""] )
"fixed Unicast-IP or a Multicast-IP.\n\n If you don't know " {
"what this means, have a look at the VLC Streaming HOWTO." )];
[NSApp beginSheet: o_wizardhelp_window /* complain to the user that "" is no valid dest. */
modalForWindow: o_wizard_window [o_wh_txt_title setStringValue: _NS("No valid destination")];
modalDelegate: o_wizardhelp_window [o_wh_txt_text setStringValue: _NS("You need to enter " \
didEndSelector: nil "a valid destination you want to stream to. Enter either a " \
contextInfo: nil]; "Unicast-IP or a Multicast-IP.\n\n If you don't know "
"what this means, have a look at the VLC Streaming HOWTO and " \
"the help texts in this window." )];
[NSApp beginSheet: o_wizardhelp_window
modalForWindow: o_wizard_window
modalDelegate: o_wizardhelp_window
didEndSelector: nil
contextInfo: nil];
} else {
/* FIXME: stupid code duplication, should be solved by a GoTo-like-thing -- FK */
[o_userSelections setObject:[o_t3_fld_address stringValue] forKey:@"stmgDest"];
/* let's go to the encap-tab */
[o_tab_pageHolder selectTabViewItemAtIndex:4];
}
} else { } else {
[o_userSelections setObject:[o_t3_fld_address stringValue] forKey:@"stmgDest"]; [o_userSelections setObject:[o_t3_fld_address stringValue] forKey:@"stmgDest"];
/* let's go to the encap-tab */ /* let's go to the encap-tab */
...@@ -739,7 +780,9 @@ static VLCWizard *_o_sharedInstance = nil; ...@@ -739,7 +780,9 @@ static VLCWizard *_o_sharedInstance = nil;
else if ([[[o_tab_pageHolder selectedTabViewItem] label] isEqualToString: @"Encap"]) else if ([[[o_tab_pageHolder selectedTabViewItem] label] isEqualToString: @"Encap"])
{ {
/* get the chosen encap format and store it */ /* get the chosen encap format and store it */
[o_userSelections setObject:[[o_t5_matrix_encap selectedCell] title] forKey:@"encapFormat"]; NSNumber * theNum;
theNum = [NSNumber numberWithInt:[[o_t5_matrix_encap selectedCell] tag]];
[o_userSelections setObject:[theNum stringValue] forKey:@"encapFormat"];
/* show either "Streaming 2" or "Transcode 2" to the user */ /* show either "Streaming 2" or "Transcode 2" to the user */
if ([[o_userSelections objectForKey:@"trnscdOrStrmg"] isEqualToString:@"strmg"]) if ([[o_userSelections objectForKey:@"trnscdOrStrmg"] isEqualToString:@"strmg"])
...@@ -842,10 +885,53 @@ static VLCWizard *_o_sharedInstance = nil; ...@@ -842,10 +885,53 @@ static VLCWizard *_o_sharedInstance = nil;
} }
[o_t8_fld_saveFileTo setStringValue: [o_userSelections objectForKey:@"trnscdFilePath"]]; [o_t8_fld_saveFileTo setStringValue: [o_userSelections objectForKey:@"trnscdFilePath"]];
} }
[o_t8_fld_encapFormat setStringValue: [o_userSelections objectForKey:@"encapFormat"]]; [o_t8_fld_encapFormat setStringValue: [[o_encapFormats objectAtIndex:[[o_userSelections objectForKey:@"encapFormat"] intValue]] objectAtIndex:1]];
[self createMrl];
[o_t8_fld_mrl setStringValue: o_mrl];
[o_tab_pageHolder selectTabViewItemAtIndex:7]; [o_tab_pageHolder selectTabViewItemAtIndex:7];
} }
- (void) createMrl
{
NSMutableString * o_mrl_string = [NSMutableString stringWithString:@""];
if ([[o_userSelections objectForKey:@"trnscdOrStrmg"] isEqualToString:@"strmg"])
{
/* we are streaming, no transcoding allowed atm */
/* FIXME: implementation missing */
} else {
/* we are just transcoding and dumping the stuff to a file */
NSMutableString *o_trnscdCmd = [NSMutableString stringWithString:@""];
if ([[o_userSelections objectForKey:@"trnscdVideo"] isEqualToString:@"YES"])
{
[o_trnscdCmd appendString: @"transcode{"];
[o_trnscdCmd appendFormat: @"vcodec=%s,vb=%i", [[[o_videoCodecs objectAtIndex:[[o_userSelections objectForKey:@"trnscdVideoCodec"] intValue]] objectAtIndex:1] UTF8String], [[o_userSelections objectForKey:@"trnscdVideoBitrate"] intValue]];
if ([[o_userSelections objectForKey:@"trnscdAudio"] isEqualToString:@"YES"])
{
[o_trnscdCmd appendString: @","];
} else
{
[o_trnscdCmd appendString: @"}:"];
}
}
if ([[o_userSelections objectForKey:@"trnscdAudio"] isEqualToString:@"YES"])
{
if ([[o_userSelections objectForKey:@"trnscdVideo"] isEqualToString:@"NO"])
{
/* in case we transcode the audio only, add this */
[o_trnscdCmd appendString: @"transcode{"];
}
[o_trnscdCmd appendFormat: @"acodec=%s,ab=%i}:", [[[o_audioCodecs objectAtIndex:[[o_userSelections objectForKey:@"trnscdAudioCodec"] intValue]] objectAtIndex:1] UTF8String], [[o_userSelections objectForKey:@"trnscdAudioBitrate"] intValue]];
}
[o_mrl_string appendFormat:
@":sout=#%sstandard{mux=%s,url=%s,access=file}", [o_trnscdCmd UTF8String],
[[[o_encapFormats objectAtIndex:[[o_userSelections objectForKey:@"encapFormat"] intValue]] objectAtIndex:0] UTF8String], [[o_userSelections objectForKey:@"trnscdFilePath"] UTF8String]];
}
o_mrl = [[NSString alloc] initWithString: o_mrl_string];
}
- (IBAction)prevTab:(id)sender - (IBAction)prevTab:(id)sender
{ {
if ([[[o_tab_pageHolder selectedTabViewItem] label] isEqualToString: @"Summary"]) if ([[[o_tab_pageHolder selectedTabViewItem] label] isEqualToString: @"Summary"])
...@@ -985,6 +1071,44 @@ static VLCWizard *_o_sharedInstance = nil; ...@@ -985,6 +1071,44 @@ static VLCWizard *_o_sharedInstance = nil;
/* check whether the entered address is valid */ /* check whether the entered address is valid */
} }
- (IBAction)t3_strmMthdChanged:(id)sender
{
/* change the captions of o_t3_txt_destInfo according to the chosen
* streaming method */
NSNumber * o_mode;
o_mode = [[NSNumber alloc] initWithInt:[[o_t3_matrix_stmgMhd selectedCell] tag]];
if( [o_mode intValue] == 2 )
{
[o_t3_txt_destInfo setStringValue: _NS("Enter the local addresses you " \
"want to listen to. Do not enter anything if you want to listen " \
"to all adresses or if you don't understand. This is generally " \
"the best thing to do. Other computers can then access the stream " \
"at http://yourip:8080 by default") ];
[o_t3_txt_strgMthdInfo setStringValue: _NS("Use this to stream to " \
"several computers. This method is less efficient, as the server " \
"needs to send several times the stream.")];
}
else if( [o_mode intValue] == 1 )
{
[o_t3_txt_destInfo setStringValue: _NS("Enter the multicast address " \
"to stream to in this field. This must be an IP address between " \
"224.0.0.0 an 239.255.255.255 For a private use, enter an " \
"address beginning with 239.255")];
[o_t3_txt_strgMthdInfo setStringValue: _NS("Use this to stream to a " \
"dynamic group of computers on a multicast-enabled network. This " \
"is the most efficient method to stream to several computers, but " \
"it does not work over Internet.")];
}
else if( [o_mode intValue] == 0 )
{
[o_t3_txt_destInfo setStringValue: _NS("Enter the address of the " \
"computer to stream to")];
[o_t3_txt_strgMthdInfo setStringValue: _NS("Use this to stream to a " \
"single computer")];
}
[o_mode release];
}
- (IBAction)t4_AudCdcChanged:(id)sender - (IBAction)t4_AudCdcChanged:(id)sender
{ {
/* update codec info */ /* update codec info */
...@@ -1080,16 +1204,17 @@ static VLCWizard *_o_sharedInstance = nil; ...@@ -1080,16 +1204,17 @@ static VLCWizard *_o_sharedInstance = nil;
/* provide a save-to-dialogue, so the user can choose a location for his/her new file */ /* provide a save-to-dialogue, so the user can choose a location for his/her new file */
NSSavePanel * savePanel = [NSSavePanel savePanel]; NSSavePanel * savePanel = [NSSavePanel savePanel];
SEL sel = @selector(t7_getTrnscdDestFile:returnCode:contextInfo:); SEL sel = @selector(t7_getTrnscdDestFile:returnCode:contextInfo:);
[savePanel setRequiredFileType:[[o_encapFormats objectAtIndex:[[o_userSelections objectForKey:@"encapFormat"] intValue]] objectAtIndex:0]];
[savePanel setCanSelectHiddenExtension:YES];
[savePanel beginSheetForDirectory:nil file:nil modalForWindow:o_wizard_window modalDelegate:self didEndSelector:sel contextInfo:nil]; [savePanel beginSheetForDirectory:nil file:nil modalForWindow:o_wizard_window modalDelegate:self didEndSelector:sel contextInfo:nil];
/* FIXME: insert a suffix in file depending on the chosen encap-format instead of providing file:nil */
} }
- (void)t7_getTrnscdDestFile: (NSSavePanel *)sheet returnCode: (int)returnCode contextInfo: (void *)contextInfo - (void)t7_getTrnscdDestFile: (NSSavePanel *)sheet returnCode: (int)returnCode contextInfo: (void *)contextInfo
{ {
if (returnCode == NSOKButton) if (returnCode == NSOKButton)
{ {
/* add a suffix depending on the chosen encap-format and output path to text-field*/
[o_t7_fld_filePath setStringValue:[sheet filename]]; [o_t7_fld_filePath setStringValue:[sheet filename]];
/* FIXME: add a suffix depending on the chosen encap-format, if needed */
} }
} }
...@@ -1105,6 +1230,7 @@ static VLCWizard *_o_sharedInstance = nil; ...@@ -1105,6 +1230,7 @@ static VLCWizard *_o_sharedInstance = nil;
[o_userSelections release]; [o_userSelections release];
[o_videoCodecs release]; [o_videoCodecs release];
[o_audioCodecs release]; [o_audioCodecs release];
[o_encapFormats release];
[super dealloc]; [super dealloc];
} }
......
...@@ -132,7 +132,7 @@ static struct method methods_array[] = ...@@ -132,7 +132,7 @@ static struct method methods_array[] =
"to stream to several computers, but it does not work over Internet."), "to stream to several computers, but it does not work over Internet."),
N_("Enter the multicast address to stream to in this field. " N_("Enter the multicast address to stream to in this field. "
"This must be an IP address between 224.0.0.0 an 239.255.255.255 " "This must be an IP address between 224.0.0.0 an 239.255.255.255 "
"For a private use, enter an address beginning with 239.255."), "For a private use, enter an address beginning with 239.255"),
{ MUX_TS, -1,-1,-1,-1,-1,-1,-1,-1 } }, { MUX_TS, -1,-1,-1,-1,-1,-1,-1,-1 } },
{"http://",N_("HTTP"), {"http://",N_("HTTP"),
N_("Use this to stream to several computers. This method is " N_("Use this to stream to several computers. This method is "
...@@ -158,13 +158,13 @@ static struct encap encaps_array[] = ...@@ -158,13 +158,13 @@ static struct encap encaps_array[] =
{ MUX_PS, "ps","MPEG PS", N_("MPEG Program Stream") }, { MUX_PS, "ps","MPEG PS", N_("MPEG Program Stream") },
{ MUX_TS, "ts","MPEG TS", N_("MPEG Transport Stream") }, { MUX_TS, "ts","MPEG TS", N_("MPEG Transport Stream") },
{ MUX_MPEG, "ps", "MPEG 1", N_("MPEG 1 Format") }, { MUX_MPEG, "ps", "MPEG 1", N_("MPEG 1 Format") },
{ MUX_OGG, "ogg", "OGG", N_("OGG") }, { MUX_OGG, "ogg", "OGG", "OGG" },
{ MUX_RAW, "raw", "RAW", N_("RAW") }, { MUX_RAW, "raw", "RAW", "RAW" },
{ MUX_ASF, "asf","ASF", N_("ASF") }, { MUX_ASF, "asf","ASF", "ASF" },
// { MUX_AVI, "avi","AVI", N_("AVI") }, // { MUX_AVI, "avi","AVI", "AVI" },
{ MUX_MP4, "mp4","MP4", N_("MPEG4") }, { MUX_MP4, "mp4","MP4", "MPEG4" },
{ MUX_MOV, "mov","MOV", N_("MOV") }, { MUX_MOV, "mov","MOV", "MOV" },
{ MUX_WAV, "wav","WAV", N_("WAV") }, { MUX_WAV, "wav","WAV", "WAV" },
{ -1 , NULL,NULL , NULL } /* Do not remove me */ { -1 , NULL,NULL , NULL } /* Do not remove me */
}; };
......
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