Some cleanups to ColorSet in anticipation of future cleanups for Appearance app
git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@13156 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
cf5ff0c0d0
commit
e67e7dd995
@ -29,9 +29,9 @@
|
|||||||
#define COLORSET_H_
|
#define COLORSET_H_
|
||||||
|
|
||||||
#include <Locker.h>
|
#include <Locker.h>
|
||||||
#include "RGBColor.h"
|
|
||||||
#include <Message.h>
|
#include <Message.h>
|
||||||
#include <String.h>
|
#include <String.h>
|
||||||
|
#include <ColorUtils.h>
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\class ColorSet ColorSet.h
|
\class ColorSet ColorSet.h
|
||||||
@ -43,18 +43,22 @@ public:
|
|||||||
ColorSet(void);
|
ColorSet(void);
|
||||||
ColorSet(const ColorSet &cs);
|
ColorSet(const ColorSet &cs);
|
||||||
ColorSet & operator=(const ColorSet &cs);
|
ColorSet & operator=(const ColorSet &cs);
|
||||||
|
|
||||||
void SetColors(const ColorSet &cs);
|
void SetColors(const ColorSet &cs);
|
||||||
void PrintToStream(void) const;
|
void PrintToStream(void) const;
|
||||||
|
|
||||||
bool ConvertToMessage(BMessage *msg) const;
|
bool ConvertToMessage(BMessage *msg) const;
|
||||||
bool ConvertFromMessage(const BMessage *msg);
|
bool ConvertFromMessage(const BMessage *msg);
|
||||||
|
|
||||||
void SetToDefaults(void);
|
void SetToDefaults(void);
|
||||||
RGBColor StringToColor(const char *string);
|
|
||||||
RGBColor AttributeToColor(int32 which);
|
rgb_color StringToColor(const char *string);
|
||||||
|
rgb_color AttributeToColor(int32 which);
|
||||||
|
|
||||||
status_t SetColor(const char *string, rgb_color value);
|
status_t SetColor(const char *string, rgb_color value);
|
||||||
|
|
||||||
BString name;
|
|
||||||
|
|
||||||
RGBColor panel_background,
|
rgb_color panel_background,
|
||||||
panel_text,
|
panel_text,
|
||||||
|
|
||||||
document_background,
|
document_background,
|
||||||
@ -83,17 +87,21 @@ public:
|
|||||||
shadow,
|
shadow,
|
||||||
window_tab,
|
window_tab,
|
||||||
|
|
||||||
// Not all of these guys don't exist in InterfaceDefs.h, but we keep
|
// Not all of these guys don't exist in InterfaceDefs.h,
|
||||||
// them as part of the color set anyway - they're important nonetheless
|
// but we keep them as part of the color set anyway -
|
||||||
|
// they're important nonetheless
|
||||||
window_tab_text,
|
window_tab_text,
|
||||||
inactive_window_tab,
|
inactive_window_tab,
|
||||||
inactive_window_tab_text;
|
inactive_window_tab_text;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
RGBColor *StringToMember(const char *string);
|
|
||||||
|
rgb_color * StringToMember(const char *string);
|
||||||
|
void PrintMember(const rgb_color &color) const;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
bool LoadGUIColors(ColorSet *set);
|
status_t LoadColorSet(const char *path, ColorSet *set);
|
||||||
void SaveGUIColors(const ColorSet &set);
|
status_t SaveColorSet(const char *path, const ColorSet &set);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -359,14 +359,14 @@ void BeDecorator::_SetFocus(void)
|
|||||||
|
|
||||||
if(GetFocus())
|
if(GetFocus())
|
||||||
{
|
{
|
||||||
button_highcol.SetColor(tint_color(_colors->window_tab.GetColor32(),B_LIGHTEN_2_TINT));
|
button_highcol.SetColor(tint_color(_colors->window_tab,B_LIGHTEN_2_TINT));
|
||||||
button_lowcol.SetColor(tint_color(_colors->window_tab.GetColor32(),B_DARKEN_1_TINT));
|
button_lowcol.SetColor(tint_color(_colors->window_tab,B_DARKEN_1_TINT));
|
||||||
textcol=_colors->window_tab_text;
|
textcol=_colors->window_tab_text;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
button_highcol.SetColor(tint_color(_colors->inactive_window_tab.GetColor32(),B_LIGHTEN_2_TINT));
|
button_highcol.SetColor(tint_color(_colors->inactive_window_tab,B_LIGHTEN_2_TINT));
|
||||||
button_lowcol.SetColor(tint_color(_colors->inactive_window_tab.GetColor32(),B_DARKEN_1_TINT));
|
button_lowcol.SetColor(tint_color(_colors->inactive_window_tab,B_DARKEN_1_TINT));
|
||||||
textcol=_colors->inactive_window_tab_text;
|
textcol=_colors->inactive_window_tab_text;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -174,7 +174,7 @@ AppServer::AppServer(void) :
|
|||||||
|
|
||||||
// Load the GUI colors here and set the global set to the values contained therein. If this
|
// Load the GUI colors here and set the global set to the values contained therein. If this
|
||||||
// is not possible, set colors to the defaults
|
// is not possible, set colors to the defaults
|
||||||
if (!LoadGUIColors(&gui_colorset))
|
if (LoadColorSet(SERVER_SETTINGS_DIR COLOR_SETTINGS_NAME,&gui_colorset)!=B_OK)
|
||||||
gui_colorset.SetToDefaults();
|
gui_colorset.SetToDefaults();
|
||||||
|
|
||||||
InitDecorators();
|
InitDecorators();
|
||||||
|
@ -35,6 +35,8 @@
|
|||||||
#include "ColorSet.h"
|
#include "ColorSet.h"
|
||||||
#include "ServerConfig.h"
|
#include "ServerConfig.h"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//! Constructor which does nothing
|
//! Constructor which does nothing
|
||||||
ColorSet::ColorSet(void)
|
ColorSet::ColorSet(void)
|
||||||
{
|
{
|
||||||
@ -46,7 +48,6 @@ ColorSet::ColorSet(void)
|
|||||||
*/
|
*/
|
||||||
ColorSet::ColorSet(const ColorSet &cs)
|
ColorSet::ColorSet(const ColorSet &cs)
|
||||||
{
|
{
|
||||||
name=cs.name;
|
|
||||||
SetColors(cs);
|
SetColors(cs);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -57,7 +58,6 @@ ColorSet::ColorSet(const ColorSet &cs)
|
|||||||
*/
|
*/
|
||||||
ColorSet & ColorSet::operator=(const ColorSet &cs)
|
ColorSet & ColorSet::operator=(const ColorSet &cs)
|
||||||
{
|
{
|
||||||
name=cs.name;
|
|
||||||
SetColors(cs);
|
SetColors(cs);
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
@ -106,40 +106,39 @@ void ColorSet::SetColors(const ColorSet &cs)
|
|||||||
//! Prints all color set elements to stdout
|
//! Prints all color set elements to stdout
|
||||||
void ColorSet::PrintToStream(void) const
|
void ColorSet::PrintToStream(void) const
|
||||||
{
|
{
|
||||||
printf("Name: %s\n",name.String());
|
printf("panel_background "); PrintMember(panel_background);
|
||||||
printf("panel_background "); panel_background.PrintToStream();
|
printf("panel_text "); PrintMember(panel_text);
|
||||||
printf("panel_text "); panel_text.PrintToStream();
|
|
||||||
|
|
||||||
printf("document_background "); document_background.PrintToStream();
|
printf("document_background "); PrintMember(document_background);
|
||||||
printf("document_text "); document_text.PrintToStream();
|
printf("document_text "); PrintMember(document_text);
|
||||||
|
|
||||||
printf("control_background "); control_background.PrintToStream();
|
printf("control_background "); PrintMember(control_background);
|
||||||
printf("control_text "); control_text.PrintToStream();
|
printf("control_text "); PrintMember(control_text);
|
||||||
printf("control_highlight "); control_highlight.PrintToStream();
|
printf("control_highlight "); PrintMember(control_highlight);
|
||||||
printf("control_border "); control_border.PrintToStream();
|
printf("control_border "); PrintMember(control_border);
|
||||||
|
|
||||||
printf("tooltip_background "); tooltip_background.PrintToStream();
|
printf("tooltip_background "); PrintMember(tooltip_background);
|
||||||
printf("tooltip_text "); tooltip_text.PrintToStream();
|
printf("tooltip_text "); PrintMember(tooltip_text);
|
||||||
|
|
||||||
printf("menu_background "); menu_background.PrintToStream();
|
printf("menu_background "); PrintMember(menu_background);
|
||||||
printf("menu_selected_background "); menu_selected_background.PrintToStream();
|
printf("menu_selected_background "); PrintMember(menu_selected_background);
|
||||||
printf("menu_text "); menu_text.PrintToStream();
|
printf("menu_text "); PrintMember(menu_text);
|
||||||
printf("menu_selected_text "); menu_selected_text.PrintToStream();
|
printf("menu_selected_text "); PrintMember(menu_selected_text);
|
||||||
printf("menu_selected_border "); menu_selected_border.PrintToStream();
|
printf("menu_selected_border "); PrintMember(menu_selected_border);
|
||||||
|
|
||||||
printf("keyboard_navigation_base "); keyboard_navigation_base.PrintToStream();
|
printf("keyboard_navigation_base "); PrintMember(keyboard_navigation_base);
|
||||||
printf("keyboard_navigation_pulse "); keyboard_navigation_pulse.PrintToStream();
|
printf("keyboard_navigation_pulse "); PrintMember(keyboard_navigation_pulse);
|
||||||
|
|
||||||
printf("success "); success.PrintToStream();
|
printf("success "); PrintMember(success);
|
||||||
printf("failure "); failure.PrintToStream();
|
printf("failure "); PrintMember(failure);
|
||||||
printf("shine "); shine.PrintToStream();
|
printf("shine "); PrintMember(shine);
|
||||||
printf("shadow "); shadow.PrintToStream();
|
printf("shadow "); PrintMember(shadow);
|
||||||
|
|
||||||
printf("window_tab "); window_tab.PrintToStream();
|
printf("window_tab "); PrintMember(window_tab);
|
||||||
printf("window_tab_text "); window_tab_text.PrintToStream();
|
printf("window_tab_text "); PrintMember(window_tab_text);
|
||||||
|
|
||||||
printf("inactive_window_tab "); inactive_window_tab.PrintToStream();
|
printf("inactive_window_tab "); PrintMember(inactive_window_tab);
|
||||||
printf("inactive_window_tab_text "); inactive_window_tab_text.PrintToStream();
|
printf("inactive_window_tab_text "); PrintMember(inactive_window_tab_text);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
@ -151,33 +150,32 @@ void ColorSet::SetToDefaults(void)
|
|||||||
#ifdef DEBUG_COLORSET
|
#ifdef DEBUG_COLORSET
|
||||||
printf("Initializing color settings to defaults\n");
|
printf("Initializing color settings to defaults\n");
|
||||||
#endif
|
#endif
|
||||||
panel_background.SetColor(216,216,216);
|
SetRGBColor(&panel_background,216,216,216);
|
||||||
panel_text.SetColor(0,0,0);
|
SetRGBColor(&panel_text,0,0,0);
|
||||||
document_background.SetColor(255,255,255);
|
SetRGBColor(&document_background,255,255,255);
|
||||||
document_text.SetColor(0,0,0);
|
SetRGBColor(&document_text,0,0,0);
|
||||||
control_background.SetColor(245,245,245);
|
SetRGBColor(&control_background,245,245,245);
|
||||||
control_text.SetColor(0,0,0);
|
SetRGBColor(&control_text,0,0,0);
|
||||||
control_border.SetColor(0,0,0);
|
SetRGBColor(&control_border,0,0,0);
|
||||||
control_highlight.SetColor(115,120,184);
|
SetRGBColor(&control_highlight,115,120,184);
|
||||||
keyboard_navigation_base.SetColor(0,0,229);
|
SetRGBColor(&keyboard_navigation_base,0,0,229);
|
||||||
keyboard_navigation_pulse.SetColor(0,0,0);
|
SetRGBColor(&keyboard_navigation_pulse,0,0,0);
|
||||||
shine.SetColor(255,255,255);
|
SetRGBColor(&shine,255,255,255);
|
||||||
shadow.SetColor(0,0,0);
|
SetRGBColor(&shadow,0,0,0);
|
||||||
menu_background.SetColor(216,216,216);
|
SetRGBColor(&menu_background,216,216,216);
|
||||||
menu_selected_background.SetColor(115,120,184);
|
SetRGBColor(&menu_selected_background,115,120,184);
|
||||||
menu_text.SetColor(0,0,0);
|
SetRGBColor(&menu_text,0,0,0);
|
||||||
menu_selected_text.SetColor(255,255,255);
|
SetRGBColor(&menu_selected_text,255,255,255);
|
||||||
menu_selected_border.SetColor(0,0,0);
|
SetRGBColor(&menu_selected_border,0,0,0);
|
||||||
tooltip_background.SetColor(255,255,0);
|
SetRGBColor(&tooltip_background,255,255,0);
|
||||||
tooltip_text.SetColor(0,0,0);
|
SetRGBColor(&tooltip_text,0,0,0);
|
||||||
success.SetColor(0,255,0);
|
SetRGBColor(&success,0,255,0);
|
||||||
failure.SetColor(255,0,0);
|
SetRGBColor(&failure,255,0,0);
|
||||||
window_tab.SetColor(255,203,0);
|
SetRGBColor(&window_tab,255,203,0);
|
||||||
|
|
||||||
// important, but not publically accessible GUI colors
|
SetRGBColor(&window_tab_text,0,0,0);
|
||||||
window_tab_text.SetColor(0,0,0);
|
SetRGBColor(&inactive_window_tab,216,216,216);
|
||||||
inactive_window_tab.SetColor(216,216,216);
|
SetRGBColor(&inactive_window_tab_text,80,80,80);
|
||||||
inactive_window_tab_text.SetColor(80,80,80);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
@ -191,59 +189,45 @@ bool ColorSet::ConvertToMessage(BMessage *msg) const
|
|||||||
|
|
||||||
msg->MakeEmpty();
|
msg->MakeEmpty();
|
||||||
|
|
||||||
rgb_color col;
|
msg->AddData("Panel Background",(type_code)'RGBC',&panel_background,
|
||||||
|
sizeof(rgb_color) );
|
||||||
msg->AddString("Name",name);
|
msg->AddData("Panel Text",(type_code)'RGBC',&panel_text,sizeof(rgb_color));
|
||||||
col=panel_background.GetColor32();
|
msg->AddData("Document Background",(type_code)'RGBC',&document_background,
|
||||||
msg->AddData("Panel Background",(type_code)'RGBC',&col,sizeof(rgb_color));
|
sizeof(rgb_color));
|
||||||
col=panel_text.GetColor32();
|
msg->AddData("Document Text",(type_code)'RGBC',&document_text,sizeof(rgb_color));
|
||||||
msg->AddData("Panel Text",(type_code)'RGBC',&col,sizeof(rgb_color));
|
msg->AddData("Control Background",(type_code)'RGBC',&control_background,
|
||||||
col=document_background.GetColor32();
|
sizeof(rgb_color));
|
||||||
msg->AddData("Document Background",(type_code)'RGBC',&col,sizeof(rgb_color));
|
msg->AddData("Control Text",(type_code)'RGBC',&control_text,sizeof(rgb_color));
|
||||||
col=document_text.GetColor32();
|
msg->AddData("Control Highlight",(type_code)'RGBC',&control_highlight,
|
||||||
msg->AddData("Document Text",(type_code)'RGBC',&col,sizeof(rgb_color));
|
sizeof(rgb_color));
|
||||||
col=control_background.GetColor32();
|
msg->AddData("Control Border",(type_code)'RGBC',&control_border,sizeof(rgb_color));
|
||||||
msg->AddData("Control Background",(type_code)'RGBC',&col,sizeof(rgb_color));
|
msg->AddData("Tooltip Background",(type_code)'RGBC',&tooltip_background,
|
||||||
col=control_text.GetColor32();
|
sizeof(rgb_color));
|
||||||
msg->AddData("Control Text",(type_code)'RGBC',&col,sizeof(rgb_color));
|
msg->AddData("Tooltip Text",(type_code)'RGBC',&tooltip_text,sizeof(rgb_color));
|
||||||
col=control_highlight.GetColor32();
|
msg->AddData("Menu Background",(type_code)'RGBC',&menu_background,
|
||||||
msg->AddData("Control Highlight",(type_code)'RGBC',&col,sizeof(rgb_color));
|
sizeof(rgb_color));
|
||||||
col=control_border.GetColor32();
|
msg->AddData("Selected Menu Item Background",(type_code)'RGBC',&menu_selected_background,
|
||||||
msg->AddData("Control Border",(type_code)'RGBC',&col,sizeof(rgb_color));
|
sizeof(rgb_color));
|
||||||
col=tooltip_background.GetColor32();
|
msg->AddData("Keyboard Navigation Base",(type_code)'RGBC',&keyboard_navigation_base,
|
||||||
msg->AddData("Tooltip Background",(type_code)'RGBC',&col,sizeof(rgb_color));
|
sizeof(rgb_color));
|
||||||
col=tooltip_text.GetColor32();
|
msg->AddData("Keyboard Navigation Pulse",(type_code)'RGBC',
|
||||||
msg->AddData("Tooltip Text",(type_code)'RGBC',&col,sizeof(rgb_color));
|
&keyboard_navigation_pulse,sizeof(rgb_color));
|
||||||
col=menu_background.GetColor32();
|
msg->AddData("Menu Item Text",(type_code)'RGBC',&menu_text,sizeof(rgb_color));
|
||||||
msg->AddData("Menu Background",(type_code)'RGBC',&col,sizeof(rgb_color));
|
msg->AddData("Selected Menu Item Text",(type_code)'RGBC',&menu_selected_text,
|
||||||
col=menu_selected_background.GetColor32();
|
sizeof(rgb_color));
|
||||||
msg->AddData("Selected Menu Item Background",(type_code)'RGBC',&col,sizeof(rgb_color));
|
msg->AddData("Selected Menu Item Border",(type_code)'RGBC',&menu_selected_border,
|
||||||
col=keyboard_navigation_base.GetColor32();
|
sizeof(rgb_color));
|
||||||
msg->AddData("Keyboard Navigation Base",(type_code)'RGBC',&col,sizeof(rgb_color));
|
msg->AddData("Success",(type_code)'RGBC',&success,sizeof(rgb_color));
|
||||||
col=keyboard_navigation_pulse.GetColor32();
|
msg->AddData("Failure",(type_code)'RGBC',&failure,sizeof(rgb_color));
|
||||||
msg->AddData("Keyboard Navigation Pulse",(type_code)'RGBC',&col,sizeof(rgb_color));
|
msg->AddData("Shine",(type_code)'RGBC',&shine,sizeof(rgb_color));
|
||||||
col=menu_text.GetColor32();
|
msg->AddData("Shadow",(type_code)'RGBC',&shadow,sizeof(rgb_color));
|
||||||
msg->AddData("Menu Item Text",(type_code)'RGBC',&col,sizeof(rgb_color));
|
msg->AddData("Window Tab",(type_code)'RGBC',&window_tab,sizeof(rgb_color));
|
||||||
col=menu_selected_text.GetColor32();
|
msg->AddData("Window Tab Text",(type_code)'RGBC',&window_tab_text,
|
||||||
msg->AddData("Selected Menu Item Text",(type_code)'RGBC',&col,sizeof(rgb_color));
|
sizeof(rgb_color));
|
||||||
col=menu_selected_border.GetColor32();
|
msg->AddData("Inactive Window Tab",(type_code)'RGBC',&inactive_window_tab,
|
||||||
msg->AddData("Selected Menu Item Border",(type_code)'RGBC',&col,sizeof(rgb_color));
|
sizeof(rgb_color));
|
||||||
col=success.GetColor32();
|
msg->AddData("Inactive Window Tab Text",(type_code)'RGBC',
|
||||||
msg->AddData("Success",(type_code)'RGBC',&col,sizeof(rgb_color));
|
&inactive_window_tab_text,sizeof(rgb_color));
|
||||||
col=failure.GetColor32();
|
|
||||||
msg->AddData("Failure",(type_code)'RGBC',&col,sizeof(rgb_color));
|
|
||||||
col=shine.GetColor32();
|
|
||||||
msg->AddData("Shine",(type_code)'RGBC',&col,sizeof(rgb_color));
|
|
||||||
col=shadow.GetColor32();
|
|
||||||
msg->AddData("Shadow",(type_code)'RGBC',&col,sizeof(rgb_color));
|
|
||||||
col=window_tab.GetColor32();
|
|
||||||
msg->AddData("Window Tab",(type_code)'RGBC',&col,sizeof(rgb_color));
|
|
||||||
col=window_tab_text.GetColor32();
|
|
||||||
msg->AddData("Window Tab Text",(type_code)'RGBC',&col,sizeof(rgb_color));
|
|
||||||
col=inactive_window_tab.GetColor32();
|
|
||||||
msg->AddData("Inactive Window Tab",(type_code)'RGBC',&col,sizeof(rgb_color));
|
|
||||||
col=inactive_window_tab_text.GetColor32();
|
|
||||||
msg->AddData("Inactive Window Tab Text",(type_code)'RGBC',&col,sizeof(rgb_color));
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -261,8 +245,6 @@ bool ColorSet::ConvertFromMessage(const BMessage *msg)
|
|||||||
ssize_t size;
|
ssize_t size;
|
||||||
BString str;
|
BString str;
|
||||||
|
|
||||||
if(msg->FindString("Name",&str)==B_OK)
|
|
||||||
name=str;
|
|
||||||
if(msg->FindData("Panel Background",(type_code)'RGBC',(const void**)&col,&size)==B_OK)
|
if(msg->FindData("Panel Background",(type_code)'RGBC',(const void**)&col,&size)==B_OK)
|
||||||
panel_background=*col;
|
panel_background=*col;
|
||||||
if(msg->FindData("Panel Text",(type_code)'RGBC',(const void**)&col,&size)==B_OK)
|
if(msg->FindData("Panel Text",(type_code)'RGBC',(const void**)&col,&size)==B_OK)
|
||||||
@ -327,7 +309,7 @@ status_t ColorSet::SetColor(const char *string, rgb_color value)
|
|||||||
if(!string)
|
if(!string)
|
||||||
return B_BAD_VALUE;
|
return B_BAD_VALUE;
|
||||||
|
|
||||||
RGBColor *col=StringToMember(string);
|
rgb_color *col=StringToMember(string);
|
||||||
if(!col)
|
if(!col)
|
||||||
return B_NAME_NOT_FOUND;
|
return B_NAME_NOT_FOUND;
|
||||||
*col=value;
|
*col=value;
|
||||||
@ -339,11 +321,14 @@ status_t ColorSet::SetColor(const char *string, rgb_color value)
|
|||||||
\param string name of the color to obtain
|
\param string name of the color to obtain
|
||||||
\return The set's color or (0,0,0,0) if not found
|
\return The set's color or (0,0,0,0) if not found
|
||||||
*/
|
*/
|
||||||
RGBColor ColorSet::StringToColor(const char *string)
|
rgb_color ColorSet::StringToColor(const char *string)
|
||||||
{
|
{
|
||||||
RGBColor *col=StringToMember(string);
|
rgb_color *col=StringToMember(string);
|
||||||
if(!col)
|
if(!col)
|
||||||
return RGBColor(0,0,0,0);
|
{
|
||||||
|
rgb_color c;
|
||||||
|
return c;
|
||||||
|
}
|
||||||
|
|
||||||
return *col;
|
return *col;
|
||||||
}
|
}
|
||||||
@ -353,7 +338,7 @@ RGBColor ColorSet::StringToColor(const char *string)
|
|||||||
\param string name of the color member to obtain
|
\param string name of the color member to obtain
|
||||||
\return An RGBColor pointer or NULL if not found
|
\return An RGBColor pointer or NULL if not found
|
||||||
*/
|
*/
|
||||||
RGBColor *ColorSet::StringToMember(const char *string)
|
rgb_color *ColorSet::StringToMember(const char *string)
|
||||||
{
|
{
|
||||||
if(!string)
|
if(!string)
|
||||||
return NULL;
|
return NULL;
|
||||||
@ -413,7 +398,7 @@ RGBColor *ColorSet::StringToMember(const char *string)
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
RGBColor ColorSet::AttributeToColor(int32 which)
|
rgb_color ColorSet::AttributeToColor(int32 which)
|
||||||
{
|
{
|
||||||
switch(which)
|
switch(which)
|
||||||
{
|
{
|
||||||
@ -549,63 +534,61 @@ RGBColor ColorSet::AttributeToColor(int32 which)
|
|||||||
|
|
||||||
default:
|
default:
|
||||||
{
|
{
|
||||||
return RGBColor(0,0,0,0);
|
rgb_color c;
|
||||||
|
return c;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void ColorSet::PrintMember(const rgb_color &color) const
|
||||||
|
{
|
||||||
|
printf("rgb_color(%d, %d, %d, %d)", color.red,color.green,color.blue,color.alpha);
|
||||||
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\brief Loads the saved system colors into a ColorSet
|
\brief Loads the saved system colors into a ColorSet
|
||||||
\param set the set to receive the system colors
|
\param set the set to receive the system colors
|
||||||
\return true if successful, false if not
|
\return B_OK if successful. See BFile for other error codes
|
||||||
|
|
||||||
Note that this function automatically looks for the file named in
|
|
||||||
COLOR_SETTINGS_NAME in the folder SERVER_SETTINGS_DIR as defined in
|
|
||||||
ServerConfig.h
|
|
||||||
*/
|
*/
|
||||||
bool LoadGUIColors(ColorSet *set)
|
status_t LoadColorSet(const char *path, ColorSet *set)
|
||||||
{
|
{
|
||||||
BString path(SERVER_SETTINGS_DIR);
|
BFile file(path,B_READ_ONLY);
|
||||||
path+=COLOR_SETTINGS_NAME;
|
|
||||||
|
|
||||||
BFile file(path.String(),B_READ_ONLY);
|
|
||||||
if(file.InitCheck()!=B_OK)
|
if(file.InitCheck()!=B_OK)
|
||||||
return false;
|
return file.InitCheck();
|
||||||
|
|
||||||
BMessage msg;
|
BMessage msg;
|
||||||
if(msg.Unflatten(&file)!=B_OK)
|
|
||||||
return false;
|
status_t st=msg.Unflatten(&file);
|
||||||
|
if(st!=B_OK)
|
||||||
|
return st;
|
||||||
|
|
||||||
set->ConvertFromMessage(&msg);
|
set->ConvertFromMessage(&msg);
|
||||||
|
|
||||||
return true;
|
return B_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\brief Saves the saved system colors into a flattened BMessage
|
\brief Saves the saved system colors into a flattened BMessage
|
||||||
\param set ColorSet containing the colors to save
|
\param set ColorSet containing the colors to save
|
||||||
|
\return B_OK if successful. See BFile for other error codes
|
||||||
Note that this function automatically looks for the file named in
|
|
||||||
COLOR_SETTINGS_NAME in the folder SERVER_SETTINGS_DIR as defined in
|
|
||||||
ServerConfig.h. If SERVER_SETTINGS_DIR does not exist, it is created, and the same for
|
|
||||||
the color settings file.
|
|
||||||
*/
|
*/
|
||||||
void SaveGUIColors(const ColorSet &set)
|
status_t SaveColorSet(const char *path, const ColorSet &set)
|
||||||
{
|
{
|
||||||
BEntry *entry=new BEntry(SERVER_SETTINGS_DIR);
|
// TODO: Move this check to the app_server
|
||||||
if(!entry->Exists())
|
BEntry entry(SERVER_SETTINGS_DIR);
|
||||||
|
if(!entry.Exists())
|
||||||
create_directory(SERVER_SETTINGS_DIR,0777);
|
create_directory(SERVER_SETTINGS_DIR,0777);
|
||||||
delete entry;
|
|
||||||
|
|
||||||
BString path(SERVER_SETTINGS_DIR);
|
BFile file(path, B_READ_WRITE | B_ERASE_FILE | B_CREATE_FILE);
|
||||||
path+=COLOR_SETTINGS_NAME;
|
if(file.InitCheck()!=B_OK)
|
||||||
BFile file(path.String(), B_READ_WRITE | B_ERASE_FILE | B_CREATE_FILE);
|
return file.InitCheck();
|
||||||
|
|
||||||
BMessage msg;
|
BMessage msg;
|
||||||
|
|
||||||
set.ConvertToMessage(&msg);
|
set.ConvertToMessage(&msg);
|
||||||
|
|
||||||
msg.Flatten(&file);
|
msg.Flatten(&file);
|
||||||
|
return B_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -679,13 +679,13 @@ DefaultDecorator::_SetFocus()
|
|||||||
// other things when a window is deactivated or activated.
|
// other things when a window is deactivated or activated.
|
||||||
|
|
||||||
if (GetFocus()) {
|
if (GetFocus()) {
|
||||||
fButtonHighColor.SetColor(tint_color(_colors->window_tab.GetColor32(),B_LIGHTEN_2_TINT));
|
fButtonHighColor.SetColor(tint_color(_colors->window_tab,B_LIGHTEN_2_TINT));
|
||||||
fButtonLowColor.SetColor(tint_color(_colors->window_tab.GetColor32(),B_DARKEN_1_TINT));
|
fButtonLowColor.SetColor(tint_color(_colors->window_tab,B_DARKEN_1_TINT));
|
||||||
fTextColor = _colors->window_tab_text;
|
fTextColor = _colors->window_tab_text;
|
||||||
fTabColor = _colors->window_tab;
|
fTabColor = _colors->window_tab;
|
||||||
} else {
|
} else {
|
||||||
fButtonHighColor.SetColor(tint_color(_colors->inactive_window_tab.GetColor32(),B_LIGHTEN_2_TINT));
|
fButtonHighColor.SetColor(tint_color(_colors->inactive_window_tab,B_LIGHTEN_2_TINT));
|
||||||
fButtonLowColor.SetColor(tint_color(_colors->inactive_window_tab.GetColor32(),B_DARKEN_1_TINT));
|
fButtonLowColor.SetColor(tint_color(_colors->inactive_window_tab,B_DARKEN_1_TINT));
|
||||||
fTextColor = _colors->inactive_window_tab_text;
|
fTextColor = _colors->inactive_window_tab_text;
|
||||||
fTabColor = _colors->inactive_window_tab;
|
fTabColor = _colors->inactive_window_tab;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user