Refactoring: moved all controls into the TMView class (former TMBox).

It now also handles all messages relating to its controls.
The file path is now truncated to the view's bounds.
Fixed wrong update position of the TMDescView; it always took updateRect
as view bounds.
Enlarged item gap a bit so fit the BeOS task manager exactly.
Cleanup.


git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@13145 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
Axel Dörfler 2005-06-15 06:37:14 +00:00
parent 9695be8f49
commit 5311273550
3 changed files with 174 additions and 120 deletions

View File

@ -1,6 +1,6 @@
// ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ // ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~
// //
// Copyright (c) 2004, Haiku // Copyright (c) 2004-2005, Haiku
// //
// This software is part of the Haiku distribution and is covered // This software is part of the Haiku distribution and is covered
// by the Haiku license. // by the Haiku license.
@ -18,7 +18,7 @@
#include <View.h> #include <View.h>
#include "TMListItem.h" #include "TMListItem.h"
#define kITEM_MARGIN 1 #define kITEM_MARGIN 2
TMListItem::TMListItem(team_info &tinfo) TMListItem::TMListItem(team_info &tinfo)
@ -28,7 +28,7 @@ TMListItem::TMListItem(team_info &tinfo)
fLargeIcon(BRect(0,0,31,31), B_CMAP8) fLargeIcon(BRect(0,0,31,31), B_CMAP8)
{ {
SetHeight(16 + kITEM_MARGIN); SetHeight(16 + kITEM_MARGIN);
int32 cookie = 0; int32 cookie = 0;
image_info info; image_info info;
if (get_next_image_info(tinfo.team, &cookie, &info) == B_OK) { if (get_next_image_info(tinfo.team, &cookie, &info) == B_OK) {
@ -46,13 +46,13 @@ TMListItem::~TMListItem()
} }
void void
TMListItem::DrawItem(BView *owner, BRect frame, bool complete) TMListItem::DrawItem(BView *owner, BRect frame, bool complete)
{ {
rgb_color kHighlight = { 140,140,140,0 }; rgb_color kHighlight = { 140,140,140,0 };
rgb_color kBlack = { 0,0,0,0 }; rgb_color kBlack = { 0,0,0,0 };
rgb_color kBlue = { 0,0,255,0 }; rgb_color kBlue = { 0,0,255,0 };
BRect r(frame); BRect r(frame);
if (IsSelected() || complete) { if (IsSelected() || complete) {
@ -69,18 +69,18 @@ TMListItem::DrawItem(BView *owner, BRect frame, bool complete)
} else { } else {
owner->SetLowColor(owner->ViewColor()); owner->SetLowColor(owner->ViewColor());
} }
frame.left += 4; frame.left += 4;
BRect iconFrame(frame); BRect iconFrame(frame);
iconFrame.Set(iconFrame.left, iconFrame.top+1, iconFrame.left+15, iconFrame.top+16); iconFrame.Set(iconFrame.left, iconFrame.top+1, iconFrame.left+15, iconFrame.top+16);
owner->SetDrawingMode(B_OP_OVER); owner->SetDrawingMode(B_OP_OVER);
owner->DrawBitmap(&fIcon, iconFrame); owner->DrawBitmap(&fIcon, iconFrame);
owner->SetDrawingMode(B_OP_COPY); owner->SetDrawingMode(B_OP_COPY);
frame.left += 16; frame.left += 16;
owner->SetHighColor(IsSystemServer() ? kBlue : kBlack); owner->SetHighColor(IsSystemServer() ? kBlue : kBlack);
BFont font = be_plain_font; BFont font = be_plain_font;
font_height finfo; font_height finfo;
font.GetHeight(&finfo); font.GetHeight(&finfo);
owner->SetFont(&font); owner->SetFont(&font);
@ -112,12 +112,13 @@ TMListItem::GetInfo()
bool bool
TMListItem::IsSystemServer() TMListItem::IsSystemServer()
{ {
char system1[] = "/boot/beos/system/"; char *system = "/boot/beos/system/";
char system2[] = "/system/servers/"; if (strncmp(system, fInfo.args, strlen(system)) == 0)
if (strncmp(system1, fInfo.args, strlen(system1))==0)
return true; return true;
if (strncmp(system2, fInfo.args, strlen(system2))==0)
system = "/system/servers/";
if (strncmp(system, fInfo.args, strlen(system)) == 0)
return true; return true;
return false; return false;
} }

View File

@ -17,9 +17,11 @@
#include "TMWindow.h" #include "TMWindow.h"
#include "TMListItem.h" #include "TMListItem.h"
#include "KeyboardInputDevice.h" #include "KeyboardInputDevice.h"
#include <Message.h> #include <Message.h>
#include <ScrollView.h> #include <ScrollView.h>
#include <Screen.h> #include <Screen.h>
#include <String.h>
const uint32 TM_CANCEL = 'TMca'; const uint32 TM_CANCEL = 'TMca';
@ -27,7 +29,7 @@ const uint32 TM_FORCE_REBOOT = 'TMfr';
const uint32 TM_KILL_APPLICATION = 'TMka'; const uint32 TM_KILL_APPLICATION = 'TMka';
const uint32 TM_SELECTED_TEAM = 'TMst'; const uint32 TM_SELECTED_TEAM = 'TMst';
#ifdef COMPILE_FOR_R5 #ifndef __HAIKU__
extern "C" void _kshutdown_(bool reboot); extern "C" void _kshutdown_(bool reboot);
#else #else
# include <syscalls.h> # include <syscalls.h>
@ -46,47 +48,11 @@ TMWindow::TMWindow()
// ToDo: make this font sensitive // ToDo: make this font sensitive
BRect rect = Bounds(); fView = new TMView(Bounds(), "background", B_FOLLOW_LEFT | B_FOLLOW_TOP,
BFont font = be_plain_font;
fBackground = new TMBox(rect, "background", B_FOLLOW_LEFT | B_FOLLOW_TOP,
B_WILL_DRAW, B_NO_BORDER); B_WILL_DRAW, B_NO_BORDER);
AddChild(fBackground); AddChild(fView);
rect = Bounds(); BRect screenFrame = BScreen(B_MAIN_SCREEN_ID).Frame();
rect.right -= 10;
rect.left = rect.right - font.StringWidth("Cancel") - 20;
rect.bottom -= 14;
rect.top = rect.bottom - 20;
BButton *cancel = new BButton(rect, "cancel", "Cancel",
new BMessage(TM_CANCEL), B_FOLLOW_RIGHT|B_FOLLOW_BOTTOM);
fBackground->AddChild(cancel);
SetDefaultButton(cancel);
rect.left = 10;
rect.right = rect.left + font.StringWidth("Force Reboot") + 20;
BButton *forceReboot = new BButton(rect, "force", "Force Reboot",
new BMessage(TM_FORCE_REBOOT), B_FOLLOW_LEFT|B_FOLLOW_BOTTOM);
fBackground->AddChild(forceReboot);
rect.top -= 97;
rect.bottom = rect.top + 20;
rect.right = rect.left + font.StringWidth("Kill Application") + 20;
fKillApp = new BButton(rect, "kill", "Kill Application",
new BMessage(TM_KILL_APPLICATION), B_FOLLOW_LEFT|B_FOLLOW_BOTTOM);
fBackground->AddChild(fKillApp);
fKillApp->SetEnabled(false);
rect.top = rect.bottom + 10;
rect.bottom = rect.top + 65;
rect.right = rect.left + Bounds().right - 10;
fDescView = new TMDescView(rect);
fBackground->AddChild(fDescView);
BRect screenFrame = (BScreen(B_MAIN_SCREEN_ID).Frame());
BPoint point; BPoint point;
point.x = (screenFrame.Width() - Bounds().Width()) / 2; point.x = (screenFrame.Width() - Bounds().Width()) / 2;
point.y = (screenFrame.Height() - Bounds().Height()) / 2; point.y = (screenFrame.Height() - Bounds().Height()) / 2;
@ -107,27 +73,6 @@ void
TMWindow::MessageReceived(BMessage *msg) TMWindow::MessageReceived(BMessage *msg)
{ {
switch (msg->what) { switch (msg->what) {
case TM_FORCE_REBOOT:
_kshutdown_(true);
break;
case TM_KILL_APPLICATION: {
TMListItem *item = (TMListItem*)fBackground->fListView->ItemAt(
fBackground->fListView->CurrentSelection());
kill_team(item->GetInfo()->team);
fKillApp->SetEnabled(false);
fDescView->SetItem(NULL);
}
break;
case TM_SELECTED_TEAM: {
fKillApp->SetEnabled(fBackground->fListView->CurrentSelection() >= 0);
TMListItem *item = (TMListItem*)fBackground->fListView->ItemAt(
fBackground->fListView->CurrentSelection());
fDescView->SetItem(item);
}
break;
case TM_CANCEL:
Disable();
break;
case SYSTEM_SHUTTING_DOWN: case SYSTEM_SHUTTING_DOWN:
fQuitting = true; fQuitting = true;
break; break;
@ -150,9 +95,9 @@ void
TMWindow::Enable() TMWindow::Enable()
{ {
SetPulseRate(1000000); SetPulseRate(1000000);
if (IsHidden()) { if (IsHidden()) {
PostMessage(B_PULSE); fView->UpdateList();
Show(); Show();
} }
} }
@ -161,7 +106,7 @@ TMWindow::Enable()
void void
TMWindow::Disable() TMWindow::Disable()
{ {
fBackground->fListView->DeselectAll(); fView->ListView()->DeselectAll();
SetPulseRate(0); SetPulseRate(0);
Hide(); Hide();
} }
@ -170,28 +115,119 @@ TMWindow::Disable()
// #pragma mark - // #pragma mark -
TMBox::TMBox(BRect bounds, const char* name, uint32 resizeFlags, TMView::TMView(BRect bounds, const char* name, uint32 resizeFlags,
uint32 flags, border_style border) uint32 flags, border_style border)
: BBox(bounds, name, resizeFlags, flags | B_PULSE_NEEDED, border) : BBox(bounds, name, resizeFlags, flags | B_PULSE_NEEDED, border)
{ {
BRect rect = Bounds(); BRect rect = bounds;
rect.InsetBy(12, 11); rect.InsetBy(12, 12);
rect.right -= B_V_SCROLL_BAR_WIDTH; rect.right -= B_V_SCROLL_BAR_WIDTH;
rect.bottom = rect.top + 146; rect.bottom = rect.top + 146;
BFont font = be_plain_font;
fListView = new BListView(rect, "teams", B_SINGLE_SELECTION_LIST, fListView = new BListView(rect, "teams", B_SINGLE_SELECTION_LIST,
B_FOLLOW_ALL); B_FOLLOW_ALL);
fListView->SetSelectionMessage(new BMessage(TM_SELECTED_TEAM)); fListView->SetSelectionMessage(new BMessage(TM_SELECTED_TEAM));
BScrollView *sv = new BScrollView("scroll_teams", fListView, BScrollView *scrollView = new BScrollView("scroll_teams", fListView,
B_FOLLOW_LEFT_RIGHT | B_FOLLOW_TOP_BOTTOM, 0, false, true, B_FANCY_BORDER); B_FOLLOW_LEFT_RIGHT | B_FOLLOW_TOP_BOTTOM, 0, false, true, B_FANCY_BORDER);
AddChild(scrollView);
AddChild(sv); rect = bounds;
rect.right -= 10;
rect.left = rect.right - font.StringWidth("Cancel") - 20;
rect.bottom -= 14;
rect.top = rect.bottom - 20;
BButton *cancel = new BButton(rect, "cancel", "Cancel",
new BMessage(TM_CANCEL), B_FOLLOW_RIGHT | B_FOLLOW_BOTTOM);
AddChild(cancel);
rect.left = 10;
rect.right = rect.left + font.StringWidth("Force Reboot") + 20;
BButton *forceReboot = new BButton(rect, "force", "Force Reboot",
new BMessage(TM_FORCE_REBOOT), B_FOLLOW_LEFT | B_FOLLOW_BOTTOM);
AddChild(forceReboot);
rect.top -= 97;
rect.bottom = rect.top + 20;
rect.right = rect.left + font.StringWidth("Kill Application") + 20;
fKillApp = new BButton(rect, "kill", "Kill Application",
new BMessage(TM_KILL_APPLICATION), B_FOLLOW_LEFT | B_FOLLOW_BOTTOM);
AddChild(fKillApp);
fKillApp->SetEnabled(false);
rect.top = rect.bottom + 10;
rect.bottom = rect.top + 65;
rect.right = bounds.right - 10;
fDescView = new TMDescView(rect);
AddChild(fDescView);
} }
void void
TMBox::Pulse() TMView::AttachedToWindow()
{
if (BButton *cancel = dynamic_cast<BButton*>(FindView("cancel"))) {
Window()->SetDefaultButton(cancel);
cancel->SetTarget(this);
}
if (BButton *kill = dynamic_cast<BButton*>(FindView("kill")))
kill->SetTarget(this);
if (BButton *reboot = dynamic_cast<BButton*>(FindView("force")))
reboot->SetTarget(this);
fListView->SetTarget(this);
}
void
TMView::MessageReceived(BMessage *msg)
{
switch (msg->what) {
case TM_FORCE_REBOOT:
_kshutdown_(true);
break;
case TM_KILL_APPLICATION: {
TMListItem *item = (TMListItem*)ListView()->ItemAt(
ListView()->CurrentSelection());
kill_team(item->GetInfo()->team);
fKillApp->SetEnabled(false);
UpdateList();
break;
}
case TM_SELECTED_TEAM: {
fKillApp->SetEnabled(fListView->CurrentSelection() >= 0);
TMListItem *item = (TMListItem*)ListView()->ItemAt(
ListView()->CurrentSelection());
fDescView->SetItem(item);
break;
}
case TM_CANCEL:
Window()->PostMessage(B_QUIT_REQUESTED);
break;
default:
BBox::MessageReceived(msg);
break;
}
}
void
TMView::Pulse()
{
UpdateList();
}
void
TMView::UpdateList()
{ {
CALLED(); CALLED();
bool changed = false; bool changed = false;
@ -227,6 +263,9 @@ TMBox::Pulse()
for (int32 i = fListView->CountItems() - 1; i >= 0; i--) { for (int32 i = fListView->CountItems() - 1; i >= 0; i--) {
TMListItem *item = (TMListItem*)fListView->ItemAt(i); TMListItem *item = (TMListItem*)fListView->ItemAt(i);
if (!item->fFound) { if (!item->fFound) {
if (item == fDescView->Item())
fDescView->SetItem(NULL);
delete fListView->RemoveItem(i); delete fListView->RemoveItem(i);
changed = true; changed = true;
} }
@ -250,9 +289,8 @@ TMDescView::TMDescView(BRect rect)
void void
TMDescView::Draw(BRect rect) TMDescView::Draw(BRect rect)
{ {
// Accessing fItem this way is not a good idea, since it's not correctly rect = Bounds();
// updated - if the team goes away in the meantime, we're doomed to crash
// (the item could have been deleted in TMBox::Pulse())
if (fItem) { if (fItem) {
BRect frame(rect); BRect frame(rect);
frame.OffsetBy(2,3); frame.OffsetBy(2,3);
@ -267,7 +305,9 @@ TMDescView::Draw(BRect rect)
SetFont(&font); SetFont(&font);
MovePenTo(frame.right+9, frame.top - 2 + ((frame.Height() - (finfo.ascent + finfo.descent + finfo.leading)) / 4) + MovePenTo(frame.right+9, frame.top - 2 + ((frame.Height() - (finfo.ascent + finfo.descent + finfo.leading)) / 4) +
(finfo.ascent + finfo.descent) - 1); (finfo.ascent + finfo.descent) - 1);
DrawString(fItem->Path()->Path()); BString path = fItem->Path()->Path();
TruncateString(&path, B_TRUNCATE_MIDDLE, rect.right - 9 - frame.right);
DrawString(path.String());
if (fItem->IsSystemServer()) { if (fItem->IsSystemServer()) {
MovePenTo(frame.right+9, frame.top + 1 + ((frame.Height() - (finfo.ascent + finfo.descent + finfo.leading)) *3 / 4) + MovePenTo(frame.right+9, frame.top + 1 + ((frame.Height() - (finfo.ascent + finfo.descent + finfo.leading)) *3 / 4) +

View File

@ -1,6 +1,6 @@
// ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ // ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~
// //
// Copyright (c) 2004, Haiku // Copyright (c) 2004-2005, Haiku
// //
// This software is part of the Haiku distribution and is covered // This software is part of the Haiku distribution and is covered
// by the Haiku license. // by the Haiku license.
@ -16,6 +16,7 @@
#ifndef TMWINDOW_H #ifndef TMWINDOW_H
#define TMWINDOW_H #define TMWINDOW_H
#include <Box.h> #include <Box.h>
#include <Button.h> #include <Button.h>
#include <ListView.h> #include <ListView.h>
@ -24,42 +25,54 @@
#include "InputServerTypes.h" #include "InputServerTypes.h"
#include "TMListItem.h" #include "TMListItem.h"
class TMBox : public BBox {
public: class TMDescView;
TMBox(BRect bounds, const char* name=NULL, uint32 resizeFlags = B_FOLLOW_LEFT|B_FOLLOW_TOP,
uint32 flags = B_WILL_DRAW|B_FRAME_EVENTS|B_NAVIGABLE_JUMP, class TMView : public BBox {
border_style border = B_FANCY_BORDER); public:
void Pulse(); TMView(BRect bounds, const char* name = NULL,
uint32 resizeFlags = B_FOLLOW_LEFT | B_FOLLOW_TOP,
BListView *fListView; uint32 flags = B_WILL_DRAW | B_FRAME_EVENTS | B_NAVIGABLE_JUMP,
border_style border = B_NO_BORDER);
virtual void AttachedToWindow();
virtual void Pulse();
virtual void MessageReceived(BMessage *msg);
void UpdateList();
BListView *ListView() { return fListView; }
private:
BListView *fListView;
BButton *fKillApp;
TMDescView *fDescView;
}; };
class TMDescView : public BBox { class TMDescView : public BBox {
public: public:
TMDescView(BRect bounds); TMDescView(BRect bounds);
void Draw(BRect bounds); virtual void Draw(BRect bounds);
void SetItem(TMListItem *item);
private: void SetItem(TMListItem *item);
TMListItem *fItem; TMListItem *Item() { return fItem; }
private:
TMListItem *fItem;
}; };
class TMWindow : public BWindow class TMWindow : public BWindow {
{ public:
public: TMWindow();
TMWindow(); virtual ~TMWindow();
~TMWindow();
void MessageReceived(BMessage *msg);
virtual bool QuitRequested();
void Enable();
void Disable();
private:
bool fQuitting;
BButton *fKillApp;
TMBox *fBackground;
TMDescView *fDescView;
};
virtual void MessageReceived(BMessage *msg);
virtual bool QuitRequested();
void Enable();
void Disable();
private:
bool fQuitting;
TMView *fView;
};
#endif //TMWINDOW_H #endif //TMWINDOW_H