Implemented kLeftTitledWindowLook.
git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@16672 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
a7dc1efbac
commit
083ec97572
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright 2001-2005, Haiku.
|
* Copyright 2001-2006, Haiku.
|
||||||
* Distributed under the terms of the MIT License.
|
* Distributed under the terms of the MIT License.
|
||||||
*
|
*
|
||||||
* Authors:
|
* Authors:
|
||||||
@ -23,6 +23,8 @@
|
|||||||
#include <Rect.h>
|
#include <Rect.h>
|
||||||
#include <View.h>
|
#include <View.h>
|
||||||
|
|
||||||
|
#include <WindowPrivate.h>
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
|
||||||
//#define DEBUG_DECORATOR
|
//#define DEBUG_DECORATOR
|
||||||
@ -112,9 +114,11 @@ DefaultDecorator::SetLook(DesktopSettings& settings,
|
|||||||
}
|
}
|
||||||
|
|
||||||
ServerFont font;
|
ServerFont font;
|
||||||
if (look == B_FLOATING_WINDOW_LOOK)
|
if (look == B_FLOATING_WINDOW_LOOK || look == kLeftTitledWindowLook) {
|
||||||
settings.GetDefaultPlainFont(font);
|
settings.GetDefaultPlainFont(font);
|
||||||
else
|
if (look == kLeftTitledWindowLook)
|
||||||
|
font.SetRotation(90.0f);
|
||||||
|
} else
|
||||||
settings.GetDefaultBoldFont(font);
|
settings.GetDefaultBoldFont(font);
|
||||||
|
|
||||||
font.SetFlags(B_FORCE_ANTIALIASING);
|
font.SetFlags(B_FORCE_ANTIALIASING);
|
||||||
@ -179,8 +183,8 @@ DefaultDecorator::ResizeBy(BPoint pt, BRegion* dirty)
|
|||||||
{
|
{
|
||||||
STRACE(("DefaultDecorator: Resize By (%.1f, %.1f)\n", pt.x, pt.y));
|
STRACE(("DefaultDecorator: Resize By (%.1f, %.1f)\n", pt.x, pt.y));
|
||||||
// Move all internal rectangles the appropriate amount
|
// Move all internal rectangles the appropriate amount
|
||||||
_frame.right += pt.x;
|
_frame.right += pt.x;
|
||||||
_frame.bottom += pt.y;
|
_frame.bottom += pt.y;
|
||||||
|
|
||||||
// handle invalidation of resize rect
|
// handle invalidation of resize rect
|
||||||
if (dirty && !(fFlags & B_NOT_RESIZABLE)) {
|
if (dirty && !(fFlags & B_NOT_RESIZABLE)) {
|
||||||
@ -197,6 +201,7 @@ DefaultDecorator::ResizeBy(BPoint pt, BRegion* dirty)
|
|||||||
case B_TITLED_WINDOW_LOOK:
|
case B_TITLED_WINDOW_LOOK:
|
||||||
case B_FLOATING_WINDOW_LOOK:
|
case B_FLOATING_WINDOW_LOOK:
|
||||||
case B_MODAL_WINDOW_LOOK:
|
case B_MODAL_WINDOW_LOOK:
|
||||||
|
case kLeftTitledWindowLook:
|
||||||
realResizeRect.Set(fRightBorder.right - 22, fBottomBorder.top,
|
realResizeRect.Set(fRightBorder.right - 22, fBottomBorder.top,
|
||||||
fRightBorder.right - 22, fBottomBorder.bottom - 1);
|
fRightBorder.right - 22, fBottomBorder.bottom - 1);
|
||||||
// resize rect at old location
|
// resize rect at old location
|
||||||
@ -260,19 +265,29 @@ DefaultDecorator::ResizeBy(BPoint pt, BRegion* dirty)
|
|||||||
|
|
||||||
// resize tab and layout tab items
|
// resize tab and layout tab items
|
||||||
if (_tabrect.IsValid()) {
|
if (_tabrect.IsValid()) {
|
||||||
float tabWidth = fRightBorder.right - fLeftBorder.left;
|
float tabSize;
|
||||||
|
if (fLook != kLeftTitledWindowLook)
|
||||||
if (tabWidth < fMinTabWidth)
|
tabSize = fRightBorder.right - fLeftBorder.left;
|
||||||
tabWidth = fMinTabWidth;
|
else
|
||||||
if (tabWidth > fMaxTabWidth)
|
tabSize = fBottomBorder.bottom - fTopBorder.top;
|
||||||
tabWidth = fMaxTabWidth;
|
|
||||||
|
if (tabSize < fMinTabSize)
|
||||||
if (tabWidth != _tabrect.Width()) {
|
tabSize = fMinTabSize;
|
||||||
|
if (tabSize > fMaxTabSize)
|
||||||
|
tabSize = fMaxTabSize;
|
||||||
|
|
||||||
|
if (fLook != kLeftTitledWindowLook && tabSize != _tabrect.Width()) {
|
||||||
// NOTE: the tab rect becoming smaller is handled
|
// NOTE: the tab rect becoming smaller is handled
|
||||||
// by the Desktop anyways, so it is sufficient
|
// by the Desktop anyways, so it is sufficient
|
||||||
// to include it into the dirty region in it's
|
// to include it into the dirty region in it's
|
||||||
// final state only once at the end
|
// final state only once at the end
|
||||||
_tabrect.right = _tabrect.left + tabWidth;
|
_tabrect.right = _tabrect.left + tabSize;
|
||||||
|
_LayoutTabItems(_tabrect);
|
||||||
|
|
||||||
|
if (dirty)
|
||||||
|
dirty->Include(_tabrect);
|
||||||
|
} else if (fLook == kLeftTitledWindowLook && tabSize != _tabrect.Height()) {
|
||||||
|
_tabrect.bottom = _tabrect.top + tabSize;
|
||||||
_LayoutTabItems(_tabrect);
|
_LayoutTabItems(_tabrect);
|
||||||
|
|
||||||
if (dirty)
|
if (dirty)
|
||||||
@ -285,7 +300,8 @@ DefaultDecorator::ResizeBy(BPoint pt, BRegion* dirty)
|
|||||||
void
|
void
|
||||||
DefaultDecorator::Draw(BRect update)
|
DefaultDecorator::Draw(BRect update)
|
||||||
{
|
{
|
||||||
STRACE(("DefaultDecorator: Draw(%.1f,%.1f,%.1f,%.1f)\n",update.left,update.top,update.right,update.bottom));
|
STRACE(("DefaultDecorator: Draw(%.1f,%.1f,%.1f,%.1f)\n",
|
||||||
|
update.left, update.top, update.right, update.bottom));
|
||||||
|
|
||||||
// We need to draw a few things: the tab, the resize thumb, the borders,
|
// We need to draw a few things: the tab, the resize thumb, the borders,
|
||||||
// and the buttons
|
// and the buttons
|
||||||
@ -311,7 +327,7 @@ DefaultDecorator::GetSizeLimits(int32* minWidth, int32* minHeight,
|
|||||||
int32* maxWidth, int32* maxHeight) const
|
int32* maxWidth, int32* maxHeight) const
|
||||||
{
|
{
|
||||||
if (_tabrect.IsValid())
|
if (_tabrect.IsValid())
|
||||||
*minWidth = (int32)roundf(max_c(*minWidth, fMinTabWidth - 2 * fBorderWidth));
|
*minWidth = (int32)roundf(max_c(*minWidth, fMinTabSize - 2 * fBorderWidth));
|
||||||
if (_resizerect.IsValid())
|
if (_resizerect.IsValid())
|
||||||
*minHeight = (int32)roundf(max_c(*minHeight, _resizerect.Height() - fBorderWidth));
|
*minHeight = (int32)roundf(max_c(*minHeight, _resizerect.Height() - fBorderWidth));
|
||||||
}
|
}
|
||||||
@ -394,7 +410,8 @@ DefaultDecorator::Clicked(BPoint pt, int32 buttons, int32 modifiers)
|
|||||||
if (!(fFlags & B_NOT_RESIZABLE)
|
if (!(fFlags & B_NOT_RESIZABLE)
|
||||||
&& (fLook == B_TITLED_WINDOW_LOOK
|
&& (fLook == B_TITLED_WINDOW_LOOK
|
||||||
|| fLook == B_FLOATING_WINDOW_LOOK
|
|| fLook == B_FLOATING_WINDOW_LOOK
|
||||||
|| fLook == B_MODAL_WINDOW_LOOK)) {
|
|| fLook == B_MODAL_WINDOW_LOOK
|
||||||
|
|| fLook == kLeftTitledWindowLook)) {
|
||||||
BRect temp(BPoint(fBottomBorder.right - 18, fBottomBorder.bottom - 18),
|
BRect temp(BPoint(fBottomBorder.right - 18, fBottomBorder.bottom - 18),
|
||||||
fBottomBorder.RightBottom());
|
fBottomBorder.RightBottom());
|
||||||
if (temp.Contains(pt))
|
if (temp.Contains(pt))
|
||||||
@ -441,6 +458,7 @@ DefaultDecorator::_DoLayout()
|
|||||||
fBorderWidth = 5;
|
fBorderWidth = 5;
|
||||||
break;
|
break;
|
||||||
case B_FLOATING_WINDOW_LOOK:
|
case B_FLOATING_WINDOW_LOOK:
|
||||||
|
case kLeftTitledWindowLook:
|
||||||
hasTab = true;
|
hasTab = true;
|
||||||
fBorderWidth = 3;
|
fBorderWidth = 3;
|
||||||
break;
|
break;
|
||||||
@ -452,24 +470,30 @@ DefaultDecorator::_DoLayout()
|
|||||||
default:
|
default:
|
||||||
fBorderWidth = 0;
|
fBorderWidth = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
// calculate our tab rect
|
// calculate our tab rect
|
||||||
if (hasTab) {
|
if (hasTab) {
|
||||||
// tab is initially on the left
|
// tab is initially on the left
|
||||||
fTabOffset = 0;
|
fTabOffset = 0;
|
||||||
// distance from one item of the tab bar to another.
|
// distance from one item of the tab bar to another.
|
||||||
// In this case the text and close/zoom rects
|
// In this case the text and close/zoom rects
|
||||||
fTextOffset = (fLook == B_FLOATING_WINDOW_LOOK) ? 10 : 18;
|
fTextOffset = (fLook == B_FLOATING_WINDOW_LOOK || fLook == kLeftTitledWindowLook)
|
||||||
|
? 10 : 18;
|
||||||
|
|
||||||
font_height fontHeight;
|
font_height fontHeight;
|
||||||
fDrawState.Font().GetHeight(fontHeight);
|
fDrawState.Font().GetHeight(fontHeight);
|
||||||
|
|
||||||
_tabrect.Set(_frame.left - fBorderWidth,
|
if (fLook != kLeftTitledWindowLook) {
|
||||||
_frame.top - fBorderWidth
|
_tabrect.Set(_frame.left - fBorderWidth,
|
||||||
- ceilf(fontHeight.ascent + fontHeight.descent + 7.0),
|
_frame.top - fBorderWidth - ceilf(fontHeight.ascent + fontHeight.descent + 7.0),
|
||||||
((_frame.right - _frame.left) < 35.0 ?
|
((_frame.right - _frame.left) < 35.0 ?
|
||||||
_frame.left + 35.0 : _frame.right) + fBorderWidth,
|
_frame.left + 35.0 : _frame.right) + fBorderWidth,
|
||||||
_frame.top - fBorderWidth);
|
_frame.top - fBorderWidth);
|
||||||
|
} else {
|
||||||
|
_tabrect.Set(_frame.left - fBorderWidth - ceilf(fontHeight.ascent + fontHeight.descent + 5.0),
|
||||||
|
_frame.top - fBorderWidth, _frame.left - fBorderWidth,
|
||||||
|
_frame.bottom + fBorderWidth);
|
||||||
|
}
|
||||||
|
|
||||||
// format tab rect for a floating window - make the rect smaller
|
// format tab rect for a floating window - make the rect smaller
|
||||||
if (fLook == B_FLOATING_WINDOW_LOOK) {
|
if (fLook == B_FLOATING_WINDOW_LOOK) {
|
||||||
@ -481,33 +505,37 @@ DefaultDecorator::_DoLayout()
|
|||||||
float size;
|
float size;
|
||||||
_GetButtonSizeAndOffset(_tabrect, &offset, &size);
|
_GetButtonSizeAndOffset(_tabrect, &offset, &size);
|
||||||
|
|
||||||
// fMinTabWidth contains just the room for the buttons
|
// fMinTabSize contains just the room for the buttons
|
||||||
fMinTabWidth = 4.0 + fTextOffset;
|
fMinTabSize = 4.0 + fTextOffset;
|
||||||
if (!(fFlags & B_NOT_CLOSABLE))
|
if ((fFlags & B_NOT_CLOSABLE) == 0)
|
||||||
fMinTabWidth += offset + size;
|
fMinTabSize += offset + size;
|
||||||
if (!(fFlags & B_NOT_ZOOMABLE))
|
if ((fFlags & B_NOT_ZOOMABLE) == 0)
|
||||||
fMinTabWidth += offset + size;
|
fMinTabSize += offset + size;
|
||||||
|
|
||||||
// fMaxTabWidth contains fMinWidth + the width required for the title
|
// fMaxTabSize contains fMinWidth + the width required for the title
|
||||||
fMaxTabWidth = _driver ? _driver->StringWidth(Title(), strlen(Title()),
|
fMaxTabSize = _driver ? ceilf(_driver->StringWidth(Title(), strlen(Title()),
|
||||||
&fDrawState) : 0.0;
|
&fDrawState)) : 0.0;
|
||||||
if (fMaxTabWidth > 0.0)
|
if (fMaxTabSize > 0.0)
|
||||||
fMaxTabWidth += fTextOffset;
|
fMaxTabSize += fTextOffset;
|
||||||
fMaxTabWidth += fMinTabWidth;
|
fMaxTabSize += fMinTabSize;
|
||||||
|
|
||||||
float tabWidth = _frame.Width();
|
float tabSize = fLook != kLeftTitledWindowLook ? _frame.Width() : _frame.Height();
|
||||||
if (tabWidth < fMinTabWidth)
|
if (tabSize < fMinTabSize)
|
||||||
tabWidth = fMinTabWidth;
|
tabSize = fMinTabSize;
|
||||||
if (tabWidth > fMaxTabWidth)
|
if (tabSize > fMaxTabSize)
|
||||||
tabWidth = fMaxTabWidth;
|
tabSize = fMaxTabSize;
|
||||||
|
|
||||||
// layout buttons and truncate text
|
// layout buttons and truncate text
|
||||||
_tabrect.right = _tabrect.left + tabWidth;
|
if (fLook != kLeftTitledWindowLook)
|
||||||
|
_tabrect.right = _tabrect.left + tabSize;
|
||||||
|
else
|
||||||
|
_tabrect.bottom = _tabrect.top + tabSize;
|
||||||
|
|
||||||
_LayoutTabItems(_tabrect);
|
_LayoutTabItems(_tabrect);
|
||||||
} else {
|
} else {
|
||||||
// no tab
|
// no tab
|
||||||
fMinTabWidth = 0.0;
|
fMinTabSize = 0.0;
|
||||||
fMaxTabWidth = 0.0;
|
fMaxTabSize = 0.0;
|
||||||
_tabrect.Set(0.0, 0.0, -1.0, -1.0);
|
_tabrect.Set(0.0, 0.0, -1.0, -1.0);
|
||||||
_closerect.Set(0.0, 0.0, -1.0, -1.0);
|
_closerect.Set(0.0, 0.0, -1.0, -1.0);
|
||||||
_zoomrect.Set(0.0, 0.0, -1.0, -1.0);
|
_zoomrect.Set(0.0, 0.0, -1.0, -1.0);
|
||||||
@ -562,8 +590,9 @@ STRACE(("_DrawFrame(%f,%f,%f,%f)\n", invalid.left, invalid.top,
|
|||||||
switch (fLook) {
|
switch (fLook) {
|
||||||
case B_TITLED_WINDOW_LOOK:
|
case B_TITLED_WINDOW_LOOK:
|
||||||
case B_DOCUMENT_WINDOW_LOOK:
|
case B_DOCUMENT_WINDOW_LOOK:
|
||||||
case B_MODAL_WINDOW_LOOK: {
|
case B_MODAL_WINDOW_LOOK:
|
||||||
//top
|
{
|
||||||
|
// top
|
||||||
if (invalid.Intersects(fTopBorder)) {
|
if (invalid.Intersects(fTopBorder)) {
|
||||||
for (int8 i = 0; i < 5; i++) {
|
for (int8 i = 0; i < 5; i++) {
|
||||||
_driver->StrokeLine(BPoint(r.left + i, r.top + i),
|
_driver->StrokeLine(BPoint(r.left + i, r.top + i),
|
||||||
@ -577,7 +606,7 @@ STRACE(("_DrawFrame(%f,%f,%f,%f)\n", invalid.left, invalid.top,
|
|||||||
fFrameColors[2]);
|
fFrameColors[2]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
//left
|
// left
|
||||||
if (invalid.Intersects(fLeftBorder.InsetByCopy(0, -fBorderWidth))) {
|
if (invalid.Intersects(fLeftBorder.InsetByCopy(0, -fBorderWidth))) {
|
||||||
for (int8 i = 0; i < 5; i++) {
|
for (int8 i = 0; i < 5; i++) {
|
||||||
_driver->StrokeLine(BPoint(r.left + i, r.top + i),
|
_driver->StrokeLine(BPoint(r.left + i, r.top + i),
|
||||||
@ -585,7 +614,7 @@ STRACE(("_DrawFrame(%f,%f,%f,%f)\n", invalid.left, invalid.top,
|
|||||||
fFrameColors[i]);
|
fFrameColors[i]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
//bottom
|
// bottom
|
||||||
if (invalid.Intersects(fBottomBorder)) {
|
if (invalid.Intersects(fBottomBorder)) {
|
||||||
for (int8 i = 0; i < 5; i++) {
|
for (int8 i = 0; i < 5; i++) {
|
||||||
_driver->StrokeLine(BPoint(r.left + i, r.bottom - i),
|
_driver->StrokeLine(BPoint(r.left + i, r.bottom - i),
|
||||||
@ -593,7 +622,7 @@ STRACE(("_DrawFrame(%f,%f,%f,%f)\n", invalid.left, invalid.top,
|
|||||||
fFrameColors[(4 - i) == 4 ? 5 : (4 - i)]);
|
fFrameColors[(4 - i) == 4 ? 5 : (4 - i)]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
//right
|
// right
|
||||||
if (invalid.Intersects(fRightBorder.InsetByCopy(0, -fBorderWidth))) {
|
if (invalid.Intersects(fRightBorder.InsetByCopy(0, -fBorderWidth))) {
|
||||||
for (int8 i = 0; i < 5; i++) {
|
for (int8 i = 0; i < 5; i++) {
|
||||||
_driver->StrokeLine(BPoint(r.right - i, r.top + i),
|
_driver->StrokeLine(BPoint(r.right - i, r.top + i),
|
||||||
@ -603,30 +632,39 @@ STRACE(("_DrawFrame(%f,%f,%f,%f)\n", invalid.left, invalid.top,
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case B_FLOATING_WINDOW_LOOK: {
|
|
||||||
//top
|
case B_FLOATING_WINDOW_LOOK:
|
||||||
|
case kLeftTitledWindowLook:
|
||||||
|
{
|
||||||
|
// top
|
||||||
if (invalid.Intersects(fTopBorder)) {
|
if (invalid.Intersects(fTopBorder)) {
|
||||||
for (int8 i = 0; i < 3; i++) {
|
for (int8 i = 0; i < 3; i++) {
|
||||||
_driver->StrokeLine(BPoint(r.left + i, r.top + i),
|
_driver->StrokeLine(BPoint(r.left + i, r.top + i),
|
||||||
BPoint(r.right - i, r.top + i),
|
BPoint(r.right - i, r.top + i),
|
||||||
fFrameColors[i * 2]);
|
fFrameColors[i * 2]);
|
||||||
}
|
}
|
||||||
if (_tabrect.IsValid()) {
|
if (_tabrect.IsValid() && fLook != kLeftTitledWindowLook) {
|
||||||
// grey along the bottom of the tab (overwrites "white" from frame)
|
// grey along the bottom of the tab (overwrites "white" from frame)
|
||||||
_driver->StrokeLine(BPoint(_tabrect.left + 2, _tabrect.bottom + 1),
|
_driver->StrokeLine(BPoint(_tabrect.left + 2, _tabrect.bottom + 1),
|
||||||
BPoint(_tabrect.right - 2, _tabrect.bottom + 1),
|
BPoint(_tabrect.right - 2, _tabrect.bottom + 1),
|
||||||
fFrameColors[2]);
|
fFrameColors[2]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
//left
|
// left
|
||||||
if (invalid.Intersects(fLeftBorder.InsetByCopy(0, -fBorderWidth))) {
|
if (invalid.Intersects(fLeftBorder.InsetByCopy(0, -fBorderWidth))) {
|
||||||
for (int8 i = 0; i < 3; i++) {
|
for (int8 i = 0; i < 3; i++) {
|
||||||
_driver->StrokeLine(BPoint(r.left + i, r.top + i),
|
_driver->StrokeLine(BPoint(r.left + i, r.top + i),
|
||||||
BPoint(r.left + i, r.bottom - i),
|
BPoint(r.left + i, r.bottom - i),
|
||||||
fFrameColors[i * 2]);
|
fFrameColors[i * 2]);
|
||||||
}
|
}
|
||||||
|
if (fLook == kLeftTitledWindowLook && _tabrect.IsValid()) {
|
||||||
|
// grey along the right side of the tab (overwrites "white" from frame)
|
||||||
|
_driver->StrokeLine(BPoint(_tabrect.right + 1, _tabrect.top + 2),
|
||||||
|
BPoint(_tabrect.right + 1, _tabrect.bottom - 2),
|
||||||
|
fFrameColors[2]);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
//bottom
|
// bottom
|
||||||
if (invalid.Intersects(fBottomBorder)) {
|
if (invalid.Intersects(fBottomBorder)) {
|
||||||
for (int8 i = 0; i < 3; i++) {
|
for (int8 i = 0; i < 3; i++) {
|
||||||
_driver->StrokeLine(BPoint(r.left + i, r.bottom - i),
|
_driver->StrokeLine(BPoint(r.left + i, r.bottom - i),
|
||||||
@ -634,7 +672,7 @@ STRACE(("_DrawFrame(%f,%f,%f,%f)\n", invalid.left, invalid.top,
|
|||||||
fFrameColors[(2 - i) == 2 ? 5 : (2 - i) * 2]);
|
fFrameColors[(2 - i) == 2 ? 5 : (2 - i) * 2]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
//right
|
// right
|
||||||
if (invalid.Intersects(fRightBorder.InsetByCopy(0, -fBorderWidth))) {
|
if (invalid.Intersects(fRightBorder.InsetByCopy(0, -fBorderWidth))) {
|
||||||
for (int8 i = 0; i < 3; i++) {
|
for (int8 i = 0; i < 3; i++) {
|
||||||
_driver->StrokeLine(BPoint(r.right - i, r.top + i),
|
_driver->StrokeLine(BPoint(r.right - i, r.top + i),
|
||||||
@ -644,10 +682,10 @@ STRACE(("_DrawFrame(%f,%f,%f,%f)\n", invalid.left, invalid.top,
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case B_BORDERED_WINDOW_LOOK: {
|
|
||||||
|
case B_BORDERED_WINDOW_LOOK:
|
||||||
_driver->StrokeRect(r, fFrameColors[5]);
|
_driver->StrokeRect(r, fFrameColors[5]);
|
||||||
break;
|
break;
|
||||||
}
|
|
||||||
|
|
||||||
default:
|
default:
|
||||||
// don't draw a border frame
|
// don't draw a border frame
|
||||||
@ -658,8 +696,9 @@ STRACE(("_DrawFrame(%f,%f,%f,%f)\n", invalid.left, invalid.top,
|
|||||||
if (!(fFlags & B_NOT_RESIZABLE)) {
|
if (!(fFlags & B_NOT_RESIZABLE)) {
|
||||||
r = _resizerect;
|
r = _resizerect;
|
||||||
|
|
||||||
switch (fLook){
|
switch (fLook) {
|
||||||
case B_DOCUMENT_WINDOW_LOOK: {
|
case B_DOCUMENT_WINDOW_LOOK:
|
||||||
|
{
|
||||||
if (!invalid.Intersects(r))
|
if (!invalid.Intersects(r))
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -667,10 +706,14 @@ STRACE(("_DrawFrame(%f,%f,%f,%f)\n", invalid.left, invalid.top,
|
|||||||
float y = r.bottom - 3;
|
float y = r.bottom - 3;
|
||||||
|
|
||||||
_driver->FillRect(BRect(x - 13, y - 13, x, y), fFrameColors[2]);
|
_driver->FillRect(BRect(x - 13, y - 13, x, y), fFrameColors[2]);
|
||||||
_driver->StrokeLine(BPoint(x - 15, y - 15), BPoint(x - 15, y - 2), fFrameColors[0]);
|
_driver->StrokeLine(BPoint(x - 15, y - 15), BPoint(x - 15, y - 2),
|
||||||
_driver->StrokeLine(BPoint(x - 14, y - 14), BPoint(x - 14, y - 1), fFrameColors[1]);
|
fFrameColors[0]);
|
||||||
_driver->StrokeLine(BPoint(x - 15, y - 15), BPoint(x - 2, y - 15), fFrameColors[0]);
|
_driver->StrokeLine(BPoint(x - 14, y - 14), BPoint(x - 14, y - 1),
|
||||||
_driver->StrokeLine(BPoint(x - 14, y - 14), BPoint(x - 1, y - 14), fFrameColors[1]);
|
fFrameColors[1]);
|
||||||
|
_driver->StrokeLine(BPoint(x - 15, y - 15), BPoint(x - 2, y - 15),
|
||||||
|
fFrameColors[0]);
|
||||||
|
_driver->StrokeLine(BPoint(x - 14, y - 14), BPoint(x - 1, y - 14),
|
||||||
|
fFrameColors[1]);
|
||||||
|
|
||||||
if (!IsFocus())
|
if (!IsFocus())
|
||||||
break;
|
break;
|
||||||
@ -688,10 +731,12 @@ STRACE(("_DrawFrame(%f,%f,%f,%f)\n", invalid.left, invalid.top,
|
|||||||
|
|
||||||
case B_TITLED_WINDOW_LOOK:
|
case B_TITLED_WINDOW_LOOK:
|
||||||
case B_FLOATING_WINDOW_LOOK:
|
case B_FLOATING_WINDOW_LOOK:
|
||||||
case B_MODAL_WINDOW_LOOK: {
|
case B_MODAL_WINDOW_LOOK:
|
||||||
|
case kLeftTitledWindowLook:
|
||||||
if (!invalid.Intersects(BRect(fRightBorder.right - 22, fBottomBorder.bottom - 22,
|
{
|
||||||
fRightBorder.right - 1, fBottomBorder.bottom - 1)))
|
if (!invalid.Intersects(BRect(fRightBorder.right - 22,
|
||||||
|
fBottomBorder.bottom - 22, fRightBorder.right - 1,
|
||||||
|
fBottomBorder.bottom - 1)))
|
||||||
break;
|
break;
|
||||||
|
|
||||||
_driver->StrokeLine(BPoint(fRightBorder.left, fBottomBorder.bottom - 22),
|
_driver->StrokeLine(BPoint(fRightBorder.left, fBottomBorder.bottom - 22),
|
||||||
@ -703,10 +748,9 @@ STRACE(("_DrawFrame(%f,%f,%f,%f)\n", invalid.left, invalid.top,
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
default: {
|
default:
|
||||||
// don't draw resize corner
|
// don't draw resize corner
|
||||||
break;
|
break;
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -731,23 +775,35 @@ DefaultDecorator::_DrawTab(BRect invalid)
|
|||||||
// outer frame
|
// outer frame
|
||||||
_driver->StrokeLine(_tabrect.LeftTop(), _tabrect.LeftBottom(), fFrameColors[0]);
|
_driver->StrokeLine(_tabrect.LeftTop(), _tabrect.LeftBottom(), fFrameColors[0]);
|
||||||
_driver->StrokeLine(_tabrect.LeftTop(), _tabrect.RightTop(), fFrameColors[0]);
|
_driver->StrokeLine(_tabrect.LeftTop(), _tabrect.RightTop(), fFrameColors[0]);
|
||||||
_driver->StrokeLine(_tabrect.RightTop(),_tabrect.RightBottom(), fFrameColors[5]);
|
if (fLook != kLeftTitledWindowLook)
|
||||||
|
_driver->StrokeLine(_tabrect.RightTop(),_tabrect.RightBottom(), fFrameColors[5]);
|
||||||
|
else
|
||||||
|
_driver->StrokeLine(_tabrect.LeftBottom(),_tabrect.RightBottom(), fFrameColors[5]);
|
||||||
|
|
||||||
// bevel
|
// bevel
|
||||||
_driver->StrokeLine(BPoint(_tabrect.left + 1, _tabrect.top + 1),
|
_driver->StrokeLine(BPoint(_tabrect.left + 1, _tabrect.top + 1),
|
||||||
BPoint(_tabrect.left + 1, _tabrect.bottom),
|
BPoint(_tabrect.left + 1, _tabrect.bottom - (fLook == kLeftTitledWindowLook ? 1 : 0)),
|
||||||
tabColorLight);
|
tabColorLight);
|
||||||
_driver->StrokeLine(BPoint(_tabrect.left + 1, _tabrect.top + 1),
|
_driver->StrokeLine(BPoint(_tabrect.left + 1, _tabrect.top + 1),
|
||||||
BPoint(_tabrect.right - 1, _tabrect.top + 1),
|
BPoint(_tabrect.right - (fLook == kLeftTitledWindowLook ? 0 : 1), _tabrect.top + 1),
|
||||||
tabColorLight);
|
tabColorLight);
|
||||||
|
|
||||||
_driver->StrokeLine(BPoint(_tabrect.right - 1, _tabrect.top + 2),
|
if (fLook != kLeftTitledWindowLook) {
|
||||||
BPoint(_tabrect.right - 1, _tabrect.bottom),
|
_driver->StrokeLine(BPoint(_tabrect.right - 1, _tabrect.top + 2),
|
||||||
tabColorShadow);
|
BPoint(_tabrect.right - 1, _tabrect.bottom), tabColorShadow);
|
||||||
|
} else {
|
||||||
|
_driver->StrokeLine(BPoint(_tabrect.left + 2, _tabrect.bottom - 1),
|
||||||
|
BPoint(_tabrect.right, _tabrect.bottom - 1), tabColorShadow);
|
||||||
|
}
|
||||||
|
|
||||||
// fill
|
// fill
|
||||||
_driver->FillRect(BRect(_tabrect.left + 2, _tabrect.top + 2,
|
if (fLook != kLeftTitledWindowLook) {
|
||||||
_tabrect.right - 2, _tabrect.bottom), fTabColor);
|
_driver->FillRect(BRect(_tabrect.left + 2, _tabrect.top + 2,
|
||||||
|
_tabrect.right - 2, _tabrect.bottom), fTabColor);
|
||||||
|
} else {
|
||||||
|
_driver->FillRect(BRect(_tabrect.left + 2, _tabrect.top + 2,
|
||||||
|
_tabrect.right, _tabrect.bottom - 2), fTabColor);
|
||||||
|
}
|
||||||
|
|
||||||
_DrawTitle(_tabrect);
|
_DrawTitle(_tabrect);
|
||||||
|
|
||||||
@ -781,10 +837,17 @@ DefaultDecorator::_DrawTitle(BRect r)
|
|||||||
fDrawState.Font().GetHeight(fontHeight);
|
fDrawState.Font().GetHeight(fontHeight);
|
||||||
|
|
||||||
BPoint titlePos;
|
BPoint titlePos;
|
||||||
titlePos.x = _closerect.IsValid() ? _closerect.right + fTextOffset
|
if (fLook != kLeftTitledWindowLook) {
|
||||||
: _tabrect.left + fTextOffset;
|
titlePos.x = _closerect.IsValid() ? _closerect.right + fTextOffset
|
||||||
titlePos.y = floorf(((_tabrect.top + 2.0) + _tabrect.bottom + fontHeight.ascent
|
: _tabrect.left + fTextOffset;
|
||||||
+ fontHeight.descent) / 2.0 - fontHeight.descent + 0.5);
|
titlePos.y = floorf(((_tabrect.top + 2.0) + _tabrect.bottom + fontHeight.ascent
|
||||||
|
+ fontHeight.descent) / 2.0 - fontHeight.descent + 0.5);
|
||||||
|
} else {
|
||||||
|
titlePos.x = floorf(((_tabrect.left + 2.0) + _tabrect.right + fontHeight.ascent
|
||||||
|
+ fontHeight.descent) / 2.0 - fontHeight.descent + 0.5);
|
||||||
|
titlePos.y = _zoomrect.IsValid() ? _zoomrect.top - fTextOffset
|
||||||
|
: _tabrect.bottom - fTextOffset;
|
||||||
|
}
|
||||||
|
|
||||||
_driver->DrawString(fTruncatedTitle.String(), fTruncatedTitleLength, titlePos, &fDrawState);
|
_driver->DrawString(fTruncatedTitle.String(), fTruncatedTitleLength, titlePos, &fDrawState);
|
||||||
}
|
}
|
||||||
@ -865,7 +928,7 @@ DefaultDecorator::_DrawBlendedRect(BRect r, bool down)
|
|||||||
rgb_color halfcol, startcol, endcol;
|
rgb_color halfcol, startcol, endcol;
|
||||||
float rstep, gstep, bstep;
|
float rstep, gstep, bstep;
|
||||||
|
|
||||||
int steps = (w < h) ? w : h;
|
int steps = w < h ? w : h;
|
||||||
|
|
||||||
if (down) {
|
if (down) {
|
||||||
startcol = fButtonLowColor.GetColor32();
|
startcol = fButtonLowColor.GetColor32();
|
||||||
@ -901,12 +964,17 @@ DefaultDecorator::_DrawBlendedRect(BRect r, bool down)
|
|||||||
|
|
||||||
// _GetButtonSizeAndOffset
|
// _GetButtonSizeAndOffset
|
||||||
void
|
void
|
||||||
DefaultDecorator::_GetButtonSizeAndOffset(const BRect& tabRect, float* offset, float* size) const
|
DefaultDecorator::_GetButtonSizeAndOffset(const BRect& tabRect, float* _offset,
|
||||||
|
float* _size) const
|
||||||
{
|
{
|
||||||
*offset = fLook == B_FLOATING_WINDOW_LOOK ? 4.0 : 5.0;
|
*_offset = fLook == B_FLOATING_WINDOW_LOOK || fLook == kLeftTitledWindowLook ? 4.0 : 5.0;
|
||||||
|
|
||||||
// "+ 2" so that the rects are centered within the solid area
|
// "+ 2" so that the rects are centered within the solid area
|
||||||
// (without the 2 pixels for the top border)
|
// (without the 2 pixels for the top border)
|
||||||
*size = tabRect.Height() - 2.0 * *offset + 2.0;
|
if (fLook != kLeftTitledWindowLook)
|
||||||
|
*_size = tabRect.Height() - 2.0 * *_offset + 2.0f;
|
||||||
|
else
|
||||||
|
*_size = tabRect.Width() - 2.0 * *_offset + 2.0f;
|
||||||
}
|
}
|
||||||
|
|
||||||
// _LayoutTabItems
|
// _LayoutTabItems
|
||||||
@ -918,31 +986,42 @@ DefaultDecorator::_LayoutTabItems(const BRect& tabRect)
|
|||||||
_GetButtonSizeAndOffset(tabRect, &offset, &size);
|
_GetButtonSizeAndOffset(tabRect, &offset, &size);
|
||||||
|
|
||||||
// calulate close rect based on the tab rectangle
|
// calulate close rect based on the tab rectangle
|
||||||
if (Flags() & B_NOT_CLOSABLE) {
|
if (fLook != kLeftTitledWindowLook) {
|
||||||
// the close rect has no width
|
|
||||||
_closerect.Set(tabRect.left + offset, tabRect.top + offset,
|
_closerect.Set(tabRect.left + offset, tabRect.top + offset,
|
||||||
tabRect.left + offset, tabRect.top + offset + size);
|
tabRect.left + offset + size, tabRect.top + offset + size);
|
||||||
|
|
||||||
|
_zoomrect.Set(tabRect.right - offset - size, tabRect.top + offset,
|
||||||
|
tabRect.right - offset, tabRect.top + offset + size);
|
||||||
|
|
||||||
|
// hidden buttons have no width
|
||||||
|
if ((Flags() & B_NOT_CLOSABLE) != 0)
|
||||||
|
_closerect.right = _closerect.left - offset;
|
||||||
|
if ((Flags() & B_NOT_ZOOMABLE) != 0)
|
||||||
|
_zoomrect.left = _zoomrect.right + offset;
|
||||||
} else {
|
} else {
|
||||||
_closerect.Set(tabRect.left + offset, tabRect.top + offset,
|
_closerect.Set(tabRect.left + offset, tabRect.top + offset,
|
||||||
tabRect.left + offset + size, tabRect.top + offset + size);
|
tabRect.left + offset + size, tabRect.top + offset + size);
|
||||||
}
|
|
||||||
|
|
||||||
// calulate zoom rect based on the tab rectangle
|
_zoomrect.Set(tabRect.left + offset, tabRect.bottom - offset - size,
|
||||||
if (Flags() & B_NOT_ZOOMABLE) {
|
tabRect.left + size + offset, tabRect.bottom - offset);
|
||||||
// the zoom rect has no width
|
|
||||||
_zoomrect.Set(tabRect.right, tabRect.top + offset,
|
// hidden buttons have no height
|
||||||
tabRect.right, tabRect.top + offset + size);
|
if ((Flags() & B_NOT_CLOSABLE) != 0)
|
||||||
} else {
|
_closerect.bottom = _closerect.top - offset;
|
||||||
_zoomrect.Set(tabRect.right - offset - size, tabRect.top + offset,
|
if ((Flags() & B_NOT_ZOOMABLE) != 0)
|
||||||
tabRect.right - offset, tabRect.top + offset + size);
|
_zoomrect.top = _zoomrect.bottom + offset;
|
||||||
}
|
}
|
||||||
|
|
||||||
// calculate room for title
|
// calculate room for title
|
||||||
// ToDo: the +2 is there because the title often appeared
|
// ToDo: the +2 is there because the title often appeared
|
||||||
// truncated for no apparent reason - OTOH the title does
|
// truncated for no apparent reason - OTOH the title does
|
||||||
// also not appear perfectly in the middle
|
// also not appear perfectly in the middle
|
||||||
float width = (_zoomrect.left - _closerect.right) - fTextOffset * 2 + 2;
|
if (fLook != kLeftTitledWindowLook)
|
||||||
|
size = (_zoomrect.left - _closerect.right) - fTextOffset * 2 + 2;
|
||||||
|
else
|
||||||
|
size = (_zoomrect.top - _closerect.bottom) - fTextOffset * 2 + 2;
|
||||||
|
|
||||||
fTruncatedTitle = Title();
|
fTruncatedTitle = Title();
|
||||||
fDrawState.Font().TruncateString(&fTruncatedTitle, B_TRUNCATE_END, width);
|
fDrawState.Font().TruncateString(&fTruncatedTitle, B_TRUNCATE_END, size);
|
||||||
fTruncatedTitleLength = fTruncatedTitle.Length();
|
fTruncatedTitleLength = fTruncatedTitle.Length();
|
||||||
}
|
}
|
||||||
|
@ -79,8 +79,8 @@ class DefaultDecorator: public Decorator {
|
|||||||
uint32 fTabOffset;
|
uint32 fTabOffset;
|
||||||
float fTextOffset;
|
float fTextOffset;
|
||||||
|
|
||||||
float fMinTabWidth;
|
float fMinTabSize;
|
||||||
float fMaxTabWidth;
|
float fMaxTabSize;
|
||||||
BString fTruncatedTitle;
|
BString fTruncatedTitle;
|
||||||
int32 fTruncatedTitleLength;
|
int32 fTruncatedTitleLength;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user