Imported DialogPane.cpp 1.3 from the OT repository: shouldn't crash anymore
under Haiku. git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@15915 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
67c3d9ebe5
commit
81202ff522
@ -37,11 +37,12 @@ All rights reserved.
|
||||
#include "Thread.h"
|
||||
#include "Utilities.h"
|
||||
|
||||
void
|
||||
ViewList::RemoveAll(BView *)
|
||||
{
|
||||
EachListItemIgnoreResult(this, &BView::RemoveSelf);
|
||||
}
|
||||
|
||||
const uint32 kValueChanged = 'swch';
|
||||
|
||||
const rgb_color kNormalColor = {150, 150, 150, 255};
|
||||
const rgb_color kHighlightColor = {100, 100, 0, 255};
|
||||
|
||||
|
||||
static void
|
||||
AddSelf(BView *self, BView *to)
|
||||
@ -49,6 +50,14 @@ AddSelf(BView *self, BView *to)
|
||||
to->AddChild(self);
|
||||
}
|
||||
|
||||
|
||||
void
|
||||
ViewList::RemoveAll(BView *)
|
||||
{
|
||||
EachListItemIgnoreResult(this, &BView::RemoveSelf);
|
||||
}
|
||||
|
||||
|
||||
void
|
||||
ViewList::AddAll(BView *toParent)
|
||||
{
|
||||
@ -56,27 +65,30 @@ ViewList::AddAll(BView *toParent)
|
||||
}
|
||||
|
||||
|
||||
// #pragma mark -
|
||||
|
||||
|
||||
DialogPane::DialogPane(BRect mode1Frame, BRect mode2Frame, int32 initialMode,
|
||||
const char *name, uint32 followFlags, uint32 flags)
|
||||
: BView(FrameForMode(initialMode, mode1Frame, mode2Frame, mode2Frame),
|
||||
name, followFlags, flags),
|
||||
fMode1Frame(mode1Frame),
|
||||
fMode2Frame(mode2Frame),
|
||||
fMode3Frame(mode2Frame)
|
||||
: BView(FrameForMode(initialMode, mode1Frame, mode2Frame, mode2Frame),
|
||||
name, followFlags, flags),
|
||||
fMode(initialMode),
|
||||
fMode1Frame(mode1Frame),
|
||||
fMode2Frame(mode2Frame),
|
||||
fMode3Frame(mode2Frame)
|
||||
{
|
||||
SetMode(initialMode, true);
|
||||
}
|
||||
|
||||
|
||||
DialogPane::DialogPane(BRect mode1Frame, BRect mode2Frame, BRect mode3Frame,
|
||||
int32 initialMode, const char *name, uint32 followFlags, uint32 flags)
|
||||
: BView(FrameForMode(initialMode, mode1Frame, mode2Frame, mode3Frame),
|
||||
name, followFlags, flags),
|
||||
fMode1Frame(mode1Frame),
|
||||
fMode2Frame(mode2Frame),
|
||||
fMode3Frame(mode3Frame)
|
||||
: BView(FrameForMode(initialMode, mode1Frame, mode2Frame, mode3Frame),
|
||||
name, followFlags, flags),
|
||||
fMode(initialMode),
|
||||
fMode1Frame(mode1Frame),
|
||||
fMode2Frame(mode2Frame),
|
||||
fMode3Frame(mode3Frame)
|
||||
{
|
||||
SetMode(initialMode, true);
|
||||
}
|
||||
|
||||
|
||||
@ -87,21 +99,21 @@ DialogPane::~DialogPane()
|
||||
}
|
||||
|
||||
|
||||
void
|
||||
void
|
||||
DialogPane::SetMode(int32 mode, bool initialSetup)
|
||||
{
|
||||
ASSERT(mode < 3 && mode >= 0);
|
||||
|
||||
|
||||
if (!initialSetup && mode == fMode)
|
||||
return;
|
||||
|
||||
|
||||
int32 oldMode = fMode;
|
||||
fMode = mode;
|
||||
|
||||
|
||||
bool followBottom = (ResizingMode() & B_FOLLOW_BOTTOM) != 0;
|
||||
// if we are follow bottom, we will move ourselves, need to place us back
|
||||
float bottomOffset = 0;
|
||||
if (followBottom)
|
||||
if (followBottom && Window() != NULL)
|
||||
bottomOffset = Window()->Bounds().bottom - Frame().bottom;
|
||||
|
||||
BRect newBounds(BoundsForMode(fMode));
|
||||
@ -111,9 +123,9 @@ DialogPane::SetMode(int32 mode, bool initialSetup)
|
||||
ResizeTo(newBounds.Width(), newBounds.Height());
|
||||
|
||||
float delta = 0;
|
||||
if (followBottom)
|
||||
if (followBottom && Window() != NULL)
|
||||
delta = (Window()->Bounds().bottom - Frame().bottom) - bottomOffset;
|
||||
|
||||
|
||||
if (delta != 0) {
|
||||
MoveBy(0, delta);
|
||||
if (fLatch && (fLatch->ResizingMode() & B_FOLLOW_BOTTOM))
|
||||
@ -122,60 +134,61 @@ DialogPane::SetMode(int32 mode, bool initialSetup)
|
||||
|
||||
switch (fMode) {
|
||||
case 0:
|
||||
{
|
||||
if (oldMode > 1)
|
||||
fMode3Items.RemoveAll(this);
|
||||
if (oldMode > 0)
|
||||
fMode2Items.RemoveAll(this);
|
||||
|
||||
BView *separator = FindView("separatorLine");
|
||||
if (separator) {
|
||||
BRect frame(separator->Frame());
|
||||
frame.InsetBy(-1, -1);
|
||||
RemoveChild(separator);
|
||||
Invalidate();
|
||||
}
|
||||
|
||||
AddChild(new SeparatorLine(BPoint(newBounds.left, newBounds.top
|
||||
+ newBounds.Height() / 2), newBounds.Width(), false,
|
||||
"separatorLine"));
|
||||
}
|
||||
break;
|
||||
case 1:
|
||||
{
|
||||
if (oldMode > 1)
|
||||
fMode3Items.RemoveAll(this);
|
||||
else
|
||||
fMode2Items.AddAll(this);
|
||||
{
|
||||
if (oldMode > 1)
|
||||
fMode3Items.RemoveAll(this);
|
||||
if (oldMode > 0)
|
||||
fMode2Items.RemoveAll(this);
|
||||
|
||||
BView *separator = FindView("separatorLine");
|
||||
if (separator) {
|
||||
BRect frame(separator->Frame());
|
||||
frame.InsetBy(-1, -1);
|
||||
RemoveChild(separator);
|
||||
Invalidate();
|
||||
}
|
||||
BView *separator = FindView("separatorLine");
|
||||
if (separator) {
|
||||
BRect frame(separator->Frame());
|
||||
frame.InsetBy(-1, -1);
|
||||
RemoveChild(separator);
|
||||
Invalidate();
|
||||
}
|
||||
|
||||
AddChild(new SeparatorLine(BPoint(newBounds.left, newBounds.top
|
||||
+ newBounds.Height() / 2), newBounds.Width(), false,
|
||||
"separatorLine"));
|
||||
break;
|
||||
}
|
||||
case 1:
|
||||
{
|
||||
if (oldMode > 1)
|
||||
fMode3Items.RemoveAll(this);
|
||||
else
|
||||
fMode2Items.AddAll(this);
|
||||
|
||||
BView *separator = FindView("separatorLine");
|
||||
if (separator) {
|
||||
BRect frame(separator->Frame());
|
||||
frame.InsetBy(-1, -1);
|
||||
RemoveChild(separator);
|
||||
Invalidate();
|
||||
}
|
||||
break;
|
||||
}
|
||||
case 2:
|
||||
{
|
||||
fMode3Items.AddAll(this);
|
||||
if (oldMode < 1)
|
||||
fMode2Items.AddAll(this);
|
||||
|
||||
BView *separator = FindView("separatorLine");
|
||||
if (separator) {
|
||||
BRect frame(separator->Frame());
|
||||
frame.InsetBy(-1, -1);
|
||||
RemoveChild(separator);
|
||||
Invalidate();
|
||||
}
|
||||
{
|
||||
fMode3Items.AddAll(this);
|
||||
if (oldMode < 1)
|
||||
fMode2Items.AddAll(this);
|
||||
|
||||
BView *separator = FindView("separatorLine");
|
||||
if (separator) {
|
||||
BRect frame(separator->Frame());
|
||||
frame.InsetBy(-1, -1);
|
||||
RemoveChild(separator);
|
||||
Invalidate();
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void
|
||||
|
||||
void
|
||||
DialogPane::AttachedToWindow()
|
||||
{
|
||||
BView *parent = Parent();
|
||||
@ -183,9 +196,12 @@ DialogPane::AttachedToWindow()
|
||||
SetViewColor(parent->ViewColor());
|
||||
SetLowColor(parent->LowColor());
|
||||
}
|
||||
|
||||
SetMode(fMode, true);
|
||||
}
|
||||
|
||||
void
|
||||
|
||||
void
|
||||
DialogPane::ResizeParentWindow(int32 from, int32 to)
|
||||
{
|
||||
if (!Window())
|
||||
@ -199,7 +215,8 @@ DialogPane::ResizeParentWindow(int32 from, int32 to)
|
||||
Window()->ResizeBy(by.x, by.y);
|
||||
}
|
||||
|
||||
void
|
||||
|
||||
void
|
||||
DialogPane::AddItem(BView *view, int32 toMode)
|
||||
{
|
||||
if (toMode == 1)
|
||||
@ -210,7 +227,8 @@ DialogPane::AddItem(BView *view, int32 toMode)
|
||||
AddChild(view);
|
||||
}
|
||||
|
||||
BRect
|
||||
|
||||
BRect
|
||||
DialogPane::FrameForMode(int32 mode)
|
||||
{
|
||||
switch (mode) {
|
||||
@ -224,7 +242,8 @@ DialogPane::FrameForMode(int32 mode)
|
||||
return fMode1Frame;
|
||||
}
|
||||
|
||||
BRect
|
||||
|
||||
BRect
|
||||
DialogPane::BoundsForMode(int32 mode)
|
||||
{
|
||||
BRect result;
|
||||
@ -243,7 +262,8 @@ DialogPane::BoundsForMode(int32 mode)
|
||||
return result;
|
||||
}
|
||||
|
||||
BRect
|
||||
|
||||
BRect
|
||||
DialogPane::FrameForMode(int32 mode, BRect mode1Frame, BRect mode2Frame,
|
||||
BRect mode3Frame)
|
||||
{
|
||||
@ -258,9 +278,8 @@ DialogPane::FrameForMode(int32 mode, BRect mode1Frame, BRect mode2Frame,
|
||||
return mode1Frame;
|
||||
}
|
||||
|
||||
const uint32 kValueChanged = 'swch';
|
||||
|
||||
void
|
||||
void
|
||||
DialogPane::SetSwitch(BControl *control)
|
||||
{
|
||||
fLatch = control;
|
||||
@ -268,7 +287,8 @@ DialogPane::SetSwitch(BControl *control)
|
||||
control->SetTarget(this);
|
||||
}
|
||||
|
||||
void
|
||||
|
||||
void
|
||||
DialogPane::MessageReceived(BMessage *message)
|
||||
{
|
||||
if (message->what == kValueChanged) {
|
||||
@ -279,6 +299,10 @@ DialogPane::MessageReceived(BMessage *message)
|
||||
_inherited::MessageReceived(message);
|
||||
}
|
||||
|
||||
|
||||
// #pragma mark -
|
||||
|
||||
|
||||
PaneSwitch::PaneSwitch(BRect frame, const char *name, bool leftAligned,
|
||||
uint32 resizeMask, uint32 flags)
|
||||
: BControl(frame, name, "", 0, resizeMask, flags),
|
||||
@ -287,7 +311,8 @@ PaneSwitch::PaneSwitch(BRect frame, const char *name, bool leftAligned,
|
||||
{
|
||||
}
|
||||
|
||||
void
|
||||
|
||||
void
|
||||
PaneSwitch::DoneTracking(BPoint point)
|
||||
{
|
||||
BRect bounds(Bounds());
|
||||
@ -301,7 +326,8 @@ PaneSwitch::DoneTracking(BPoint point)
|
||||
}
|
||||
}
|
||||
|
||||
void
|
||||
|
||||
void
|
||||
PaneSwitch::Track(BPoint point, uint32)
|
||||
{
|
||||
BRect bounds(Bounds());
|
||||
@ -315,12 +341,12 @@ PaneSwitch::Track(BPoint point, uint32)
|
||||
}
|
||||
|
||||
|
||||
void
|
||||
void
|
||||
PaneSwitch::MouseDown(BPoint)
|
||||
{
|
||||
if (!IsEnabled())
|
||||
return;
|
||||
|
||||
|
||||
fPressing = true;
|
||||
MouseDownThread<PaneSwitch>::TrackMouse(this, &PaneSwitch::DoneTracking,
|
||||
&PaneSwitch::Track);
|
||||
@ -328,9 +354,6 @@ PaneSwitch::MouseDown(BPoint)
|
||||
}
|
||||
|
||||
|
||||
const rgb_color kNormalColor = {150, 150, 150, 255};
|
||||
const rgb_color kHighlightColor = {100, 100, 0, 255};
|
||||
|
||||
void
|
||||
PaneSwitch::Draw(BRect)
|
||||
{
|
||||
@ -341,7 +364,6 @@ PaneSwitch::Draw(BRect)
|
||||
else
|
||||
DrawInState(kCollapsed);
|
||||
|
||||
|
||||
rgb_color markColor = ui_color(B_KEYBOARD_NAVIGATION_COLOR);
|
||||
|
||||
bool focused = IsFocus() && Window()->IsActive();
|
||||
@ -354,7 +376,8 @@ PaneSwitch::Draw(BRect)
|
||||
EndLineArray();
|
||||
}
|
||||
|
||||
void
|
||||
|
||||
void
|
||||
PaneSwitch::DrawInState(PaneSwitch::State state)
|
||||
{
|
||||
BRect rect(0, 0, 10, 10);
|
||||
@ -362,9 +385,8 @@ PaneSwitch::DrawInState(PaneSwitch::State state)
|
||||
rgb_color outlineColor = {0, 0, 0, 255};
|
||||
rgb_color middleColor = state == kPressed ? kHighlightColor : kNormalColor;
|
||||
|
||||
|
||||
SetDrawingMode(B_OP_COPY);
|
||||
|
||||
|
||||
switch (state) {
|
||||
case kCollapsed:
|
||||
BeginLineArray(6);
|
||||
@ -376,7 +398,7 @@ PaneSwitch::DrawInState(PaneSwitch::State state)
|
||||
BPoint(rect.left + 7, rect.top + 5), outlineColor);
|
||||
AddLine(BPoint(rect.left + 7, rect.top + 5),
|
||||
BPoint(rect.left + 3, rect.bottom - 1), outlineColor);
|
||||
|
||||
|
||||
AddLine(BPoint(rect.left + 4, rect.top + 3),
|
||||
BPoint(rect.left + 4, rect.bottom - 3), middleColor);
|
||||
AddLine(BPoint(rect.left + 5, rect.top + 4),
|
||||
@ -390,7 +412,7 @@ PaneSwitch::DrawInState(PaneSwitch::State state)
|
||||
BPoint(rect.right - 7, rect.top + 5), outlineColor);
|
||||
AddLine(BPoint(rect.right - 7, rect.top + 5),
|
||||
BPoint(rect.right - 3, rect.bottom - 1), outlineColor);
|
||||
|
||||
|
||||
AddLine(BPoint(rect.right - 4, rect.top + 3),
|
||||
BPoint(rect.right - 4, rect.bottom - 3), middleColor);
|
||||
AddLine(BPoint(rect.right - 5, rect.top + 4),
|
||||
@ -410,7 +432,7 @@ PaneSwitch::DrawInState(PaneSwitch::State state)
|
||||
BPoint(rect.left + 7, rect.top + 7), outlineColor);
|
||||
AddLine(BPoint(rect.left + 1, rect.top + 7),
|
||||
BPoint(rect.left + 7, rect.top + 1), outlineColor);
|
||||
|
||||
|
||||
AddLine(BPoint(rect.left + 3, rect.top + 6),
|
||||
BPoint(rect.left + 6, rect.top + 6), middleColor);
|
||||
AddLine(BPoint(rect.left + 4, rect.top + 5),
|
||||
@ -426,7 +448,7 @@ PaneSwitch::DrawInState(PaneSwitch::State state)
|
||||
BPoint(rect.right - 7, rect.top + 7), outlineColor);
|
||||
AddLine(BPoint(rect.right - 1, rect.top + 7),
|
||||
BPoint(rect.right - 7, rect.top + 1), outlineColor);
|
||||
|
||||
|
||||
AddLine(BPoint(rect.right - 3, rect.top + 6),
|
||||
BPoint(rect.right - 6, rect.top + 6), middleColor);
|
||||
AddLine(BPoint(rect.right - 4, rect.top + 5),
|
||||
|
Loading…
x
Reference in New Issue
Block a user