/*****************************************************************************
* extended.m: MacOS X Extended interface panel
*****************************************************************************
- * Copyright (C) 2005-2006 the VideoLAN team
+ * Copyright (C) 2005-2007 the VideoLAN team
* $Id$
*
- * Authors: Felix Kühne <fkuehne@users.sf.net>
+ * Authors: Felix Paul Kühne <fkuehne@videolan.org>
*
* 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
*****************************************************************************/
-/*****************************************************************************
- * Note:
- * the code used to bind with VLC's modules is heavily based upon
- * ../wxwidgets/extrapanel.cpp, written by Clément Stenac.
- * the code used to insert/remove the views was inspired by intf.m,
- * written by Derk-Jan Hartman and Benjamin Pracht.
- * (all 3 are members of the VideoLAN team)
- *****************************************************************************/
-
-
/*****************************************************************************
* Preamble
*****************************************************************************/
[o_lbl_audioFlts setStringValue: _NS("Audio filters")];
[o_lbl_videoFlts setStringValue: _NS("Video filters")];
[o_lbl_adjustImage setStringValue: _NS("Image adjustment")];
- [o_btn_vidFlts_mrInfo setTitle: _NS("More Info")];
+ [o_btn_vidFlts_mrInfo setToolTip: _NS("Shows more information about the available video filters.")];
[o_ckb_wave setTitle: _NS("Wave")];
[o_ckb_ripple setTitle: _NS("Ripple")];
[o_ckb_psycho setTitle: _NS("Psychedelic")];
[o_lbl_hue setStringValue: _NS("Hue")];
[o_lbl_saturation setStringValue: _NS("Saturation")];
[o_lbl_opaque setStringValue: _NS("Opaqueness")];
-
+
}
- (void)awakeFromNib
free( psz_vfilters );
}
-
+
/* set the video-filter checkboxes to the correct values */
char * psz_vifilters;
psz_vifilters = config_GetPsz( p_intf, "video-filter" );
free( psz_vifilters );
}
-
+
/* set the audio-filter-checkboxes to the values taken from the prefs */
char * psz_afilters;
psz_afilters = config_GetPsz( p_intf, "audio-filter" );
{
[o_ckb_hdphnVirt setState: (int)strstr( psz_afilters, "headphone" ) ];
[o_ckb_vlme_norm setState: (int)strstr( psz_afilters, "normvol" ) ];
-
+
free( psz_afilters );
}
}
/* collaps all views so Cocoa saves the window position correctly */
if( o_adjImg_expanded )
{
- [self extWin_exp_adjImg: nil];
+ [self expandAdjustImage: nil];
}
if( o_audFlts_expanded )
{
- [self extWin_exp_audFlts: nil];
+ [self expandAudioFilters: nil];
}
if( o_vidFlts_expanded )
{
- [self extWin_exp_vidFlts: nil];
+ [self expandVideoFilters: nil];
}
}
}
float f_value;
-
+
f_value = config_GetFloat( p_intf, "saturation" );
if( f_value > 0 && f_value < 5 )
{
[o_extended_window makeKeyAndOrderFront:nil];
}
-- (IBAction)adjImg_Enbl:(id)sender
+- (IBAction)enableAdjustImage:(id)sender
{
/* en-/disable the sliders */
if ([o_ckb_enblAdjustImg state] == NSOnState)
}
}
-- (IBAction)adjImg_rstrDefaults:(id)sender
+- (IBAction)restoreDefaultsForAdjustImage:(id)sender
{
/* reset the sliders */
[o_sld_brightness setIntValue: 100];
[o_sld_gamma setIntValue: 10];
[o_sld_hue setIntValue: 0];
[o_sld_saturation setIntValue: 100];
-
+ [o_sld_opaque setIntValue: 100];
+
/* transmit the values */
- [self adjImg_sliders: o_sld_brightness];
- [self adjImg_sliders: o_sld_contrast];
- [self adjImg_sliders: o_sld_gamma];
- [self adjImg_sliders: o_sld_hue];
- [self adjImg_sliders: o_sld_saturation];
+ [self sliderActionAdjustImage: o_sld_brightness];
+ [self sliderActionAdjustImage: o_sld_contrast];
+ [self sliderActionAdjustImage: o_sld_gamma];
+ [self sliderActionAdjustImage: o_sld_hue];
+ [self sliderActionAdjustImage: o_sld_saturation];
+ [self opaqueSliderAction: o_sld_opaque];
}
-- (IBAction)adjImg_sliders:(id)sender
+- (IBAction)sliderActionAdjustImage:(id)sender
{
/* read-out the sliders' values and apply them */
intf_thread_t * p_intf = VLCIntf;
}
/* change the opaqueness of the vouts */
-- (IBAction)adjImg_opaque:(id)sender
+- (IBAction)opaqueSliderAction:(id)sender
{
vlc_value_t val;
id o_window = [NSApp keyWindow];
while ((o_window = [o_enumerator nextObject]))
{
- if( [[o_window className] isEqualToString: @"VLCWindow"] ||
+ if( [[o_window className] isEqualToString: @"VLCVoutWindow"] ||
[[[VLCMain sharedInstance] getEmbeddedList]
windowContainsEmbedded: o_window])
{
}
vlc_object_release( p_vout );
}
-
+
/* store to prefs */
config_PutFloat( p_playlist , "macosx-opaqueness" , val.f_float );
-
+
vlc_object_release( p_playlist );
o_config_changed = YES;
}
-- (IBAction)audFtls_hdphnVirt:(id)sender
+- (IBAction)enableHeadphoneVirtualizer:(id)sender
{
/* en-/disable headphone virtualisation */
if ([o_ckb_hdphnVirt state] == NSOnState)
}
}
-- (IBAction)audFtls_maxLevelSld:(id)sender
+- (IBAction)sliderActionMaximumAudioLevel:(id)sender
{
/* read-out the slider's value and apply it */
intf_thread_t * p_intf = VLCIntf;
o_config_changed = YES;
}
-- (IBAction)audFtls_vlmeNorm:(id)sender
+- (IBAction)enableVolumeNormalization:(id)sender
{
/* en-/disable volume normalisation */
if ([o_ckb_vlme_norm state] == NSOnState)
}
}
-- (IBAction)extWin_exp_adjImg:(id)sender
+- (IBAction)expandAdjustImage:(id)sender
{
/* expand or collapse adjImg */
NSRect o_win_rect = [o_extended_window frame];
NSRect o_box_audFlts_rect = [o_box_audFlts frame];
NSRect o_box_vidFlts_rect = [o_box_vidFlts frame];
NSRect o_box_adjImg_rect = [o_box_adjImg frame];
-
+
if (o_adjImg_expanded)
{
/* move the window contents upwards (partially done through settings
o_win_rect.origin.y = [o_extended_window frame].origin.y + 193;
o_box_audFlts_rect.origin.y = o_box_audFlts_rect.origin.y + 193;
o_box_vidFlts_rect.origin.y = o_box_vidFlts_rect.origin.y + 193;
-
+
/* remove the inserted view */
[o_adjustImg_view removeFromSuperviewWithoutNeedingDisplay];
}else{
-
+
/* move the window contents downwards and resize the window */
o_win_rect.size.height = o_win_rect.size.height + 193;
o_win_rect.origin.y = [o_extended_window frame].origin.y - 193;
o_box_audFlts_rect.origin.y = o_box_audFlts_rect.origin.y - 193;
o_box_vidFlts_rect.origin.y = o_box_vidFlts_rect.origin.y - 193;
}
-
+
[o_box_audFlts setFrameFromContentFrame: o_box_audFlts_rect];
[o_box_vidFlts setFrameFromContentFrame: o_box_vidFlts_rect];
[o_extended_window displayIfNeeded];
[o_extended_window setFrame: o_win_rect display:YES animate: YES];
-
+
if (o_adjImg_expanded)
{
o_box_adjImg_rect.size.height = [o_box_adjImg frame].size.height - 193;
[o_box_adjImg setFrameFromContentFrame: o_box_adjImg_rect];
}
-- (IBAction)extWin_exp_audFlts:(id)sender
+- (IBAction)expandAudioFilters:(id)sender
{
/* expand or collapse audFlts */
NSRect o_win_rect = [o_extended_window frame];
NSRect o_box_audFlts_rect = [o_box_audFlts frame];
-
+
if (o_audFlts_expanded)
{
/* move the window contents upwards (partially done through settings
* inside the nib) and resize the window */
o_win_rect.size.height = o_win_rect.size.height - 66;
o_win_rect.origin.y = [o_extended_window frame].origin.y + 66;
-
+
/* remove the inserted view */
[o_audioFlts_view removeFromSuperviewWithoutNeedingDisplay];
}else{
}
[o_extended_window displayIfNeeded];
[o_extended_window setFrame: o_win_rect display:YES animate: YES];
-
-
+
+
if (o_audFlts_expanded)
{
o_box_audFlts_rect.size.height = [o_box_audFlts frame].size.height - 66;
[o_box_audFlts setFrameFromContentFrame: o_box_audFlts_rect];
}
-- (IBAction)extWin_exp_vidFlts:(id)sender
+- (IBAction)expandVideoFilters:(id)sender
{
/* expand or collapse vidFlts */
NSRect o_win_rect = [o_extended_window frame];
NSRect o_box_audFlts_rect = [o_box_audFlts frame];
NSRect o_box_vidFlts_rect = [o_box_vidFlts frame];
-
+
if (o_vidFlts_expanded)
{
/* move the window contents upwards (partially done through settings
* inside the nib) and resize the window */
- o_win_rect.size.height = o_win_rect.size.height - 188;
- o_win_rect.origin.y = [o_extended_window frame].origin.y + 188;
- o_box_audFlts_rect.origin.y = o_box_audFlts_rect.origin.y + 188;
-
+ o_win_rect.size.height = o_win_rect.size.height - 172;
+ o_win_rect.origin.y = [o_extended_window frame].origin.y + 172;
+ o_box_audFlts_rect.origin.y = o_box_audFlts_rect.origin.y + 172;
+
/* remove the inserted view */
[o_videoFilters_view removeFromSuperviewWithoutNeedingDisplay];
}else{
-
+
/* move the window contents downwards and resize the window */
- o_win_rect.size.height = o_win_rect.size.height + 188;
- o_win_rect.origin.y = [o_extended_window frame].origin.y - 188;
- o_box_audFlts_rect.origin.y = o_box_audFlts_rect.origin.y - 188;
+ o_win_rect.size.height = o_win_rect.size.height + 172;
+ o_win_rect.origin.y = [o_extended_window frame].origin.y - 172;
+ o_box_audFlts_rect.origin.y = o_box_audFlts_rect.origin.y - 172;
}
-
+
[o_box_audFlts setFrameFromContentFrame: o_box_audFlts_rect];
[o_extended_window displayIfNeeded];
[o_extended_window setFrame: o_win_rect display:YES animate: YES];
-
+
if (o_vidFlts_expanded)
{
- o_box_vidFlts_rect.size.height = [o_box_vidFlts frame].size.height - 188;
+ o_box_vidFlts_rect.size.height = [o_box_vidFlts frame].size.height - 172;
o_vidFlts_expanded = NO;
} else {
/* insert view */
- o_box_vidFlts_rect.size.height = [o_box_vidFlts frame].size.height + 188;
- [o_videoFilters_view setFrame: NSMakeRect( 20, -10, 370, 188)];
+ o_box_vidFlts_rect.size.height = [o_box_vidFlts frame].size.height + 172;
+ [o_videoFilters_view setFrame: NSMakeRect( 20, -10, 370, 172)];
[o_videoFilters_view setNeedsDisplay:YES];
[o_videoFilters_view setAutoresizesSubviews: YES];
[[o_box_vidFlts contentView] addSubview: o_videoFilters_view];
[o_box_vidFlts setFrameFromContentFrame: o_box_vidFlts_rect];
}
-- (IBAction)vidFlts:(id)sender
+- (IBAction)videoFilterAction:(id)sender
{
/* en-/disable video filters */
if (sender == o_ckb_blur)
else {
/* this shouldn't happen */
- msg_Warn (VLCIntf, "cannot find switched video-filter");
+ msg_Err( VLCIntf, "cannot find switched video-filter" );
}
}
-- (IBAction)vidFlts_mrInfo:(id)sender
+- (IBAction)moreInfoVideoFilters:(id)sender
{
/* show info sheet */
- NSBeginInformationalAlertSheet(_NS("More Information"), _NS("OK"), @"", @"",
- o_extended_window, nil, nil, nil, nil, _NS("This panel allows to "
- "select video effects filters to apply.\n"
- "The filters can be configured individually in the Preferences, in "
+ NSBeginInformationalAlertSheet(_NS("About the video filters"), _NS("OK"), @"", @"",
+ o_extended_window, nil, nil, nil, nil, _NS("This panel allows "
+ "on-the-fly selection of various video effects.\n"
+ "These filters can be configured individually in the Preferences, in "
"the subsections of Video/Filters.\n"
"To choose the order in which the filter are applied, a filter "
"option string can be set in the Preferences, Video / Filters section."));
* methods to communicate changes to VLC's core
*****************************************************************************/
-- (void)changeVoutFiltersString:(char *)psz_name onOrOff:(vlc_bool_t )b_add
+- (void)changeVoutFiltersString:(char *)psz_name onOrOff:(vlc_bool_t )b_add
{
/* copied from ../wxwidgets/extrapanel.cpp
* renamed to conform with Cocoa's rules */
- /* this method only changes 1st generation video filters (the ones which
+ /* this method only changes 1st generation video filters (the ones which
* can't be used for transcoding). Have a look at changeVideoFiltersString
* for the 2nd generation filters. */
-
+
vout_thread_t *p_vout;
intf_thread_t * p_intf = VLCIntf;
-
+
char *psz_parser, *psz_string;
psz_string = config_GetPsz( p_intf, "vout-filter" );
-
+
if( !psz_string ) psz_string = strdup("");
psz_parser = strstr( psz_string, psz_name );
}
-- (void)changeVideoFiltersString:(char *)psz_name onOrOff:(vlc_bool_t )b_add
+- (void)changeVideoFiltersString:(char *)psz_name onOrOff:(vlc_bool_t )b_add
{
/* same as changeVoutFiltersString but addressing the "video-filter"
* variable which represents the video filter 2 modules */
-
+
vout_thread_t *p_vout;
intf_thread_t * p_intf = VLCIntf;
-
+
char *psz_parser, *psz_string;
psz_string = config_GetPsz( p_intf, "video-filter" );
-
+
if( !psz_string ) psz_string = strdup("");
psz_parser = strstr( psz_string, psz_name );
}
- (void)savePrefs
-{
+{
/* save the preferences to make sure that our module-changes will up on
* next launch again */
playlist_t * p_playlist = pl_Yield( VLCIntf );
@"clone", @"crop", @"normvol", @"headphone_channel_mixer", @"macosx",
nil];
unsigned int x = 0;
-
+
while ( x != [theModules count] )
{
returnedValue = config_SaveConfigFile( p_playlist, [[theModules
if (returnedValue != 0)
{
msg_Err(p_playlist, "unable to save the preferences of the "
- "extended control attribute '%s' (%i)",
+ "extended control attribute '%s' (%i)",
[[theModules objectAtIndex: x] UTF8String] , returnedValue);
[theModules release];
vlc_object_release( p_playlist );
-
+
return;
}
x = ( x + 1 );
}
-
+
msg_Dbg( p_playlist, "VLCExtended: saved certain preferences successfully" );
-
+
[theModules release];
vlc_object_release( p_playlist );
}