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:
Axel Dörfler 2006-01-11 20:16:28 +00:00
parent 67c3d9ebe5
commit 81202ff522

View File

@ -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),