Commit 7f4508b3 authored by Eric Petit's avatar Eric Petit

beos/PreferencesWindow*: fixed widgets

parent 31892994
...@@ -39,15 +39,18 @@ ...@@ -39,15 +39,18 @@
/***************************************************************************** /*****************************************************************************
* PreferencesWindow::PreferencesWindow * PreferencesWindow::PreferencesWindow
*****************************************************************************/ *****************************************************************************/
PreferencesWindow::PreferencesWindow( intf_thread_t * p_interface, PreferencesWindow::PreferencesWindow( intf_thread_t * _p_intf,
BRect frame, const char * name ) BRect frame, const char * name )
: BWindow( frame, name, B_FLOATING_WINDOW_LOOK, B_NORMAL_WINDOW_FEEL, : BWindow( frame, name, B_FLOATING_WINDOW_LOOK, B_NORMAL_WINDOW_FEEL,
B_NOT_ZOOMABLE ), B_NOT_ZOOMABLE )
fConfigScroll( NULL ),
p_intf( p_interface )
{ {
p_intf = _p_intf;
fCurrent = NULL;
BRect rect; BRect rect;
SetSizeLimits( PREFS_WINDOW_WIDTH, 2000, PREFS_WINDOW_HEIGHT, 2000 );
/* The "background" view */ /* The "background" view */
fPrefsView = new BView( Bounds(), NULL, B_FOLLOW_ALL, B_WILL_DRAW ); fPrefsView = new BView( Bounds(), NULL, B_FOLLOW_ALL, B_WILL_DRAW );
fPrefsView->SetViewColor( ui_color( B_PANEL_BACKGROUND_COLOR ) ); fPrefsView->SetViewColor( ui_color( B_PANEL_BACKGROUND_COLOR ) );
...@@ -182,9 +185,11 @@ PreferencesWindow::PreferencesWindow( intf_thread_t * p_interface, ...@@ -182,9 +185,11 @@ PreferencesWindow::PreferencesWindow( intf_thread_t * p_interface,
if( options < 1 || category < 0 || subcategory < 0 ) if( options < 1 || category < 0 || subcategory < 0 )
continue; continue;
#if 0
fprintf( stderr, "cat %d, sub %d, %s\n", category, subcategory, fprintf( stderr, "cat %d, sub %d, %s\n", category, subcategory,
p_module->psz_shortname ? p_module->psz_shortname : p_module->psz_shortname ? p_module->psz_shortname :
p_module->psz_object_name ); p_module->psz_object_name );
#endif
catItem = NULL; catItem = NULL;
for( int j = 0; j < fOutline->CountItemsUnder( NULL, true ); j++ ) for( int j = 0; j < fOutline->CountItemsUnder( NULL, true ); j++ )
...@@ -322,8 +327,7 @@ void PreferencesWindow::MessageReceived( BMessage * message ) ...@@ -322,8 +327,7 @@ void PreferencesWindow::MessageReceived( BMessage * message )
void PreferencesWindow::FrameResized( float width, float height ) void PreferencesWindow::FrameResized( float width, float height )
{ {
BWindow::FrameResized( width, height ); BWindow::FrameResized( width, height );
fCurrent->UpdateScrollBar();
UpdateScrollBar();
} }
/***************************************************************************** /*****************************************************************************
...@@ -334,64 +338,24 @@ void PreferencesWindow::Update() ...@@ -334,64 +338,24 @@ void PreferencesWindow::Update()
/* Get the selected item, if any */ /* Get the selected item, if any */
if( fOutline->CurrentSelection() < 0 ) if( fOutline->CurrentSelection() < 0 )
return; return;
fCurrent = (ConfigItem*)
fOutline->ItemAt( fOutline->CurrentSelection() );
/* Detach the old box if any */ /* Detach the old box if any */
if( fDummyView->CountChildren() > 0 ) if( fCurrent )
fDummyView->RemoveChild( fDummyView->ChildAt( 0 ) ); {
fCurrent->ResetScroll();
fDummyView->RemoveChild( fCurrent->Box() );
}
/* Add the new one... */ /* Add the new one... */
fCurrent = (ConfigItem *)
fOutline->ItemAt( fOutline->CurrentSelection() );
fDummyView->AddChild( fCurrent->Box() ); fDummyView->AddChild( fCurrent->Box() );
/* ...then resize it (we must resize it after it's attached or the /* ...then resize it (we must resize it after it's attached or the
children don't get adjusted) */ children don't get adjusted) */
fCurrent->Box()->ResizeTo( fDummyView->Bounds().Width(), fCurrent->Box()->ResizeTo( fDummyView->Bounds().Width(),
fDummyView->Bounds().Height() ); fDummyView->Bounds().Height() );
fCurrent->UpdateScrollBar();
#if 0
/* Force redrawing of its children */
BRect rect = fCurrent->fConfigBox->Bounds();
rect.InsetBy( 10,10 );
rect.top += 10;
fCurrent->fConfigScroll->ResizeTo( rect.Width(), rect.Height() );
fCurrent->fConfigScroll->Draw( fCurrent->fConfigScroll->Bounds() );
UpdateScrollBar();
#endif
}
/*****************************************************************************
* PreferencesWindow::UpdateScrollBar
*****************************************************************************/
void PreferencesWindow::UpdateScrollBar()
{
/* We have to fix the scrollbar manually because it doesn't handle
correctly simple BViews */
#if 0
if( !fCurrent )
{
return;
}
/* Get the available BRect for display */
BRect display = fCurrent->fConfigScroll->Bounds();
display.right -= B_V_SCROLL_BAR_WIDTH;
/* Fix the scrollbar */
BScrollBar * scrollBar;
long max;
BRect visible = display & fCurrent->fConfigView->Bounds();
BRect total = display | fCurrent->fConfigView->Bounds();
scrollBar = fCurrent->fConfigScroll->ScrollBar( B_VERTICAL );
max = (long)( fCurrent->fConfigView->Bounds().Height() - visible.Height() );
if( max < 0 ) max = 0;
scrollBar->SetRange( 0, max );
scrollBar->SetProportion( visible.Height() / total.Height() );
scrollBar->SetSteps( 10, 100 );
#endif
} }
/***************************************************************************** /*****************************************************************************
...@@ -444,15 +408,18 @@ ConfigItem::ConfigItem( intf_thread_t * _p_intf, char * name, ...@@ -444,15 +408,18 @@ ConfigItem::ConfigItem( intf_thread_t * _p_intf, char * name,
fType = type; fType = type;
fHelp = strdup( help ); fHelp = strdup( help );
fTextView = NULL;
BRect r; BRect r;
r = BRect( 0, 0, 100, 100 ); r = BRect( 0, 0, 100, 100 );
fBox = new BBox( r, NULL, B_FOLLOW_ALL ); fBox = new BBox( r, NULL, B_FOLLOW_ALL );
fBox->SetLabel( name ); fBox->SetLabel( name );
fTextView = NULL;
fScroll = NULL;
fView = NULL;
if( fType == TYPE_CATEGORY ) if( fType == TYPE_CATEGORY )
{ {
/* Category: we just show the help text */
r = fBox->Bounds(); r = fBox->Bounds();
r.InsetBy( 10, 10 ); r.InsetBy( 10, 10 );
r.top += 5; r.top += 5;
...@@ -463,7 +430,105 @@ ConfigItem::ConfigItem( intf_thread_t * _p_intf, char * name, ...@@ -463,7 +430,105 @@ ConfigItem::ConfigItem( intf_thread_t * _p_intf, char * name,
fTextView->MakeSelectable( false ); fTextView->MakeSelectable( false );
fTextView->Insert( fHelp ); fTextView->Insert( fHelp );
fBox->AddChild( fTextView ); fBox->AddChild( fTextView );
return;
}
vlc_list_t * p_list = NULL;
module_t * p_module = NULL;
if( fType == TYPE_MODULE )
{
p_module = (module_t *) vlc_object_get( p_intf, fObjectId );
}
else
{
if( !( p_list = vlc_list_find( p_intf, VLC_OBJECT_MODULE,
FIND_ANYWHERE ) ) )
{
return;
}
for( int i = 0; i < p_list->i_count; i++ )
{
p_module = (module_t*) p_list->p_values[i].p_object;
if( !strcmp( p_module->psz_object_name, "main" ) )
break;
else
p_module = NULL;
}
}
if( !p_module || p_module->i_object_type != VLC_OBJECT_MODULE )
{
/* Shouldn't happen */
return;
}
module_config_t * p_item;
p_item = fSubModule ? ((module_t *)p_module->p_parent)->p_config :
p_module->p_config;
if( fType == TYPE_SUBCATEGORY )
{
for( ; p_item->i_type != CONFIG_HINT_END; p_item++ )
{
if( p_item->i_type == CONFIG_SUBCATEGORY &&
p_item->i_value == fObjectId )
{
break;
}
}
}
r = fBox->Bounds();
r = BRect( 10,20,fBox->Bounds().right-B_V_SCROLL_BAR_WIDTH-10,
fBox->Bounds().bottom-10 );
fView = new BView( r, NULL, B_FOLLOW_LEFT_RIGHT | B_FOLLOW_TOP,
B_WILL_DRAW | B_FULL_UPDATE_ON_RESIZE );
fView->SetViewColor( ui_color( B_PANEL_BACKGROUND_COLOR ) );
r = fView->Bounds();
r.InsetBy( 10,10 );
ConfigWidget * widget;
for( ; p_item->i_type != CONFIG_HINT_END; p_item++ )
{
if( ( p_item->i_type == CONFIG_CATEGORY ||
p_item->i_type == CONFIG_SUBCATEGORY ) &&
fType == TYPE_SUBCATEGORY &&
p_item->i_value != fObjectId )
{
break;
}
widget = new ConfigWidget( p_intf, r, p_item );
if( !widget->InitCheck() )
{
delete widget;
continue;
} }
fView->AddChild( widget );
r.top += widget->Bounds().Height();
}
if( fType == TYPE_MODULE )
{
vlc_object_release( p_module );
}
else
{
vlc_list_release( p_list );
}
/* Create a scroll view around our fView */
fScroll = new BScrollView( NULL, fView, B_FOLLOW_ALL, 0, false,
true, B_FANCY_BORDER );
fScroll->SetViewColor( ui_color( B_PANEL_BACKGROUND_COLOR ) );
fBox->AddChild( fScroll );
/* Adjust fView's height to the size it actually needs (we do this
only now so the BScrollView fits the BBox) */
fView->ResizeTo( fView->Bounds().Width(), r.top + 10 );
} }
/*********************************************************************** /***********************************************************************
...@@ -479,6 +544,53 @@ ConfigItem::~ConfigItem() ...@@ -479,6 +544,53 @@ ConfigItem::~ConfigItem()
} }
} }
/*****************************************************************************
* ConfigItem::UpdateScrollBar
*****************************************************************************/
void ConfigItem::UpdateScrollBar()
{
/* We have to fix the scrollbar manually because it doesn't handle
correctly simple BViews */
if( !fScroll )
{
return;
}
/* Get the available BRect for display */
BRect display = fScroll->Bounds();
display.right -= B_V_SCROLL_BAR_WIDTH;
/* Fix the scrollbar */
BScrollBar * scrollBar;
BRect visible = display & fView->Bounds();
BRect total = display | fView->Bounds();
scrollBar = fScroll->ScrollBar( B_VERTICAL );
long max = (long)( fView->Bounds().Height() - visible.Height() );
if( max < 0 ) max = 0;
scrollBar->SetRange( 0, max );
scrollBar->SetProportion( visible.Height() / total.Height() );
scrollBar->SetSteps( 10, 100 );
/* We have to force redraw to avoid visual bugs when resizing
(BeOS bug?) */
fScroll->Invalidate();
fView->Invalidate();
}
/*****************************************************************************
* ConfigItem::ResetScroll
*****************************************************************************/
void ConfigItem::ResetScroll()
{
if( !fScroll )
{
return;
}
fView->ScrollTo( 0, 0 );
}
/*********************************************************************** /***********************************************************************
* ConfigItem::Apply * ConfigItem::Apply
*********************************************************************** ***********************************************************************
...@@ -514,64 +626,77 @@ void ConfigItem::Apply( bool doIt ) ...@@ -514,64 +626,77 @@ void ConfigItem::Apply( bool doIt )
**********************************************************************/ **********************************************************************/
ConfigWidget::ConfigWidget( intf_thread_t * _p_intf, BRect rect, ConfigWidget::ConfigWidget( intf_thread_t * _p_intf, BRect rect,
module_config_t * p_item ) module_config_t * p_item )
: BView( rect, NULL, B_FOLLOW_ALL, B_WILL_DRAW ) : BView( rect, NULL, B_FOLLOW_LEFT_RIGHT | B_FOLLOW_TOP,
B_WILL_DRAW )
{ {
#if 0 p_intf = _p_intf;
fType = type;
switch( fType ) fInitOK = true;
SetViewColor( ui_color( B_PANEL_BACKGROUND_COLOR ) );
BRect r;
BMenuItem * menuItem;
switch( p_item->i_type )
{ {
case CONFIG_ITEM_MODULE:
case CONFIG_ITEM_MODULE_CAT:
case CONFIG_ITEM_MODULE_LIST_CAT:
case CONFIG_ITEM_STRING: case CONFIG_ITEM_STRING:
case CONFIG_ITEM_FILE: case CONFIG_ITEM_FILE:
case CONFIG_ITEM_MODULE:
case CONFIG_ITEM_DIRECTORY: case CONFIG_ITEM_DIRECTORY:
case CONFIG_ITEM_INTEGER: case CONFIG_ITEM_INTEGER:
case CONFIG_ITEM_FLOAT: case CONFIG_ITEM_FLOAT:
ResizeTo( Bounds().Width(), 25 ); ResizeTo( Bounds().Width(), 25 );
fTextControl = new BTextControl( Bounds(), NULL, label, NULL, fTextControl = new VTextControl( Bounds(), NULL,
new BMessage() ); p_item->psz_text, NULL, new BMessage(),
B_FOLLOW_LEFT_RIGHT | B_FOLLOW_TOP );
AddChild( fTextControl ); AddChild( fTextControl );
break; break;
case CONFIG_ITEM_BOOL:
ResizeTo( Bounds().Width(), 25 );
fCheckBox = new BCheckBox( Bounds(), NULL, label, new BMessage() );
AddChild( fCheckBox );
break;
case CONFIG_ITEM_KEY: case CONFIG_ITEM_KEY:
ResizeTo( Bounds().Width(), 25 ); ResizeTo( Bounds().Width(), 25 );
r.left = r.right - 60; r = Bounds();
r.left = r.right - 100;
fPopUpMenu = new BPopUpMenu( "" ); fPopUpMenu = new BPopUpMenu( "" );
fMenuField = new BMenuField( r, NULL, NULL, fPopUpMenu ); fMenuField = new BMenuField( r, NULL, NULL, fPopUpMenu,
B_FOLLOW_RIGHT | B_FOLLOW_TOP );
for( unsigned i = 0; for( unsigned i = 0;
i < sizeof( vlc_keys ) / sizeof( key_descriptor_t ); i++ ) i < sizeof( vlc_keys ) / sizeof( key_descriptor_t );
i++ )
{ {
menuItem = new BMenuItem( vlc_keys[i].psz_key_string, NULL ); menuItem = new BMenuItem( vlc_keys[i].psz_key_string, NULL );
fPopUpMenu->AddItem( menuItem ); fPopUpMenu->AddItem( menuItem );
} }
r.right = r.left - 10; r.left = r.left - 60; r.right = r.left - 10; r.left = r.left - 60;
fShiftCheck = new BCheckBox( r, NULL, "Shift", new BMessage ); fShiftCheck = new BCheckBox( r, NULL, "Shift",
new BMessage(), B_FOLLOW_RIGHT | B_FOLLOW_TOP );
r.right = r.left - 10; r.left = r.left - 60; r.right = r.left - 10; r.left = r.left - 60;
fCtrlCheck = new BCheckBox( r, NULL, "Ctrl", new BMessage ); fCtrlCheck = new BCheckBox( r, NULL, "Ctrl",
new BMessage(), B_FOLLOW_RIGHT | B_FOLLOW_TOP );
r.right = r.left - 10; r.left = r.left - 60; r.right = r.left - 10; r.left = r.left - 60;
fAltCheck = new BCheckBox( r, NULL, "Alt", new BMessage ); fAltCheck = new BCheckBox( r, NULL, "Alt",
new BMessage(), B_FOLLOW_RIGHT | B_FOLLOW_TOP );
/* Can someone tell me how we're supposed to get GUI items aligned ? */ r.right = r.left - 10; r.left = 0; r.bottom -= 10;
r.right = r.left - 10; r.left = 0; fStringView = new BStringView( r, NULL, p_item->psz_text,
r.bottom -= 10; B_FOLLOW_LEFT_RIGHT | B_FOLLOW_TOP );
fStringView = new BStringView( r, NULL, label );
AddChild( fStringView ); AddChild( fStringView );
AddChild( fAltCheck ); AddChild( fAltCheck );
AddChild( fCtrlCheck ); AddChild( fCtrlCheck );
AddChild( fShiftCheck ); AddChild( fShiftCheck );
AddChild( fMenuField ); AddChild( fMenuField );
break; break;
#endif case CONFIG_ITEM_BOOL:
ResizeTo( Bounds().Width(), 25 );
fCheckBox = new BCheckBox( Bounds(), NULL, p_item->psz_text,
new BMessage(), B_FOLLOW_LEFT_RIGHT | B_FOLLOW_TOP );
AddChild( fCheckBox );
break;
case CONFIG_SECTION:
fInitOK = false;
break;
default:
fInitOK = false;
}
} }
/*********************************************************************** /***********************************************************************
...@@ -698,3 +823,17 @@ void VTextView::FrameResized( float width, float height ) ...@@ -698,3 +823,17 @@ void VTextView::FrameResized( float width, float height )
BTextView::FrameResized( width, height ); BTextView::FrameResized( width, height );
SetTextRect( BRect( 10,10, width-11, height-11 ) ); SetTextRect( BRect( 10,10, width-11, height-11 ) );
} }
VTextControl::VTextControl( BRect frame, const char *name,
const char *label, const char *text,
BMessage * message, uint32 resizingMode )
: BTextControl( frame, name, label, text, message, resizingMode )
{
FrameResized( Bounds().Width(), Bounds().Height() );
}
void VTextControl::FrameResized( float width, float height )
{
BTextControl::FrameResized( width, height );
SetDivider( width / 2 );
}
...@@ -27,7 +27,7 @@ ...@@ -27,7 +27,7 @@
#include <InterfaceKit.h> #include <InterfaceKit.h>
#define PREFS_WINDOW_WIDTH 700 #define PREFS_WINDOW_WIDTH 700
#define PREFS_WINDOW_HEIGHT 600 #define PREFS_WINDOW_HEIGHT 400
#define PREFS_ITEM_SELECTED 'pris' #define PREFS_ITEM_SELECTED 'pris'
#define PREFS_DEFAULTS 'prde' #define PREFS_DEFAULTS 'prde'
#define PREFS_APPLY 'prap' #define PREFS_APPLY 'prap'
...@@ -41,19 +41,28 @@ class VTextView : public BTextView ...@@ -41,19 +41,28 @@ class VTextView : public BTextView
void FrameResized( float width, float height ); void FrameResized( float width, float height );
}; };
class VTextControl : public BTextControl
{
public:
VTextControl( BRect frame, const char *name,
const char *label, const char *text,
BMessage * message, uint32 resizingMode );
void FrameResized( float width, float height );
};
class ConfigWidget : public BView class ConfigWidget : public BView
{ {
public: public:
ConfigWidget( intf_thread_t * p_intf, BRect rect, ConfigWidget( intf_thread_t * p_intf, BRect rect,
module_config_t * p_item ); module_config_t * p_item );
bool InitCheck() { return fInitOK; }
void Apply( bool doIt ); void Apply( bool doIt );
private: private:
intf_thread_t * p_intf; intf_thread_t * p_intf;
int fType; bool fInitOK;
VTextControl * fTextControl;
BTextControl * fTextControl;
BCheckBox * fCheckBox; BCheckBox * fCheckBox;
BPopUpMenu * fPopUpMenu; BPopUpMenu * fPopUpMenu;
BMenuField * fMenuField; BMenuField * fMenuField;
...@@ -73,8 +82,9 @@ class ConfigItem : public BStringItem ...@@ -73,8 +82,9 @@ class ConfigItem : public BStringItem
~ConfigItem(); ~ConfigItem();
int ObjectId() { return fObjectId; } int ObjectId() { return fObjectId; }
BBox * Box() { return fBox; } BBox * Box() { return fBox; }
void UpdateScrollBar();
void ResetScroll();
void Apply( bool doIt ); void Apply( bool doIt );
void Pulse();
private: private:
intf_thread_t * p_intf; intf_thread_t * p_intf;
...@@ -85,9 +95,9 @@ class ConfigItem : public BStringItem ...@@ -85,9 +95,9 @@ class ConfigItem : public BStringItem
char * fHelp; char * fHelp;
BBox * fBox; BBox * fBox;
VTextView * fTextView;
BScrollView * fScroll; BScrollView * fScroll;
BView * fView; BView * fView;
VTextView * fTextView;
}; };
class PreferencesWindow : public BWindow class PreferencesWindow : public BWindow
...@@ -103,7 +113,6 @@ class PreferencesWindow : public BWindow ...@@ -103,7 +113,6 @@ class PreferencesWindow : public BWindow
virtual void FrameResized( float, float ); virtual void FrameResized( float, float );
void Update(); void Update();
void UpdateScrollBar();
void ApplyChanges( bool doIt ); void ApplyChanges( bool doIt );
void SaveChanges(); void SaveChanges();
...@@ -117,7 +126,6 @@ class PreferencesWindow : public BWindow ...@@ -117,7 +126,6 @@ class PreferencesWindow : public BWindow
BView * fPrefsView; BView * fPrefsView;
BOutlineListView * fOutline; BOutlineListView * fOutline;
BView * fDummyView; BView * fDummyView;
BScrollView * fConfigScroll;
ConfigItem * fCurrent; ConfigItem * fCurrent;
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