* Use layout API in libprint dialogs.
* Use layout API in preview printer add-on. * Use layout API in some dialogs in PDF Writer. * Removed unused class PrinterSetupWindow from PDF Writer. * Improved layout in print_server configuration dialog. git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@38986 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
a009356a78
commit
5a695bce10
@ -139,8 +139,14 @@ SYSTEM_ADD_ONS_MEDIA = cortex_audioadapter.media_addon
|
|||||||
#legacy.media_addon
|
#legacy.media_addon
|
||||||
;
|
;
|
||||||
SYSTEM_ADD_ONS_MEDIA_PLUGINS = $(X86_ONLY)ffmpeg raw_decoder ;
|
SYSTEM_ADD_ONS_MEDIA_PLUGINS = $(X86_ONLY)ffmpeg raw_decoder ;
|
||||||
SYSTEM_ADD_ONS_PRINT = Canon\ LIPS3\ Compatible Canon\ LIPS4\ Compatible
|
SYSTEM_ADD_ONS_PRINT =
|
||||||
PCL5\ Compatible PCL6\ Compatible PDF\ Writer PS\ Compatible Preview
|
Canon\ LIPS3\ Compatible
|
||||||
|
Canon\ LIPS4\ Compatible
|
||||||
|
PCL5\ Compatible
|
||||||
|
PCL6\ Compatible
|
||||||
|
PDF\ Writer
|
||||||
|
PS\ Compatible
|
||||||
|
Preview
|
||||||
;
|
;
|
||||||
SYSTEM_ADD_ONS_PRINT_TRANSPORT = HP\ JetDirect IPP LPR Parallel\ Port
|
SYSTEM_ADD_ONS_PRINT_TRANSPORT = HP\ JetDirect IPP LPR Parallel\ Port
|
||||||
Print\ To\ File Serial\ Port USB\ Port
|
Print\ To\ File Serial\ Port USB\ Port
|
||||||
|
@ -17,15 +17,12 @@
|
|||||||
class JSDSlider : public BSlider
|
class JSDSlider : public BSlider
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
JSDSlider(BRect frame, const char* name, const char *label,
|
JSDSlider(const char* name, const char* label,
|
||||||
BMessage *msg, int32 min, int32 max, thumb_style t);
|
BMessage* msg, int32 min, int32 max);
|
||||||
|
|
||||||
virtual ~JSDSlider();
|
virtual ~JSDSlider();
|
||||||
#ifdef __HAIKU__
|
|
||||||
virtual const char* UpdateText() const;
|
virtual const char* UpdateText() const;
|
||||||
#else
|
|
||||||
virtual char* UpdateText() const;
|
|
||||||
#endif
|
|
||||||
private:
|
private:
|
||||||
mutable BString fResult;
|
mutable BString fResult;
|
||||||
};
|
};
|
||||||
|
@ -26,14 +26,15 @@ class PagesView;
|
|||||||
|
|
||||||
class JobSetupView : public BView {
|
class JobSetupView : public BView {
|
||||||
public:
|
public:
|
||||||
JobSetupView(BRect frame, JobData *job_data, PrinterData *printer_data, const PrinterCap *printer_cap);
|
JobSetupView(JobData* job_data, PrinterData* printer_data,
|
||||||
|
const PrinterCap* printer_cap);
|
||||||
virtual void AttachedToWindow();
|
virtual void AttachedToWindow();
|
||||||
virtual void MessageReceived(BMessage *msg);
|
virtual void MessageReceived(BMessage* msg);
|
||||||
bool UpdateJobData(bool showPreview);
|
bool UpdateJobData(bool showPreview);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void UpdateButtonEnabledState();
|
void UpdateButtonEnabledState();
|
||||||
BRadioButton* AddPageSelectionItem(BView* parent, BRect rect, const char* name, const char* label,
|
BRadioButton* CreatePageSelectionItem(const char* name, const char* label,
|
||||||
JobData::PageSelection pageSelection);
|
JobData::PageSelection pageSelection);
|
||||||
void AllowOnlyDigits(BTextView* textView, int maxDigits);
|
void AllowOnlyDigits(BTextView* textView, int maxDigits);
|
||||||
JobData::Color getColor();
|
JobData::Color getColor();
|
||||||
|
@ -143,6 +143,24 @@ enum MarginUnit {
|
|||||||
kUnitPoint
|
kUnitPoint
|
||||||
};
|
};
|
||||||
|
|
||||||
|
class PageView : public BView
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
PageView();
|
||||||
|
|
||||||
|
void SetPageSize(float pageWidth, float pageHeight);
|
||||||
|
void SetMargins(BRect margins);
|
||||||
|
|
||||||
|
virtual void Draw(BRect bounds);
|
||||||
|
|
||||||
|
|
||||||
|
private:
|
||||||
|
float fPageWidth;
|
||||||
|
float fPageHeight;
|
||||||
|
|
||||||
|
BRect fMargins;
|
||||||
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Class MarginView
|
* Class MarginView
|
||||||
*/
|
*/
|
||||||
@ -151,7 +169,7 @@ class MarginView : public BBox
|
|||||||
friend class MarginManager;
|
friend class MarginManager;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
MarginView(BRect rect, int32 pageWidth = 0,
|
MarginView(int32 pageWidth = 0,
|
||||||
int32 pageHeight = 0,
|
int32 pageHeight = 0,
|
||||||
BRect margins = BRect(1, 1, 1, 1), // 1 inch
|
BRect margins = BRect(1, 1, 1, 1), // 1 inch
|
||||||
MarginUnit unit = kUnitInch);
|
MarginUnit unit = kUnitInch);
|
||||||
@ -159,8 +177,6 @@ public:
|
|||||||
virtual ~MarginView();
|
virtual ~MarginView();
|
||||||
|
|
||||||
virtual void AttachedToWindow();
|
virtual void AttachedToWindow();
|
||||||
virtual void Draw(BRect rect);
|
|
||||||
virtual void FrameResized(float width, float height);
|
|
||||||
virtual void MessageReceived(BMessage *msg);
|
virtual void MessageReceived(BMessage *msg);
|
||||||
|
|
||||||
// point.x = width, point.y = height
|
// point.x = width, point.y = height
|
||||||
@ -190,33 +206,25 @@ private:
|
|||||||
// performed internally using the supplied popup
|
// performed internally using the supplied popup
|
||||||
void _SetMarginUnit(MarginUnit unit);
|
void _SetMarginUnit(MarginUnit unit);
|
||||||
|
|
||||||
// Calculate the view size for the margins
|
|
||||||
void _CalculateViewSize(uint32 msg);
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
BTextControl* fTop;
|
BTextControl* fTop;
|
||||||
BTextControl* fBottom;
|
BTextControl* fBottom;
|
||||||
BTextControl* fLeft;
|
BTextControl* fLeft;
|
||||||
BTextControl* fRight;
|
BTextControl* fRight;
|
||||||
|
|
||||||
// rect that holds the margins for the page as a set of point offsets
|
|
||||||
BRect fMargins;
|
|
||||||
|
|
||||||
// the maximum size of the page view calculated from the view size
|
|
||||||
float fMaxPageWidth;
|
|
||||||
float fMaxPageHeight;
|
|
||||||
|
|
||||||
// the actual size of the page in points
|
// the actual size of the page in points
|
||||||
float fPageHeight;
|
float fPageHeight;
|
||||||
float fPageWidth;
|
float fPageWidth;
|
||||||
|
|
||||||
|
// rect that holds the margins for the page as a set of point offsets
|
||||||
|
BRect fMargins;
|
||||||
|
|
||||||
// the units used to calculate the page size
|
// the units used to calculate the page size
|
||||||
MarginUnit fMarginUnit;
|
MarginUnit fMarginUnit;
|
||||||
float fUnitValue;
|
float fUnitValue;
|
||||||
|
|
||||||
// the size of the drawing area we have to draw the view in pixels
|
PageView* fPage;
|
||||||
float fViewHeight;
|
BStringView* fPageSize;
|
||||||
float fViewWidth;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // _MARGIN_VIEW_H
|
#endif // _MARGIN_VIEW_H
|
||||||
|
@ -20,7 +20,8 @@ class MarginView;
|
|||||||
|
|
||||||
class PageSetupView : public BView {
|
class PageSetupView : public BView {
|
||||||
public:
|
public:
|
||||||
PageSetupView(BRect frame, JobData *job_data, PrinterData *printer_data, const PrinterCap *printer_cap);
|
PageSetupView(JobData *job_data, PrinterData *printer_data,
|
||||||
|
const PrinterCap *printer_cap);
|
||||||
~PageSetupView();
|
~PageSetupView();
|
||||||
virtual void AttachedToWindow();
|
virtual void AttachedToWindow();
|
||||||
bool UpdateJobData();
|
bool UpdateJobData();
|
||||||
@ -43,11 +44,13 @@ private:
|
|||||||
|
|
||||||
class PageSetupDlg : public DialogWindow {
|
class PageSetupDlg : public DialogWindow {
|
||||||
public:
|
public:
|
||||||
PageSetupDlg(JobData *job_data, PrinterData *printer_data, const PrinterCap *printer_cap);
|
PageSetupDlg(JobData *job_data, PrinterData *printer_data,
|
||||||
|
const PrinterCap *printer_cap);
|
||||||
virtual void MessageReceived(BMessage *message);
|
virtual void MessageReceived(BMessage *message);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
BMessageFilter *fFilter;
|
BMessageFilter* fFilter;
|
||||||
|
PageSetupView* fPageSetupView;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif /* __PAGESETUPDLG_H */
|
#endif /* __PAGESETUPDLG_H */
|
||||||
|
@ -35,7 +35,6 @@ Addon PDF\ Writer :
|
|||||||
PrinterDriver.cpp
|
PrinterDriver.cpp
|
||||||
PrinterPrefs.cpp
|
PrinterPrefs.cpp
|
||||||
PrinterSettings.cpp
|
PrinterSettings.cpp
|
||||||
PrinterSetupWindow.cpp
|
|
||||||
RegExp.cpp
|
RegExp.cpp
|
||||||
Report.cpp
|
Report.cpp
|
||||||
Scanner.cpp
|
Scanner.cpp
|
||||||
|
@ -3,6 +3,7 @@
|
|||||||
PDF Writer printer driver.
|
PDF Writer printer driver.
|
||||||
|
|
||||||
Copyright (c) 2001-2003 OpenBeOS.
|
Copyright (c) 2001-2003 OpenBeOS.
|
||||||
|
Copyright (c) 2010 Haiku, Inc.
|
||||||
|
|
||||||
Authors:
|
Authors:
|
||||||
Philippe Houdoin
|
Philippe Houdoin
|
||||||
@ -29,6 +30,9 @@ THE SOFTWARE.
|
|||||||
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include <GridView.h>
|
||||||
|
#include <GroupLayout.h>
|
||||||
|
#include <GroupLayoutBuilder.h>
|
||||||
#include <InterfaceKit.h>
|
#include <InterfaceKit.h>
|
||||||
#include <SupportKit.h>
|
#include <SupportKit.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
@ -49,9 +53,11 @@ static const char* includeKeys[] = {
|
|||||||
|
|
||||||
// --------------------------------------------------
|
// --------------------------------------------------
|
||||||
JobSetupWindow::JobSetupWindow(BMessage *msg, const char * printerName)
|
JobSetupWindow::JobSetupWindow(BMessage *msg, const char * printerName)
|
||||||
: HWindow(BRect(0, 0, 320, 160), "Job Setup", B_TITLED_WINDOW_LOOK,
|
: HWindow(BRect(0, 0, 100, 100), "Job Setup",
|
||||||
B_MODAL_APP_WINDOW_FEEL, B_NOT_RESIZABLE | B_NOT_MINIMIZABLE |
|
B_TITLED_WINDOW_LOOK,
|
||||||
B_NOT_ZOOMABLE)
|
B_MODAL_APP_WINDOW_FEEL,
|
||||||
|
B_NOT_RESIZABLE | B_NOT_MINIMIZABLE | B_NOT_ZOOMABLE
|
||||||
|
| B_AUTO_UPDATE_SIZE_LIMITS)
|
||||||
{
|
{
|
||||||
fSetupMsg = msg;
|
fSetupMsg = msg;
|
||||||
fExitSem = create_sem(0, "JobSetup");
|
fExitSem = create_sem(0, "JobSetup");
|
||||||
@ -64,27 +70,14 @@ JobSetupWindow::JobSetupWindow(BMessage *msg, const char * printerName)
|
|||||||
fPrinterName = printerName;
|
fPrinterName = printerName;
|
||||||
}
|
}
|
||||||
|
|
||||||
// ---- Ok, build a default job setup user interface
|
|
||||||
BRect r;
|
|
||||||
BBox *panel;
|
|
||||||
BBox *line;
|
|
||||||
BButton *ok;
|
|
||||||
BButton *cancel;
|
|
||||||
BStringView *sv;
|
|
||||||
float x, y, w, h;
|
|
||||||
float indent;
|
|
||||||
int32 copies;
|
|
||||||
int32 firstPage;
|
|
||||||
int32 lastPage;
|
|
||||||
bool allPages;
|
|
||||||
char buffer[80];
|
|
||||||
|
|
||||||
// PrinterDriver ensures that property exists
|
// PrinterDriver ensures that property exists
|
||||||
fSetupMsg->FindInt32("copies", &copies);
|
int32 firstPage;
|
||||||
fSetupMsg->FindInt32("first_page", &firstPage);
|
fSetupMsg->FindInt32("first_page", &firstPage);
|
||||||
|
int32 lastPage;
|
||||||
fSetupMsg->FindInt32("last_page", &lastPage);
|
fSetupMsg->FindInt32("last_page", &lastPage);
|
||||||
|
|
||||||
BMessage doc_info;
|
BMessage doc_info;
|
||||||
if (B_OK != fSetupMsg->FindMessage("doc_info", &doc_info)) {
|
if (fSetupMsg->FindMessage("doc_info", &doc_info) != B_OK) {
|
||||||
// default fields
|
// default fields
|
||||||
doc_info.AddString("Author", "");
|
doc_info.AddString("Author", "");
|
||||||
doc_info.AddString("Subject", "");
|
doc_info.AddString("Subject", "");
|
||||||
@ -93,150 +86,77 @@ JobSetupWindow::JobSetupWindow(BMessage *msg, const char * printerName)
|
|||||||
}
|
}
|
||||||
AddFields(&fDocInfo, fSetupMsg, NULL, includeKeys);
|
AddFields(&fDocInfo, fSetupMsg, NULL, includeKeys);
|
||||||
|
|
||||||
allPages = firstPage == 1 && lastPage == MAX_INT32;
|
bool allPages = firstPage == 1 && lastPage == MAX_INT32;
|
||||||
|
|
||||||
r = Bounds();
|
fAll = new BRadioButton("allPages", "Print all pages",
|
||||||
|
|
||||||
// add a *dialog* background
|
|
||||||
panel = new BBox(r, "top_panel", B_FOLLOW_ALL,
|
|
||||||
B_WILL_DRAW | B_FRAME_EVENTS | B_NAVIGABLE_JUMP,
|
|
||||||
B_PLAIN_BORDER);
|
|
||||||
|
|
||||||
const int kMargin = 6;
|
|
||||||
|
|
||||||
//const char *kCopiesLabel = "Copies:";
|
|
||||||
const char *kCopiesLabelExtraSpace = "Copies:##";
|
|
||||||
const char *kPagesRangeLabel = "Pages:";
|
|
||||||
const char *kAllPagesLabel = "All";
|
|
||||||
const char *kPagesRangeSelectionLabel = "";
|
|
||||||
const char *kFromLabel = "From:";
|
|
||||||
const char *kFromLabelExtraSpace = "From:##";
|
|
||||||
const char *kToLabel = "To:";
|
|
||||||
const char *kToLabelExtraSpace = "To:##";
|
|
||||||
|
|
||||||
r = panel->Bounds();
|
|
||||||
|
|
||||||
x = r.left + kMargin;
|
|
||||||
y = r.top + kMargin;
|
|
||||||
|
|
||||||
|
|
||||||
// add a "copies" input field
|
|
||||||
|
|
||||||
/* Simon: temporarily removed this code
|
|
||||||
sprintf(buffer, "%d", (int)copies);
|
|
||||||
fCopies = new BTextControl(BRect(x, y, x+100, y+20), "copies", kCopiesLabel,
|
|
||||||
buffer, new BMessage(NB_COPIES_MSG));
|
|
||||||
fCopies->SetAlignment(B_ALIGN_LEFT, B_ALIGN_RIGHT);
|
|
||||||
fCopies->ResizeToPreferred();
|
|
||||||
fCopies->GetPreferredSize(&w, &h);
|
|
||||||
panel->AddChild(fCopies);
|
|
||||||
|
|
||||||
y += h + kMargin; // "new line"
|
|
||||||
*/
|
|
||||||
// add a "pages" label
|
|
||||||
sv = new BStringView(BRect(x, y, x+100, y+20), "pages_range", kPagesRangeLabel);
|
|
||||||
panel->AddChild(sv);
|
|
||||||
sv->ResizeToPreferred();
|
|
||||||
sv->GetPreferredSize(&w, &h);
|
|
||||||
|
|
||||||
// align "copies" textcontrol field on the "allPages" radiobutton bellow...
|
|
||||||
indent = be_plain_font->StringWidth(kCopiesLabelExtraSpace);
|
|
||||||
w += kMargin;
|
|
||||||
if ( w > indent )
|
|
||||||
indent = w;
|
|
||||||
// fCopies->SetDivider(indent);
|
|
||||||
|
|
||||||
x += indent;
|
|
||||||
|
|
||||||
// add a "all" radiobutton
|
|
||||||
fAll = new BRadioButton(BRect(x, y, x+100, y+20), "all_pages", kAllPagesLabel,
|
|
||||||
new BMessage(ALL_PAGES_MGS));
|
new BMessage(ALL_PAGES_MGS));
|
||||||
fAll->ResizeToPreferred();
|
|
||||||
fAll->GetPreferredSize(&w, &h);
|
|
||||||
fAll->SetValue(allPages);
|
fAll->SetValue(allPages);
|
||||||
panel->AddChild(fAll);
|
|
||||||
|
|
||||||
y += h + kMargin; // "new line"
|
fRange = new BRadioButton("pagesRange", "Print pages:",
|
||||||
|
|
||||||
// add a range selection raddiobutton
|
|
||||||
fRange = new BRadioButton(BRect(x, y, x+100, y+20), "pages_range_selection", kPagesRangeSelectionLabel,
|
|
||||||
new BMessage(RANGE_SELECTION_MSG));
|
new BMessage(RANGE_SELECTION_MSG));
|
||||||
fRange->ResizeToPreferred();
|
|
||||||
fRange->GetPreferredSize(&w, &h);
|
|
||||||
fRange->SetValue(!allPages);
|
fRange->SetValue(!allPages);
|
||||||
panel->AddChild(fRange);
|
|
||||||
|
|
||||||
x += w + kMargin;
|
fFrom = new BTextControl("from", "From:", "SomeSpaceHere", NULL);
|
||||||
|
|
||||||
// add a "from" field
|
|
||||||
if (allPages) {
|
|
||||||
buffer[0] = 0;
|
|
||||||
} else {
|
|
||||||
sprintf(buffer, "%d", (int)firstPage);
|
|
||||||
}
|
|
||||||
fFrom = new BTextControl(BRect(x, y, x+100, y+20), "from_field", kFromLabel, buffer,
|
|
||||||
new BMessage(RANGE_FROM_MSG));
|
|
||||||
fFrom->SetAlignment(B_ALIGN_LEFT, B_ALIGN_RIGHT);
|
fFrom->SetAlignment(B_ALIGN_LEFT, B_ALIGN_RIGHT);
|
||||||
fFrom->SetDivider(be_plain_font->StringWidth(kFromLabelExtraSpace));
|
fFrom->SetEnabled(!allPages);
|
||||||
fFrom->ResizeToPreferred();
|
|
||||||
fFrom->GetPreferredSize(&w, &h);
|
|
||||||
panel->AddChild(fFrom);
|
|
||||||
|
|
||||||
x += w + kMargin;
|
fTo = new BTextControl("to", "To:", "", NULL);
|
||||||
|
|
||||||
// add a "to" field
|
|
||||||
if (allPages) {
|
|
||||||
buffer[0] = 0;
|
|
||||||
} else {
|
|
||||||
sprintf(buffer, "%d", (int)lastPage);
|
|
||||||
}
|
|
||||||
fTo = new BTextControl(BRect(x, y, x+100, y+20), "to_field", kToLabel, buffer,
|
|
||||||
new BMessage(RANGE_TO_MSG));
|
|
||||||
fTo->SetAlignment(B_ALIGN_LEFT, B_ALIGN_RIGHT);
|
fTo->SetAlignment(B_ALIGN_LEFT, B_ALIGN_RIGHT);
|
||||||
fTo->SetDivider(be_plain_font->StringWidth(kToLabelExtraSpace));
|
fTo->SetEnabled(!allPages);
|
||||||
fTo->ResizeToPreferred();
|
|
||||||
fTo->GetPreferredSize(&w, &h);
|
|
||||||
panel->AddChild(fTo);
|
|
||||||
|
|
||||||
y += h + kMargin + kMargin; // "new line"
|
BString buffer;
|
||||||
x = r.left + kMargin;
|
buffer << firstPage;
|
||||||
|
fFrom->SetText(buffer.String());
|
||||||
|
|
||||||
// add a separator line...
|
buffer = "";
|
||||||
line = new BBox(BRect(r.left, y - 1, r.right, y), NULL,
|
buffer << lastPage;
|
||||||
B_FOLLOW_LEFT_RIGHT | B_FOLLOW_TOP );
|
fTo->SetText(buffer.String());
|
||||||
panel->AddChild(line);
|
|
||||||
|
|
||||||
y += 2 + kMargin + kMargin; // "new line"
|
for (uint32 i = 0; i < '0'; i++) {
|
||||||
|
fTo->TextView()->DisallowChar(i);
|
||||||
|
fFrom->TextView()->DisallowChar(i);
|
||||||
|
}
|
||||||
|
|
||||||
// add a "OK" button, and make it default
|
for (uint32 i = '9' + 1; i < 255; i++) {
|
||||||
ok = new BButton(BRect(x, y, x+100, y+20), NULL, "OK", new BMessage(OK_MSG), B_FOLLOW_RIGHT | B_FOLLOW_TOP);
|
fTo->TextView()->DisallowChar(i);
|
||||||
|
fFrom->TextView()->DisallowChar(i);
|
||||||
|
}
|
||||||
|
|
||||||
|
BBox *separator = new BBox("separator");
|
||||||
|
separator->SetExplicitMaxSize(BSize(B_SIZE_UNLIMITED, 1));
|
||||||
|
|
||||||
|
BButton *documentInfo = new BButton("documentInfo",
|
||||||
|
"Document" B_UTF8_ELLIPSIS,
|
||||||
|
new BMessage(DOC_INFO_MSG));
|
||||||
|
|
||||||
|
BButton *cancel = new BButton("cancel", "Cancel", new BMessage(CANCEL_MSG));
|
||||||
|
|
||||||
|
BButton *ok = new BButton("ok", "OK", new BMessage(OK_MSG));
|
||||||
ok->MakeDefault(true);
|
ok->MakeDefault(true);
|
||||||
ok->ResizeToPreferred();
|
|
||||||
ok->GetPreferredSize(&w, &h);
|
|
||||||
x = r.right - w - kMargin;
|
|
||||||
ok->MoveTo(x, ok->Frame().top); // put the ok bottom at bottom right corner
|
|
||||||
panel->AddChild(ok);
|
|
||||||
|
|
||||||
// add a "Cancel" button
|
BGridView* settings = new BGridView();
|
||||||
cancel = new BButton(BRect(x, y, x + 100, y + 20), NULL, "Cancel", new BMessage(CANCEL_MSG), B_FOLLOW_RIGHT | B_FOLLOW_TOP);
|
BGridLayout* settingsLayout = settings->GridLayout();
|
||||||
cancel->ResizeToPreferred();
|
settingsLayout->AddItem(fFrom->CreateLabelLayoutItem(), 0, 0);
|
||||||
cancel->GetPreferredSize(&w, &h);
|
settingsLayout->AddItem(fFrom->CreateTextViewLayoutItem(), 1, 0);
|
||||||
cancel->MoveTo(x - w - kMargin, y); // put cancel button left next the ok button
|
settingsLayout->AddItem(fTo->CreateLabelLayoutItem(), 0, 1);
|
||||||
panel->AddChild(cancel);
|
settingsLayout->AddItem(fTo->CreateTextViewLayoutItem(), 1, 1);
|
||||||
|
settingsLayout->SetSpacing(0, 0);
|
||||||
|
|
||||||
// add a "DocInfo" button
|
SetLayout(new BGroupLayout(B_VERTICAL));
|
||||||
BButton *button = new BButton(r, NULL, "Doc Info", new BMessage(DOC_INFO_MSG),
|
AddChild(BGroupLayoutBuilder(B_VERTICAL, 0)
|
||||||
B_FOLLOW_RIGHT | B_FOLLOW_TOP);
|
.Add(fAll)
|
||||||
button->GetPreferredSize(&w, &h);
|
.Add(fRange)
|
||||||
button->ResizeToPreferred();
|
.Add(settings)
|
||||||
button->MoveTo(8, y);
|
.AddGlue()
|
||||||
panel->AddChild(button);
|
.Add(separator)
|
||||||
|
.AddGroup(B_HORIZONTAL, 10, 1.0f)
|
||||||
// Finally, add our panel to window
|
.Add(documentInfo)
|
||||||
AddChild(panel);
|
.AddGlue()
|
||||||
|
.Add(cancel)
|
||||||
// Auto resize window
|
.Add(ok)
|
||||||
ResizeTo(ok->Frame().right + kMargin, ok->Frame().bottom + kMargin);
|
.End()
|
||||||
|
.SetInsets(10, 10, 10, 10)
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -295,9 +215,14 @@ JobSetupWindow::MessageReceived(BMessage *msg)
|
|||||||
release_sem(fExitSem);
|
release_sem(fExitSem);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case RANGE_FROM_MSG:
|
case ALL_PAGES_MGS:
|
||||||
case RANGE_TO_MSG:
|
fTo->SetEnabled(false);
|
||||||
fRange->SetValue(B_CONTROL_ON);
|
fFrom->SetEnabled(false);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case RANGE_SELECTION_MSG:
|
||||||
|
fTo->SetEnabled(true);
|
||||||
|
fFrom->SetEnabled(true);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DOC_INFO_MSG:
|
case DOC_INFO_MSG:
|
||||||
|
@ -71,7 +71,6 @@ private:
|
|||||||
status_t fResult;
|
status_t fResult;
|
||||||
BMessage *fSetupMsg;
|
BMessage *fSetupMsg;
|
||||||
BMessage fDocInfo;
|
BMessage fDocInfo;
|
||||||
BTextControl *fCopies;
|
|
||||||
BRadioButton *fAll;
|
BRadioButton *fAll;
|
||||||
BRadioButton *fRange;
|
BRadioButton *fRange;
|
||||||
BTextControl *fFrom;
|
BTextControl *fFrom;
|
||||||
|
@ -45,6 +45,9 @@ THE SOFTWARE.
|
|||||||
|
|
||||||
#include <Box.h>
|
#include <Box.h>
|
||||||
#include <Button.h>
|
#include <Button.h>
|
||||||
|
#include <GridView.h>
|
||||||
|
#include <GroupLayout.h>
|
||||||
|
#include <GroupLayoutBuilder.h>
|
||||||
#include <MenuField.h>
|
#include <MenuField.h>
|
||||||
#include <Message.h>
|
#include <Message.h>
|
||||||
#include <PopUpMenu.h>
|
#include <PopUpMenu.h>
|
||||||
@ -92,9 +95,10 @@ static const char *pdf_compatibility[] = { "1.3", "1.4", NULL };
|
|||||||
|
|
||||||
|
|
||||||
PageSetupWindow::PageSetupWindow(BMessage *msg, const char *printerName)
|
PageSetupWindow::PageSetupWindow(BMessage *msg, const char *printerName)
|
||||||
: HWindow(BRect(0,0,400,220), "Page setup", B_TITLED_WINDOW_LOOK,
|
: HWindow(BRect(0, 0, 200, 100), "Page setup", B_TITLED_WINDOW_LOOK,
|
||||||
B_MODAL_APP_WINDOW_FEEL, B_NOT_RESIZABLE | B_NOT_MINIMIZABLE |
|
B_MODAL_APP_WINDOW_FEEL,
|
||||||
B_NOT_ZOOMABLE),
|
B_NOT_RESIZABLE | B_NOT_MINIMIZABLE | B_NOT_ZOOMABLE
|
||||||
|
| B_AUTO_UPDATE_SIZE_LIMITS),
|
||||||
fResult(B_ERROR),
|
fResult(B_ERROR),
|
||||||
fSetupMsg(msg),
|
fSetupMsg(msg),
|
||||||
fAdvancedSettings(*msg),
|
fAdvancedSettings(*msg),
|
||||||
@ -151,29 +155,13 @@ PageSetupWindow::PageSetupWindow(BMessage *msg, const char *printerName)
|
|||||||
if (fSetupMsg->FindMessage("fonts", &fonts) == B_OK)
|
if (fSetupMsg->FindMessage("fonts", &fonts) == B_OK)
|
||||||
fFonts->SetTo(&fonts);
|
fFonts->SetTo(&fonts);
|
||||||
|
|
||||||
// add a *dialog* background
|
fMarginView = new MarginView(int32(width), int32(height), margin,
|
||||||
BRect bounds(Bounds());
|
|
||||||
BBox *panel = new BBox(bounds, "background", B_FOLLOW_ALL,
|
|
||||||
B_WILL_DRAW | B_FRAME_EVENTS | B_NAVIGABLE_JUMP, B_PLAIN_BORDER);
|
|
||||||
AddChild(panel);
|
|
||||||
|
|
||||||
bounds.InsetBy(10.0, 10.0);
|
|
||||||
bounds.right = 230.0;
|
|
||||||
bounds.bottom = 160.0;
|
|
||||||
fMarginView = new MarginView(bounds, int32(width), int32(height), margin,
|
|
||||||
MarginUnit(units));
|
MarginUnit(units));
|
||||||
panel->AddChild(fMarginView);
|
|
||||||
fMarginView->SetResizingMode(B_FOLLOW_NONE);
|
|
||||||
|
|
||||||
BPopUpMenu* m = new BPopUpMenu("Page size");
|
BPopUpMenu* pageSize = new BPopUpMenu("Page size");
|
||||||
m->SetRadioMode(true);
|
pageSize->SetRadioMode(true);
|
||||||
|
|
||||||
bounds.OffsetBy(bounds.Width() + 10.0, 5.0);
|
fPageSizeMenu = new BMenuField("page_size", "Page size:", pageSize);
|
||||||
float divider = be_plain_font->StringWidth("PDF compatibility: ");
|
|
||||||
fPageSizeMenu = new BMenuField(bounds, "page_size", "Page size:", m);
|
|
||||||
panel->AddChild(fPageSizeMenu);
|
|
||||||
fPageSizeMenu->ResizeToPreferred();
|
|
||||||
fPageSizeMenu->SetDivider(divider);
|
|
||||||
fPageSizeMenu->Menu()->SetLabelFromMarked(true);
|
fPageSizeMenu->Menu()->SetLabelFromMarked(true);
|
||||||
|
|
||||||
for (int32 i = 0; pageFormat[i].label != NULL; i++) {
|
for (int32 i = 0; pageFormat[i].label != NULL; i++) {
|
||||||
@ -181,98 +169,97 @@ PageSetupWindow::PageSetupWindow(BMessage *msg, const char *printerName)
|
|||||||
message->AddFloat("width", pageFormat[i].width);
|
message->AddFloat("width", pageFormat[i].width);
|
||||||
message->AddFloat("height", pageFormat[i].height);
|
message->AddFloat("height", pageFormat[i].height);
|
||||||
BMenuItem* item = new BMenuItem(pageFormat[i].label, message);
|
BMenuItem* item = new BMenuItem(pageFormat[i].label, message);
|
||||||
m->AddItem(item);
|
pageSize->AddItem(item);
|
||||||
|
|
||||||
if (label.Compare(pageFormat[i].label) == 0)
|
if (label.Compare(pageFormat[i].label) == 0)
|
||||||
item->SetMarked(true);
|
item->SetMarked(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
m = new BPopUpMenu("Orientation");
|
BPopUpMenu* orientationPopUpMenu = new BPopUpMenu("Orientation");
|
||||||
m->SetRadioMode(true);
|
orientationPopUpMenu->SetRadioMode(true);
|
||||||
|
|
||||||
bounds.OffsetBy(0.0, fPageSizeMenu->Bounds().Height() + 10.0);
|
fOrientationMenu = new BMenuField("orientation", "Orientation:",
|
||||||
fOrientationMenu = new BMenuField(bounds, "orientation", "Orientation:", m);
|
orientationPopUpMenu);
|
||||||
panel->AddChild(fOrientationMenu);
|
|
||||||
fOrientationMenu->ResizeToPreferred();
|
|
||||||
fOrientationMenu->SetDivider(divider);
|
|
||||||
fOrientationMenu->Menu()->SetLabelFromMarked(true);
|
fOrientationMenu->Menu()->SetLabelFromMarked(true);
|
||||||
|
|
||||||
for (int32 i = 0; orientation[i].label != NULL; i++) {
|
for (int32 i = 0; orientation[i].label != NULL; i++) {
|
||||||
BMessage* message = new BMessage(ORIENTATION_CHANGED);
|
BMessage* message = new BMessage(ORIENTATION_CHANGED);
|
||||||
message->AddInt32("orientation", orientation[i].orientation);
|
message->AddInt32("orientation", orientation[i].orientation);
|
||||||
BMenuItem* item = new BMenuItem(orientation[i].label, message);
|
BMenuItem* item = new BMenuItem(orientation[i].label, message);
|
||||||
m->AddItem(item);
|
orientationPopUpMenu->AddItem(item);
|
||||||
|
|
||||||
if (fCurrentOrientation == orientation[i].orientation)
|
if (fCurrentOrientation == orientation[i].orientation)
|
||||||
item->SetMarked(true);
|
item->SetMarked(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
m = new BPopUpMenu("PDF compatibility");
|
BPopUpMenu* compatibility = new BPopUpMenu("PDF compatibility");
|
||||||
m->SetRadioMode(true);
|
compatibility->SetRadioMode(true);
|
||||||
|
|
||||||
bounds.OffsetBy(0.0, fOrientationMenu->Bounds().Height() + 10.0);
|
fPDFCompatibilityMenu = new BMenuField("pdf_compatibility",
|
||||||
fPDFCompatibilityMenu = new BMenuField(bounds, "pdf_compatibility",
|
"PDF compatibility:", compatibility);
|
||||||
"PDF compatibility:", m);
|
|
||||||
panel->AddChild(fPDFCompatibilityMenu);
|
|
||||||
fPDFCompatibilityMenu->ResizeToPreferred();
|
|
||||||
fPDFCompatibilityMenu->SetDivider(divider);
|
|
||||||
fPDFCompatibilityMenu->Menu()->SetLabelFromMarked(true);
|
fPDFCompatibilityMenu->Menu()->SetLabelFromMarked(true);
|
||||||
|
|
||||||
for (int32 i = 0; pdf_compatibility[i] != NULL; i++) {
|
for (int32 i = 0; pdf_compatibility[i] != NULL; i++) {
|
||||||
BMenuItem* item = new BMenuItem(pdf_compatibility[i], NULL);
|
BMenuItem* item = new BMenuItem(pdf_compatibility[i], NULL);
|
||||||
m->AddItem(item);
|
compatibility->AddItem(item);
|
||||||
if (setting_value == pdf_compatibility[i])
|
if (setting_value == pdf_compatibility[i])
|
||||||
item->SetMarked(true);
|
item->SetMarked(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
bounds.OffsetBy(0.0, fPDFCompatibilityMenu->Bounds().Height() + 10.0);
|
fPDFCompressionSlider = new BSlider("pdf_compression",
|
||||||
fPDFCompressionSlider = new BSlider(bounds, "pdf_compression",
|
"Compression:", NULL, 0, 9, B_HORIZONTAL);
|
||||||
"Compression:", NULL, 0, 9);
|
|
||||||
panel->AddChild(fPDFCompressionSlider);
|
|
||||||
fPDFCompressionSlider->SetLimitLabels("None", "Best");
|
fPDFCompressionSlider->SetLimitLabels("None", "Best");
|
||||||
fPDFCompressionSlider->SetHashMarks(B_HASH_MARKS_BOTTOM);
|
fPDFCompressionSlider->SetHashMarks(B_HASH_MARKS_BOTTOM);
|
||||||
fPDFCompressionSlider->SetValue(compression);
|
fPDFCompressionSlider->SetValue(compression);
|
||||||
fPDFCompressionSlider->ResizeToPreferred();
|
|
||||||
|
|
||||||
bounds = Bounds();
|
BBox *separator = new BBox("separator");
|
||||||
bounds.InsetBy(5.0, 0.0);
|
separator->SetExplicitMaxSize(BSize(B_SIZE_UNLIMITED, 1));
|
||||||
bounds.top = MAX(fPDFCompressionSlider->Frame().bottom,
|
|
||||||
fMarginView->Frame().bottom) + 10.0;
|
|
||||||
BBox *line = new BBox(BRect(bounds.left, bounds.top, bounds.right,
|
|
||||||
bounds.top + 1.0), NULL, B_FOLLOW_LEFT_RIGHT);
|
|
||||||
panel->AddChild(line);
|
|
||||||
|
|
||||||
bounds.InsetBy(5.0, 0.0);
|
BButton *cancel = new BButton("cancel", "Cancel", new BMessage(CANCEL_MSG));
|
||||||
bounds.OffsetBy(0.0, 11.0);
|
|
||||||
BButton *cancel = new BButton(bounds, NULL, "Cancel", new BMessage(CANCEL_MSG));
|
|
||||||
panel->AddChild(cancel);
|
|
||||||
cancel->ResizeToPreferred();
|
|
||||||
|
|
||||||
BButton *ok = new BButton(bounds, NULL, "OK", new BMessage(OK_MSG));
|
|
||||||
panel->AddChild(ok, cancel);
|
|
||||||
ok->ResizeToPreferred();
|
|
||||||
|
|
||||||
bounds.right = fPDFCompressionSlider->Frame().right;
|
|
||||||
ok->MoveTo(bounds.right - ok->Bounds().Width(), ok->Frame().top);
|
|
||||||
|
|
||||||
bounds = ok->Frame();
|
|
||||||
cancel->MoveTo(bounds.left - cancel->Bounds().Width() - 10.0, bounds.top);
|
|
||||||
|
|
||||||
|
BButton *ok = new BButton("ok", "OK", new BMessage(OK_MSG));
|
||||||
ok->MakeDefault(true);
|
ok->MakeDefault(true);
|
||||||
ResizeTo(bounds.right + 10.0, bounds.bottom + 10.0);
|
|
||||||
|
|
||||||
BButton *button = new BButton(bounds, NULL, "Fonts" B_UTF8_ELLIPSIS,
|
BButton *fontsButton = new BButton("fonts", "Fonts" B_UTF8_ELLIPSIS,
|
||||||
new BMessage(FONTS_MSG));
|
new BMessage(FONTS_MSG));
|
||||||
panel->AddChild(button);
|
|
||||||
button->ResizeToPreferred();
|
|
||||||
button->MoveTo(fMarginView->Frame().left, bounds.top);
|
|
||||||
|
|
||||||
bounds = button->Frame();
|
BButton* advancedButton = new BButton("advanced",
|
||||||
button = new BButton(bounds, NULL, "Advanced" B_UTF8_ELLIPSIS,
|
"Advanced" B_UTF8_ELLIPSIS,
|
||||||
new BMessage(ADVANCED_MSG));
|
new BMessage(ADVANCED_MSG));
|
||||||
panel->AddChild(button);
|
|
||||||
button->ResizeToPreferred();
|
BGridView* settings = new BGridView();
|
||||||
button->MoveTo(bounds.right + 10, bounds.top);
|
BGridLayout* settingsLayout = settings->GridLayout();
|
||||||
|
settingsLayout->AddItem(fPageSizeMenu->CreateLabelLayoutItem(), 0, 0);
|
||||||
|
settingsLayout->AddItem(fPageSizeMenu->CreateMenuBarLayoutItem(), 1, 0);
|
||||||
|
settingsLayout->AddItem(fOrientationMenu->CreateLabelLayoutItem(), 0, 1);
|
||||||
|
settingsLayout->AddItem(fOrientationMenu->CreateMenuBarLayoutItem(), 1, 1);
|
||||||
|
settingsLayout->AddItem(fPDFCompatibilityMenu->CreateLabelLayoutItem(), 0, 2);
|
||||||
|
settingsLayout->AddItem(fPDFCompatibilityMenu->CreateMenuBarLayoutItem(), 1, 2);
|
||||||
|
settingsLayout->AddView(fPDFCompressionSlider, 0, 3, 2);
|
||||||
|
settingsLayout->SetSpacing(0, 0);
|
||||||
|
|
||||||
|
SetLayout(new BGroupLayout(B_VERTICAL));
|
||||||
|
AddChild(BGroupLayoutBuilder(B_VERTICAL, 0)
|
||||||
|
.AddGroup(B_HORIZONTAL, 5, 1)
|
||||||
|
.AddGroup(B_VERTICAL, 0, 1.0f)
|
||||||
|
.Add(fMarginView)
|
||||||
|
.AddGlue()
|
||||||
|
.End()
|
||||||
|
.AddGroup(B_VERTICAL, 0, 1.0f)
|
||||||
|
.Add(settings)
|
||||||
|
.AddGlue()
|
||||||
|
.End()
|
||||||
|
.End()
|
||||||
|
.Add(separator)
|
||||||
|
.AddGroup(B_HORIZONTAL, 10, 1.0f)
|
||||||
|
.Add(fontsButton)
|
||||||
|
.Add(advancedButton)
|
||||||
|
.AddGlue()
|
||||||
|
.Add(cancel)
|
||||||
|
.Add(ok)
|
||||||
|
.End()
|
||||||
|
.SetInsets(10, 10, 10, 10)
|
||||||
|
);
|
||||||
|
|
||||||
BRect winFrame(Frame());
|
BRect winFrame(Frame());
|
||||||
BRect screenFrame(BScreen().Frame());
|
BRect screenFrame(BScreen().Frame());
|
||||||
|
@ -37,7 +37,6 @@ THE SOFTWARE.
|
|||||||
|
|
||||||
#include "PrinterDriver.h"
|
#include "PrinterDriver.h"
|
||||||
|
|
||||||
#include "PrinterSetupWindow.h"
|
|
||||||
#include "PageSetupWindow.h"
|
#include "PageSetupWindow.h"
|
||||||
#include "JobSetupWindow.h"
|
#include "JobSetupWindow.h"
|
||||||
#include "StatusWindow.h"
|
#include "StatusWindow.h"
|
||||||
@ -222,10 +221,7 @@ status_t
|
|||||||
PrinterDriver::PrinterSetup(char *printerName)
|
PrinterDriver::PrinterSetup(char *printerName)
|
||||||
// name of printer, to attach printer settings
|
// name of printer, to attach printer settings
|
||||||
{
|
{
|
||||||
PrinterSetupWindow *psw;
|
return B_OK;
|
||||||
|
|
||||||
psw = new PrinterSetupWindow(printerName);
|
|
||||||
return psw->Go();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -1,249 +0,0 @@
|
|||||||
/*
|
|
||||||
|
|
||||||
PDF Writer printer driver.
|
|
||||||
|
|
||||||
Copyright (c) 2001 OpenBeOS.
|
|
||||||
|
|
||||||
Authors:
|
|
||||||
Philippe Houdoin
|
|
||||||
Simon Gauvin
|
|
||||||
Michael Pfeiffer
|
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy of
|
|
||||||
this software and associated documentation files (the "Software"), to deal in
|
|
||||||
the Software without restriction, including without limitation the rights to
|
|
||||||
use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies
|
|
||||||
of the Software, and to permit persons to whom the Software is furnished to do
|
|
||||||
so, subject to the following conditions:
|
|
||||||
|
|
||||||
The above copyright notice and this permission notice shall be included in all
|
|
||||||
copies or substantial portions of the Software.
|
|
||||||
|
|
||||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
||||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
||||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
||||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
||||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
||||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
||||||
THE SOFTWARE.
|
|
||||||
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include <InterfaceKit.h>
|
|
||||||
#include <StorageKit.h>
|
|
||||||
#include <SupportKit.h>
|
|
||||||
|
|
||||||
#include "PrinterSetupWindow.h"
|
|
||||||
|
|
||||||
// --------------------------------------------------
|
|
||||||
PrinterSetupWindow::PrinterSetupWindow(char *printerName)
|
|
||||||
: HWindow(BRect(0,0,300,300), printerName, B_TITLED_WINDOW_LOOK,
|
|
||||||
B_MODAL_APP_WINDOW_FEEL, B_NOT_ZOOMABLE)
|
|
||||||
{
|
|
||||||
fExitSem = create_sem(0, "PrinterSetup");
|
|
||||||
fResult = B_ERROR;
|
|
||||||
fPrinterName = printerName;
|
|
||||||
|
|
||||||
if (printerName) {
|
|
||||||
BString title;
|
|
||||||
title << printerName << " Printer Setup";
|
|
||||||
SetTitle(title.String());
|
|
||||||
} else
|
|
||||||
SetTitle("Printer Setup");
|
|
||||||
|
|
||||||
// ---- Ok, build a default job setup user interface
|
|
||||||
BRect r;
|
|
||||||
BButton *button;
|
|
||||||
float x, y, w, h;
|
|
||||||
font_height fh;
|
|
||||||
|
|
||||||
r = Bounds();
|
|
||||||
|
|
||||||
// add a *dialog* background
|
|
||||||
BBox *panel = new BBox(r, "top_panel", B_FOLLOW_ALL,
|
|
||||||
B_WILL_DRAW | B_FRAME_EVENTS | B_NAVIGABLE_JUMP,
|
|
||||||
B_PLAIN_BORDER);
|
|
||||||
|
|
||||||
|
|
||||||
const int kInterSpace = 8;
|
|
||||||
const int kHorzMargin = 10;
|
|
||||||
const int kVertMargin = 10;
|
|
||||||
|
|
||||||
x = kHorzMargin;
|
|
||||||
y = kVertMargin;
|
|
||||||
|
|
||||||
// add a label before the list
|
|
||||||
const char *kModelLabel = "Printer model";
|
|
||||||
|
|
||||||
be_plain_font->GetHeight(&fh);
|
|
||||||
|
|
||||||
w = Bounds().Width();
|
|
||||||
w -= 2 * kHorzMargin;
|
|
||||||
h = 150;
|
|
||||||
|
|
||||||
BBox * model_group = new BBox(BRect(x, y, x+w, y+h), "model_group", B_FOLLOW_ALL_SIDES);
|
|
||||||
model_group->SetLabel(kModelLabel);
|
|
||||||
|
|
||||||
BRect rlv = model_group->Bounds();
|
|
||||||
|
|
||||||
rlv.InsetBy(kHorzMargin, kVertMargin);
|
|
||||||
rlv.top += fh.ascent + fh.descent + fh.leading;
|
|
||||||
rlv.right -= B_V_SCROLL_BAR_WIDTH;
|
|
||||||
fModelList = new BListView(rlv, "model_list",
|
|
||||||
B_SINGLE_SELECTION_LIST, B_FOLLOW_ALL_SIDES );
|
|
||||||
|
|
||||||
BScrollView * sv = new BScrollView( "model_list_scrollview", fModelList,
|
|
||||||
B_FOLLOW_ALL_SIDES, B_WILL_DRAW | B_FRAME_EVENTS, false, true );
|
|
||||||
model_group->AddChild(sv);
|
|
||||||
|
|
||||||
panel->AddChild(model_group);
|
|
||||||
|
|
||||||
y += (h + kInterSpace);
|
|
||||||
|
|
||||||
x = r.right - kHorzMargin;
|
|
||||||
|
|
||||||
// add a "OK" button, and make it default
|
|
||||||
fOkButton = new BButton(BRect(x, y, x + 400, y), NULL, "OK", new BMessage(OK_MSG), B_FOLLOW_RIGHT | B_FOLLOW_BOTTOM);
|
|
||||||
fOkButton->ResizeToPreferred();
|
|
||||||
fOkButton->GetPreferredSize(&w, &h);
|
|
||||||
x -= w;
|
|
||||||
fOkButton->MoveTo(x, y);
|
|
||||||
fOkButton->MakeDefault(true);
|
|
||||||
fOkButton->SetEnabled(false);
|
|
||||||
|
|
||||||
panel->AddChild(fOkButton);
|
|
||||||
|
|
||||||
x -= kInterSpace;
|
|
||||||
|
|
||||||
// add a "Cancel" button
|
|
||||||
button = new BButton(BRect(x, y, x + 400, y), NULL, "Cancel", new BMessage(CANCEL_MSG), B_FOLLOW_RIGHT | B_FOLLOW_BOTTOM);
|
|
||||||
button->ResizeToPreferred();
|
|
||||||
button->GetPreferredSize(&w, &h);
|
|
||||||
x -= w;
|
|
||||||
button->MoveTo(x, y);
|
|
||||||
panel->AddChild(button);
|
|
||||||
|
|
||||||
y += (h + kInterSpace);
|
|
||||||
|
|
||||||
panel->ResizeTo(Bounds().Width(), y);
|
|
||||||
ResizeTo(Bounds().Width(), y);
|
|
||||||
|
|
||||||
float minWidth, maxWidth, minHeight, maxHeight;
|
|
||||||
|
|
||||||
GetSizeLimits(&minWidth, &maxWidth, &minHeight, &maxHeight);
|
|
||||||
SetSizeLimits(panel->Frame().Width(), panel->Frame().Width(),
|
|
||||||
panel->Frame().Height(), maxHeight);
|
|
||||||
|
|
||||||
// Finally, add our panel to window
|
|
||||||
AddChild(panel);
|
|
||||||
|
|
||||||
BDirectory Folder;
|
|
||||||
BEntry entry;
|
|
||||||
|
|
||||||
Folder.SetTo ("/boot/beos/etc/bubblejet");
|
|
||||||
if (Folder.InitCheck() != B_OK)
|
|
||||||
return;
|
|
||||||
|
|
||||||
while (Folder.GetNextEntry(&entry) != B_ENTRY_NOT_FOUND) {
|
|
||||||
char name[B_FILE_NAME_LENGTH];
|
|
||||||
if (entry.GetName(name) == B_NO_ERROR)
|
|
||||||
fModelList->AddItem (new BStringItem(name));
|
|
||||||
}
|
|
||||||
|
|
||||||
fModelList->SetSelectionMessage(new BMessage(MODEL_MSG));
|
|
||||||
fModelList->SetInvocationMessage(new BMessage(OK_MSG));
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// --------------------------------------------------
|
|
||||||
PrinterSetupWindow::~PrinterSetupWindow()
|
|
||||||
{
|
|
||||||
delete_sem(fExitSem);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// --------------------------------------------------
|
|
||||||
bool
|
|
||||||
PrinterSetupWindow::QuitRequested()
|
|
||||||
{
|
|
||||||
release_sem(fExitSem);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// --------------------------------------------------
|
|
||||||
void
|
|
||||||
PrinterSetupWindow::MessageReceived(BMessage *msg)
|
|
||||||
{
|
|
||||||
switch (msg->what) {
|
|
||||||
case OK_MSG:
|
|
||||||
{
|
|
||||||
// Test model selection (if any), save it in printerName node and return
|
|
||||||
BNode spoolDir;
|
|
||||||
BPath * path;
|
|
||||||
|
|
||||||
if (fModelList->CurrentSelection() < 0)
|
|
||||||
break;
|
|
||||||
|
|
||||||
BStringItem * item = dynamic_cast<BStringItem*>
|
|
||||||
(fModelList->ItemAt(fModelList->CurrentSelection()));
|
|
||||||
|
|
||||||
if (!item)
|
|
||||||
break;
|
|
||||||
|
|
||||||
path = new BPath();
|
|
||||||
|
|
||||||
find_directory(B_USER_SETTINGS_DIRECTORY, path);
|
|
||||||
path->Append("printers");
|
|
||||||
path->Append(fPrinterName);
|
|
||||||
|
|
||||||
spoolDir.SetTo(path->Path());
|
|
||||||
delete path;
|
|
||||||
|
|
||||||
if (spoolDir.InitCheck() != B_OK) {
|
|
||||||
BAlert * alert = new BAlert("Uh oh!",
|
|
||||||
"Couldn't find printer spool directory.", "OK");
|
|
||||||
alert->Go();
|
|
||||||
} else {
|
|
||||||
spoolDir.WriteAttr("printer_model", B_STRING_TYPE, 0, item->Text(),
|
|
||||||
strlen(item->Text()));
|
|
||||||
fResult = B_OK;
|
|
||||||
}
|
|
||||||
|
|
||||||
release_sem(fExitSem);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
case CANCEL_MSG:
|
|
||||||
fResult = B_ERROR;
|
|
||||||
release_sem(fExitSem);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case MODEL_MSG:
|
|
||||||
fOkButton->SetEnabled((fModelList->CurrentSelection() >= 0));
|
|
||||||
break;
|
|
||||||
|
|
||||||
default:
|
|
||||||
inherited::MessageReceived(msg);
|
|
||||||
break;
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// --------------------------------------------------
|
|
||||||
status_t
|
|
||||||
PrinterSetupWindow::Go()
|
|
||||||
{
|
|
||||||
MoveTo(300, 300);
|
|
||||||
Show();
|
|
||||||
|
|
||||||
while (acquire_sem(fExitSem) == B_INTERRUPTED) {
|
|
||||||
}
|
|
||||||
|
|
||||||
// cache the value as after Quit() this object is deleted
|
|
||||||
status_t result = fResult;
|
|
||||||
if (Lock())
|
|
||||||
Quit();
|
|
||||||
|
|
||||||
return result;
|
|
||||||
}
|
|
@ -1,72 +0,0 @@
|
|||||||
/*
|
|
||||||
|
|
||||||
PDF Writer printer driver.
|
|
||||||
|
|
||||||
Copyright (c) 2001 OpenBeOS.
|
|
||||||
|
|
||||||
Authors:
|
|
||||||
Philippe Houdoin
|
|
||||||
Simon Gauvin
|
|
||||||
Michael Pfeiffer
|
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy of
|
|
||||||
this software and associated documentation files (the "Software"), to deal in
|
|
||||||
the Software without restriction, including without limitation the rights to
|
|
||||||
use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies
|
|
||||||
of the Software, and to permit persons to whom the Software is furnished to do
|
|
||||||
so, subject to the following conditions:
|
|
||||||
|
|
||||||
The above copyright notice and this permission notice shall be included in all
|
|
||||||
copies or substantial portions of the Software.
|
|
||||||
|
|
||||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
||||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
||||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
||||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
||||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
||||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
||||||
THE SOFTWARE.
|
|
||||||
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef PRINTERSETUPWINDOW_H
|
|
||||||
#define PRINTERSETUPWINDOW_H
|
|
||||||
|
|
||||||
#include <InterfaceKit.h>
|
|
||||||
#include "BlockingWindow.h"
|
|
||||||
#include "PrintUtils.h"
|
|
||||||
|
|
||||||
class PrinterSetupWindow : public HWindow
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
// Constructors, destructors, operators...
|
|
||||||
|
|
||||||
PrinterSetupWindow(char *printerName);
|
|
||||||
~PrinterSetupWindow();
|
|
||||||
|
|
||||||
typedef HWindow inherited;
|
|
||||||
|
|
||||||
// public constantes
|
|
||||||
enum {
|
|
||||||
OK_MSG = 'ok__',
|
|
||||||
CANCEL_MSG = 'cncl',
|
|
||||||
MODEL_MSG = 'modl'
|
|
||||||
};
|
|
||||||
|
|
||||||
// Virtual function overrides
|
|
||||||
public:
|
|
||||||
virtual void MessageReceived(BMessage *msg);
|
|
||||||
virtual bool QuitRequested();
|
|
||||||
status_t Go();
|
|
||||||
|
|
||||||
// From here, it's none of your business! ;-)
|
|
||||||
private:
|
|
||||||
BButton *fOkButton;
|
|
||||||
BListView *fModelList;
|
|
||||||
char *fPrinterName;
|
|
||||||
long fExitSem;
|
|
||||||
status_t fResult;
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
@ -18,15 +18,19 @@
|
|||||||
|
|
||||||
#include <Box.h>
|
#include <Box.h>
|
||||||
#include <Button.h>
|
#include <Button.h>
|
||||||
|
#include <GridView.h>
|
||||||
|
#include <GroupLayout.h>
|
||||||
|
#include <GroupLayoutBuilder.h>
|
||||||
#include <RadioButton.h>
|
#include <RadioButton.h>
|
||||||
#include <Screen.h>
|
#include <Screen.h>
|
||||||
#include <TextControl.h>
|
#include <TextControl.h>
|
||||||
|
|
||||||
|
|
||||||
JobSetupWindow::JobSetupWindow(BMessage *msg, const char * printerName)
|
JobSetupWindow::JobSetupWindow(BMessage *msg, const char * printerName)
|
||||||
: BlockingWindow(BRect(0, 0, 300, 200), "Job Setup", B_TITLED_WINDOW_LOOK,
|
: BlockingWindow(BRect(0, 0, 100, 100), "Job Setup",
|
||||||
|
B_TITLED_WINDOW_LOOK,
|
||||||
B_MODAL_APP_WINDOW_FEEL, B_NOT_RESIZABLE | B_NOT_MINIMIZABLE |
|
B_MODAL_APP_WINDOW_FEEL, B_NOT_RESIZABLE | B_NOT_MINIMIZABLE |
|
||||||
B_NOT_ZOOMABLE),
|
B_NOT_ZOOMABLE | B_AUTO_UPDATE_SIZE_LIMITS),
|
||||||
fPrinterName(printerName),
|
fPrinterName(printerName),
|
||||||
fSetupMsg(msg)
|
fSetupMsg(msg)
|
||||||
{
|
{
|
||||||
@ -40,42 +44,20 @@ JobSetupWindow::JobSetupWindow(BMessage *msg, const char * printerName)
|
|||||||
fSetupMsg->FindInt32("last_page", &lastPage);
|
fSetupMsg->FindInt32("last_page", &lastPage);
|
||||||
bool allPages = firstPage == 1 && lastPage == LONG_MAX;
|
bool allPages = firstPage == 1 && lastPage == LONG_MAX;
|
||||||
|
|
||||||
BRect bounds(Bounds());
|
fAll = new BRadioButton("allPages", "Print all pages",
|
||||||
BBox *panel = new BBox(bounds, "background", B_FOLLOW_ALL,
|
|
||||||
B_WILL_DRAW | B_FRAME_EVENTS | B_NAVIGABLE_JUMP, B_PLAIN_BORDER);
|
|
||||||
AddChild(panel);
|
|
||||||
|
|
||||||
bounds.InsetBy(10.0, 10.0);
|
|
||||||
|
|
||||||
fAll = new BRadioButton(bounds, "allPages", "Print all pages",
|
|
||||||
new BMessage(ALL_PAGES_MGS));
|
new BMessage(ALL_PAGES_MGS));
|
||||||
panel->AddChild(fAll);
|
|
||||||
fAll->ResizeToPreferred();
|
|
||||||
fAll->SetValue(allPages);
|
fAll->SetValue(allPages);
|
||||||
|
|
||||||
bounds.OffsetBy(0.0, fAll->Bounds().Height() + 10.0);
|
fRange = new BRadioButton("pagesRange", "Print selected pages:",
|
||||||
fRange = new BRadioButton(bounds, "pagesRange", "Print pages:",
|
|
||||||
new BMessage(RANGE_SELECTION_MSG));
|
new BMessage(RANGE_SELECTION_MSG));
|
||||||
panel->AddChild(fRange);
|
|
||||||
fRange->ResizeToPreferred();
|
|
||||||
fRange->SetValue(!allPages);
|
fRange->SetValue(!allPages);
|
||||||
|
|
||||||
bounds.OffsetBy(0.0, fRange->Bounds().Height() + 5.0);
|
fFrom = new BTextControl("from", "From:", "SomeSpaceHere", NULL);
|
||||||
BRect rect(bounds);
|
|
||||||
rect.right = be_plain_font->StringWidth("From: SomeSpaceHere");
|
|
||||||
fFrom = new BTextControl(rect, "from", "From:", "SomeSpaceHere", NULL);
|
|
||||||
panel->AddChild(fFrom);
|
|
||||||
fFrom->SetAlignment(B_ALIGN_LEFT, B_ALIGN_RIGHT);
|
fFrom->SetAlignment(B_ALIGN_LEFT, B_ALIGN_RIGHT);
|
||||||
fFrom->ResizeToPreferred();
|
|
||||||
fFrom->SetDivider(be_plain_font->StringWidth("From: "));
|
|
||||||
fFrom->SetEnabled(!allPages);
|
fFrom->SetEnabled(!allPages);
|
||||||
|
|
||||||
rect = fFrom->Frame();
|
fTo = new BTextControl("to", "To:", "", NULL);
|
||||||
fTo = new BTextControl(rect, "to", "To:", "SomeSpaceHere", NULL);
|
|
||||||
panel->AddChild(fTo);
|
|
||||||
fTo->SetAlignment(B_ALIGN_LEFT, B_ALIGN_RIGHT);
|
fTo->SetAlignment(B_ALIGN_LEFT, B_ALIGN_RIGHT);
|
||||||
fTo->SetDivider(be_plain_font->StringWidth("To: "));
|
|
||||||
fTo->MoveTo(fFrom->Frame().right + 10.0, fTo->Frame().top);
|
|
||||||
fTo->SetEnabled(!allPages);
|
fTo->SetEnabled(!allPages);
|
||||||
|
|
||||||
BString buffer;
|
BString buffer;
|
||||||
@ -96,28 +78,37 @@ JobSetupWindow::JobSetupWindow(BMessage *msg, const char * printerName)
|
|||||||
fFrom->TextView()->DisallowChar(i);
|
fFrom->TextView()->DisallowChar(i);
|
||||||
}
|
}
|
||||||
|
|
||||||
bounds.OffsetBy(0.0, fTo->Bounds().Height() + 10.0);
|
BBox *separator = new BBox("separator");
|
||||||
BBox *line = new BBox(BRect(bounds.left - 5.0, bounds.top, bounds.right + 5.0,
|
separator->SetExplicitMaxSize(BSize(B_SIZE_UNLIMITED, 1));
|
||||||
bounds.top + 1.0), NULL, B_FOLLOW_LEFT_RIGHT | B_FOLLOW_TOP );
|
|
||||||
panel->AddChild(line);
|
|
||||||
|
|
||||||
bounds.OffsetBy(0.0, 11.0);
|
BButton *cancel = new BButton("cancel", "Cancel", new BMessage(CANCEL_MSG));
|
||||||
BButton *cancel = new BButton(bounds, NULL, "Cancel", new BMessage(CANCEL_MSG));
|
|
||||||
panel->AddChild(cancel);
|
|
||||||
cancel->ResizeToPreferred();
|
|
||||||
|
|
||||||
BButton *ok = new BButton(bounds, NULL, "OK", new BMessage(OK_MSG));
|
|
||||||
panel->AddChild(ok, cancel);
|
|
||||||
ok->ResizeToPreferred();
|
|
||||||
|
|
||||||
bounds.right = fTo->Frame().right;
|
|
||||||
ok->MoveTo(bounds.right - ok->Bounds().Width(), ok->Frame().top);
|
|
||||||
|
|
||||||
bounds = ok->Frame();
|
|
||||||
cancel->MoveTo(bounds.left - cancel->Bounds().Width() - 10.0, bounds.top);
|
|
||||||
|
|
||||||
|
BButton *ok = new BButton("ok", "OK", new BMessage(OK_MSG));
|
||||||
ok->MakeDefault(true);
|
ok->MakeDefault(true);
|
||||||
ResizeTo(bounds.right + 10.0, bounds.bottom + 10.0);
|
|
||||||
|
BGridView* settings = new BGridView();
|
||||||
|
BGridLayout* settingsLayout = settings->GridLayout();
|
||||||
|
settingsLayout->AddItem(fFrom->CreateLabelLayoutItem(), 0, 0);
|
||||||
|
settingsLayout->AddItem(fFrom->CreateTextViewLayoutItem(), 1, 0);
|
||||||
|
settingsLayout->AddItem(fTo->CreateLabelLayoutItem(), 0, 1);
|
||||||
|
settingsLayout->AddItem(fTo->CreateTextViewLayoutItem(), 1, 1);
|
||||||
|
settingsLayout->SetSpacing(0, 0);
|
||||||
|
|
||||||
|
SetLayout(new BGroupLayout(B_VERTICAL));
|
||||||
|
AddChild(BGroupLayoutBuilder(B_VERTICAL, 0)
|
||||||
|
.Add(fAll)
|
||||||
|
.Add(fRange)
|
||||||
|
.Add(settings)
|
||||||
|
.AddGlue()
|
||||||
|
.Add(separator)
|
||||||
|
.AddGroup(B_HORIZONTAL, 10, 1.0f)
|
||||||
|
.AddGlue()
|
||||||
|
.Add(cancel)
|
||||||
|
.Add(ok)
|
||||||
|
.End()
|
||||||
|
.SetInsets(10, 10, 10, 10)
|
||||||
|
);
|
||||||
|
|
||||||
|
|
||||||
BRect winFrame(Frame());
|
BRect winFrame(Frame());
|
||||||
BRect screenFrame(BScreen().Frame());
|
BRect screenFrame(BScreen().Frame());
|
||||||
@ -154,27 +145,27 @@ void
|
|||||||
JobSetupWindow::MessageReceived(BMessage *msg)
|
JobSetupWindow::MessageReceived(BMessage *msg)
|
||||||
{
|
{
|
||||||
switch (msg->what) {
|
switch (msg->what) {
|
||||||
case OK_MSG: {
|
case OK_MSG:
|
||||||
UpdateJobMessage();
|
UpdateJobMessage();
|
||||||
Quit(B_OK);
|
Quit(B_OK);
|
||||||
} break;
|
break;
|
||||||
|
|
||||||
case CANCEL_MSG: {
|
case CANCEL_MSG:
|
||||||
Quit(B_ERROR);
|
Quit(B_ERROR);
|
||||||
} break;
|
break;
|
||||||
|
|
||||||
case ALL_PAGES_MGS : {
|
case ALL_PAGES_MGS:
|
||||||
fTo->SetEnabled(false);
|
fTo->SetEnabled(false);
|
||||||
fFrom->SetEnabled(false);
|
fFrom->SetEnabled(false);
|
||||||
} break;
|
break;
|
||||||
|
|
||||||
case RANGE_SELECTION_MSG : {
|
case RANGE_SELECTION_MSG:
|
||||||
fTo->SetEnabled(true);
|
fTo->SetEnabled(true);
|
||||||
fFrom->SetEnabled(true);
|
fFrom->SetEnabled(true);
|
||||||
} break;
|
break;
|
||||||
|
|
||||||
default: {
|
default:
|
||||||
BlockingWindow::MessageReceived(msg);
|
BlockingWindow::MessageReceived(msg);
|
||||||
} break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -20,6 +20,9 @@
|
|||||||
|
|
||||||
#include <Box.h>
|
#include <Box.h>
|
||||||
#include <Button.h>
|
#include <Button.h>
|
||||||
|
#include <GridView.h>
|
||||||
|
#include <GroupLayout.h>
|
||||||
|
#include <GroupLayoutBuilder.h>
|
||||||
#include <MenuField.h>
|
#include <MenuField.h>
|
||||||
#include <Message.h>
|
#include <Message.h>
|
||||||
#include <PopUpMenu.h>
|
#include <PopUpMenu.h>
|
||||||
@ -90,9 +93,11 @@ static struct
|
|||||||
|
|
||||||
|
|
||||||
PageSetupWindow::PageSetupWindow(BMessage *msg, const char *printerName)
|
PageSetupWindow::PageSetupWindow(BMessage *msg, const char *printerName)
|
||||||
: BlockingWindow(BRect(0,0,400,220), "Page setup", B_TITLED_WINDOW_LOOK,
|
: BlockingWindow(BRect(0, 0, 100, 100), "Page setup",
|
||||||
B_MODAL_APP_WINDOW_FEEL, B_NOT_RESIZABLE | B_NOT_MINIMIZABLE |
|
B_TITLED_WINDOW_LOOK,
|
||||||
B_NOT_ZOOMABLE),
|
B_MODAL_APP_WINDOW_FEEL,
|
||||||
|
B_NOT_RESIZABLE | B_NOT_MINIMIZABLE | B_NOT_ZOOMABLE
|
||||||
|
| B_AUTO_UPDATE_SIZE_LIMITS),
|
||||||
fSetupMsg(msg),
|
fSetupMsg(msg),
|
||||||
fPrinterDirName(printerName)
|
fPrinterDirName(printerName)
|
||||||
{
|
{
|
||||||
@ -134,28 +139,14 @@ PageSetupWindow::PageSetupWindow(BMessage *msg, const char *printerName)
|
|||||||
margin.Set(28.34, 28.34, 28.34, 28.34); // 28.34 dots = 1cm
|
margin.Set(28.34, 28.34, 28.34, 28.34); // 28.34 dots = 1cm
|
||||||
}
|
}
|
||||||
|
|
||||||
BRect bounds(Bounds());
|
|
||||||
BBox *panel = new BBox(bounds, "background", B_FOLLOW_ALL,
|
|
||||||
B_WILL_DRAW | B_FRAME_EVENTS | B_NAVIGABLE_JUMP, B_PLAIN_BORDER);
|
|
||||||
AddChild(panel);
|
|
||||||
|
|
||||||
bounds.InsetBy(10.0, 10.0);
|
fMarginView = new MarginView(int32(width), int32(height), margin,
|
||||||
bounds.right = 230.0;
|
|
||||||
bounds.bottom = 160.0;
|
|
||||||
fMarginView = new MarginView(bounds, int32(width), int32(height), margin,
|
|
||||||
MarginUnit(units));
|
MarginUnit(units));
|
||||||
panel->AddChild(fMarginView);
|
|
||||||
fMarginView->SetResizingMode(B_FOLLOW_NONE);
|
|
||||||
|
|
||||||
BPopUpMenu* m = new BPopUpMenu("Page size");
|
BPopUpMenu* pageSizePopUpMenu = new BPopUpMenu("Page size");
|
||||||
m->SetRadioMode(true);
|
pageSizePopUpMenu->SetRadioMode(true);
|
||||||
|
|
||||||
bounds.OffsetBy(bounds.Width() + 10.0, 5.0);
|
fPageSizeMenu = new BMenuField("page_size", "Page size:", pageSizePopUpMenu);
|
||||||
float divider = be_plain_font->StringWidth("Orientation: ");
|
|
||||||
fPageSizeMenu = new BMenuField(bounds, "page_size", "Page size:", m);
|
|
||||||
panel->AddChild(fPageSizeMenu);
|
|
||||||
fPageSizeMenu->ResizeToPreferred();
|
|
||||||
fPageSizeMenu->SetDivider(divider);
|
|
||||||
fPageSizeMenu->Menu()->SetLabelFromMarked(true);
|
fPageSizeMenu->Menu()->SetLabelFromMarked(true);
|
||||||
|
|
||||||
for (int32 i = 0; pageFormat[i].label != NULL; i++) {
|
for (int32 i = 0; pageFormat[i].label != NULL; i++) {
|
||||||
@ -163,27 +154,24 @@ PageSetupWindow::PageSetupWindow(BMessage *msg, const char *printerName)
|
|||||||
message->AddFloat("width", pageFormat[i].width);
|
message->AddFloat("width", pageFormat[i].width);
|
||||||
message->AddFloat("height", pageFormat[i].height);
|
message->AddFloat("height", pageFormat[i].height);
|
||||||
BMenuItem* item = new BMenuItem(pageFormat[i].label, message);
|
BMenuItem* item = new BMenuItem(pageFormat[i].label, message);
|
||||||
m->AddItem(item);
|
pageSizePopUpMenu->AddItem(item);
|
||||||
|
|
||||||
if (label.Compare(pageFormat[i].label) == 0)
|
if (label.Compare(pageFormat[i].label) == 0)
|
||||||
item->SetMarked(true);
|
item->SetMarked(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
m = new BPopUpMenu("Orientation");
|
BPopUpMenu* orientationPopUpMenu = new BPopUpMenu("Orientation");
|
||||||
m->SetRadioMode(true);
|
orientationPopUpMenu->SetRadioMode(true);
|
||||||
|
|
||||||
bounds.OffsetBy(0.0, fPageSizeMenu->Bounds().Height() + 10.0);
|
fOrientationMenu = new BMenuField("orientation", "Orientation:",
|
||||||
fOrientationMenu = new BMenuField(bounds, "orientation", "Orientation:", m);
|
orientationPopUpMenu);
|
||||||
panel->AddChild(fOrientationMenu);
|
|
||||||
fOrientationMenu->ResizeToPreferred();
|
|
||||||
fOrientationMenu->SetDivider(divider);
|
|
||||||
fOrientationMenu->Menu()->SetLabelFromMarked(true);
|
fOrientationMenu->Menu()->SetLabelFromMarked(true);
|
||||||
|
|
||||||
for (int32 i = 0; orientation[i].label != NULL; i++) {
|
for (int32 i = 0; orientation[i].label != NULL; i++) {
|
||||||
BMessage* message = new BMessage(ORIENTATION_CHANGED);
|
BMessage* message = new BMessage(ORIENTATION_CHANGED);
|
||||||
message->AddInt32("orientation", orientation[i].orientation);
|
message->AddInt32("orientation", orientation[i].orientation);
|
||||||
BMenuItem* item = new BMenuItem(orientation[i].label, message);
|
BMenuItem* item = new BMenuItem(orientation[i].label, message);
|
||||||
m->AddItem(item);
|
orientationPopUpMenu->AddItem(item);
|
||||||
|
|
||||||
if (fCurrentOrientation == orientation[i].orientation)
|
if (fCurrentOrientation == orientation[i].orientation)
|
||||||
item->SetMarked(true);
|
item->SetMarked(true);
|
||||||
@ -196,13 +184,8 @@ PageSetupWindow::PageSetupWindow(BMessage *msg, const char *printerName)
|
|||||||
else
|
else
|
||||||
scale = "100";
|
scale = "100";
|
||||||
|
|
||||||
bounds.OffsetBy(0.0, fOrientationMenu->Bounds().Height() + 10.0);
|
fScaleControl = new BTextControl("scale", "Scale [%]:",
|
||||||
bounds.right -= 30.0;
|
|
||||||
fScaleControl = new BTextControl(bounds, "scale", "Scale [%]:",
|
|
||||||
scale.String(), NULL);
|
scale.String(), NULL);
|
||||||
panel->AddChild(fScaleControl);
|
|
||||||
fScaleControl->ResizeToPreferred();
|
|
||||||
fScaleControl->SetDivider(divider);
|
|
||||||
|
|
||||||
for (uint32 i = 0; i < '0'; i++)
|
for (uint32 i = 0; i < '0'; i++)
|
||||||
fScaleControl->TextView()->DisallowChar(i);
|
fScaleControl->TextView()->DisallowChar(i);
|
||||||
@ -212,32 +195,44 @@ PageSetupWindow::PageSetupWindow(BMessage *msg, const char *printerName)
|
|||||||
|
|
||||||
fScaleControl->TextView()->SetMaxBytes(3);
|
fScaleControl->TextView()->SetMaxBytes(3);
|
||||||
|
|
||||||
bounds = Bounds();
|
BBox *separator = new BBox("separator");
|
||||||
bounds.InsetBy(5.0, 0.0);
|
separator->SetExplicitMaxSize(BSize(B_SIZE_UNLIMITED, 1));
|
||||||
bounds.top =
|
|
||||||
MAX(fScaleControl->Frame().bottom, fMarginView->Frame().bottom) + 10.0;
|
|
||||||
BBox *line = new BBox(BRect(bounds.left, bounds.top, bounds.right,
|
|
||||||
bounds.top + 1.0), NULL, B_FOLLOW_LEFT_RIGHT);
|
|
||||||
panel->AddChild(line);
|
|
||||||
|
|
||||||
bounds.InsetBy(5.0, 0.0);
|
BButton *cancel = new BButton("cancel", "Cancel", new BMessage(CANCEL_MSG));
|
||||||
bounds.OffsetBy(0.0, 11.0);
|
|
||||||
BButton *cancel = new BButton(bounds, NULL, "Cancel", new BMessage(CANCEL_MSG));
|
|
||||||
panel->AddChild(cancel);
|
|
||||||
cancel->ResizeToPreferred();
|
|
||||||
|
|
||||||
BButton *ok = new BButton(bounds, NULL, "OK", new BMessage(OK_MSG));
|
|
||||||
panel->AddChild(ok, cancel);
|
|
||||||
ok->ResizeToPreferred();
|
|
||||||
|
|
||||||
bounds.right = fScaleControl->Frame().right;
|
|
||||||
ok->MoveTo(bounds.right - ok->Bounds().Width(), ok->Frame().top);
|
|
||||||
|
|
||||||
bounds = ok->Frame();
|
|
||||||
cancel->MoveTo(bounds.left - cancel->Bounds().Width() - 10.0, bounds.top);
|
|
||||||
|
|
||||||
|
BButton *ok = new BButton("ok", "OK", new BMessage(OK_MSG));
|
||||||
ok->MakeDefault(true);
|
ok->MakeDefault(true);
|
||||||
ResizeTo(bounds.right + 10.0, bounds.bottom + 10.0);
|
|
||||||
|
BGridView* settings = new BGridView();
|
||||||
|
BGridLayout* settingsLayout = settings->GridLayout();
|
||||||
|
settingsLayout->AddItem(fPageSizeMenu->CreateLabelLayoutItem(), 0, 0);
|
||||||
|
settingsLayout->AddItem(fPageSizeMenu->CreateMenuBarLayoutItem(), 1, 0);
|
||||||
|
settingsLayout->AddItem(fOrientationMenu->CreateLabelLayoutItem(), 0, 1);
|
||||||
|
settingsLayout->AddItem(fOrientationMenu->CreateMenuBarLayoutItem(), 1, 1);
|
||||||
|
settingsLayout->AddItem(fScaleControl->CreateLabelLayoutItem(), 0, 2);
|
||||||
|
settingsLayout->AddItem(fScaleControl->CreateTextViewLayoutItem(), 1, 2);
|
||||||
|
settingsLayout->SetSpacing(0, 0);
|
||||||
|
|
||||||
|
SetLayout(new BGroupLayout(B_VERTICAL));
|
||||||
|
AddChild(BGroupLayoutBuilder(B_VERTICAL, 0)
|
||||||
|
.AddGroup(B_HORIZONTAL, 5, 1)
|
||||||
|
.AddGroup(B_VERTICAL, 0, 1.0f)
|
||||||
|
.Add(fMarginView)
|
||||||
|
.AddGlue()
|
||||||
|
.End()
|
||||||
|
.AddGroup(B_VERTICAL, 0, 1.0f)
|
||||||
|
.Add(settings)
|
||||||
|
.AddGlue()
|
||||||
|
.End()
|
||||||
|
.End()
|
||||||
|
.Add(separator)
|
||||||
|
.AddGroup(B_HORIZONTAL, 10, 1.0f)
|
||||||
|
.AddGlue()
|
||||||
|
.Add(cancel)
|
||||||
|
.Add(ok)
|
||||||
|
.End()
|
||||||
|
.SetInsets(10, 10, 10, 10)
|
||||||
|
);
|
||||||
|
|
||||||
BRect winFrame(Frame());
|
BRect winFrame(Frame());
|
||||||
BRect screenFrame(BScreen().Frame());
|
BRect screenFrame(BScreen().Frame());
|
||||||
|
@ -14,9 +14,9 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
|
|
||||||
JSDSlider::JSDSlider(BRect frame, const char* name, const char *label,
|
JSDSlider::JSDSlider(const char* name, const char* label,
|
||||||
BMessage *msg, int32 min, int32 max, thumb_style t)
|
BMessage* msg, int32 min, int32 max)
|
||||||
: BSlider(frame, name, label, msg, min, max, t)
|
: BSlider(name, label, msg, min, max, B_HORIZONTAL)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -26,10 +26,7 @@ JSDSlider::~JSDSlider()
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#ifdef __HAIKU__
|
const char*
|
||||||
const
|
|
||||||
#endif
|
|
||||||
char*
|
|
||||||
JSDSlider::UpdateText() const
|
JSDSlider::UpdateText() const
|
||||||
{
|
{
|
||||||
// When the slider's Draw method is called, this method will also be called.
|
// When the slider's Draw method is called, this method will also be called.
|
||||||
@ -49,9 +46,5 @@ JSDSlider::UpdateText() const
|
|||||||
}
|
}
|
||||||
|
|
||||||
fResult.SetTo(string);
|
fResult.SetTo(string);
|
||||||
#ifdef __HAIKU__
|
|
||||||
return fResult.String();
|
return fResult.String();
|
||||||
#else
|
|
||||||
return const_cast<char*>(fResult.String());
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
@ -17,6 +17,9 @@
|
|||||||
#include <Box.h>
|
#include <Box.h>
|
||||||
#include <Button.h>
|
#include <Button.h>
|
||||||
#include <CheckBox.h>
|
#include <CheckBox.h>
|
||||||
|
#include <GridView.h>
|
||||||
|
#include <GroupLayout.h>
|
||||||
|
#include <GroupLayoutBuilder.h>
|
||||||
#include <Looper.h>
|
#include <Looper.h>
|
||||||
#include <MessageFilter.h>
|
#include <MessageFilter.h>
|
||||||
#include <MenuField.h>
|
#include <MenuField.h>
|
||||||
@ -48,288 +51,6 @@ using namespace std;
|
|||||||
#define std
|
#define std
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
//#define PRINT_COPIES 100
|
|
||||||
|
|
||||||
#define QUALITY_H 10
|
|
||||||
#define QUALITY_V 10
|
|
||||||
#define QUALITY_WIDTH 180
|
|
||||||
|
|
||||||
#define BPP_H 10
|
|
||||||
#define BPP_V 15
|
|
||||||
#define BPP_WIDTH 120
|
|
||||||
#define BPP_HEIGHT 16
|
|
||||||
|
|
||||||
#define DITHER_H BPP_H
|
|
||||||
#define DITHER_V BPP_V + BPP_HEIGHT + 10
|
|
||||||
#define DITHER_WIDTH BPP_WIDTH
|
|
||||||
#define DITHER_HEIGHT BPP_HEIGHT
|
|
||||||
|
|
||||||
#define GAMMA_H BPP_H
|
|
||||||
#define GAMMA_V DITHER_V + DITHER_HEIGHT + 10
|
|
||||||
#define GAMMA_WIDTH QUALITY_WIDTH - 20
|
|
||||||
#define GAMMA_HEIGHT 55 // BPP_HEIGHT
|
|
||||||
|
|
||||||
#define INK_DENSITY_H BPP_H
|
|
||||||
#define INK_DENSITY_V GAMMA_V + GAMMA_HEIGHT + 5
|
|
||||||
#define INK_DENSITY_WIDTH GAMMA_WIDTH
|
|
||||||
#define INK_DENSITY_HEIGHT 55 // BPP_HEIGHT
|
|
||||||
|
|
||||||
#define HALFTONE_H INK_DENSITY_H
|
|
||||||
#define HALFTONE_V INK_DENSITY_V + INK_DENSITY_HEIGHT + 5
|
|
||||||
#define HALFTONE_WIDTH 160
|
|
||||||
#define HALFTONE_HEIGHT 4*11
|
|
||||||
|
|
||||||
#define QUALITY_HEIGHT HALFTONE_V + HALFTONE_HEIGHT + 5
|
|
||||||
|
|
||||||
#define PAGERABGE_H QUALITY_H
|
|
||||||
#define PAGERABGE_V QUALITY_V + QUALITY_HEIGHT + 5
|
|
||||||
#define PAGERABGE_WIDTH QUALITY_WIDTH
|
|
||||||
#define PAGERABGE_HEIGHT 70
|
|
||||||
|
|
||||||
#define ALL_H 10
|
|
||||||
#define ALL_V 20
|
|
||||||
#define ALL_WIDTH 36
|
|
||||||
#define ALL_HEIGHT 16
|
|
||||||
|
|
||||||
#define SELECTION_H ALL_H
|
|
||||||
#define SELECTION_V ALL_V + ALL_HEIGHT + 4
|
|
||||||
#define SELECTION_WIDTH 16
|
|
||||||
#define SELECTION_HEIGHT 16
|
|
||||||
|
|
||||||
#define FROM_H (SELECTION_H + SELECTION_WIDTH + 1)
|
|
||||||
#define FROM_V ALL_V + 19
|
|
||||||
#define FROM_WIDTH 73
|
|
||||||
#define FROM_HEIGHT 16
|
|
||||||
|
|
||||||
#define TO_H (FROM_H + FROM_WIDTH + 7)
|
|
||||||
#define TO_V FROM_V
|
|
||||||
#define TO_WIDTH 59
|
|
||||||
#define TO_HEIGHT FROM_HEIGHT
|
|
||||||
|
|
||||||
#define PRINT_WIDTH 365
|
|
||||||
#define PRINT_HEIGHT QUALITY_HEIGHT + PAGERABGE_HEIGHT + 60
|
|
||||||
|
|
||||||
#define PAPERFEED_H QUALITY_H + QUALITY_WIDTH + 10
|
|
||||||
#define PAPERFEED_V QUALITY_V + 5
|
|
||||||
#define PAPERFEED_WIDTH 160
|
|
||||||
#define PAPERFEED_HEIGHT 16
|
|
||||||
|
|
||||||
#define NUP_H PAPERFEED_H
|
|
||||||
#define NUP_V PAPERFEED_V + PAPERFEED_HEIGHT + 7
|
|
||||||
#define NUP_WIDTH PAPERFEED_WIDTH
|
|
||||||
#define NUP_HEIGHT 16
|
|
||||||
#define MENU_HEIGHT 16
|
|
||||||
|
|
||||||
#define COPIES_H PAPERFEED_H
|
|
||||||
#define COPIES_V NUP_V + NUP_HEIGHT + 10
|
|
||||||
#define COPIES_WIDTH 140
|
|
||||||
#define COPIES_HEIGHT 16
|
|
||||||
|
|
||||||
#define DUPLEX_H PAPERFEED_H
|
|
||||||
#define DUPLEX_V COPIES_V + COPIES_HEIGHT + 7
|
|
||||||
#define DUPLEX_WIDTH PAPERFEED_WIDTH
|
|
||||||
#define DUPLEX_HEIGHT 16
|
|
||||||
|
|
||||||
#define COLLATE_H PAPERFEED_H
|
|
||||||
#define COLLATE_V DUPLEX_V + DUPLEX_HEIGHT + 5
|
|
||||||
#define COLLATE_WIDTH PAPERFEED_WIDTH
|
|
||||||
#define COLLATE_HEIGHT 16
|
|
||||||
|
|
||||||
#define REVERSE_H PAPERFEED_H
|
|
||||||
#define REVERSE_V COLLATE_V + COLLATE_HEIGHT + 5
|
|
||||||
#define REVERSE_WIDTH PAPERFEED_WIDTH
|
|
||||||
#define REVERSE_HEIGHT 16
|
|
||||||
|
|
||||||
#define PAGES_H PAPERFEED_H
|
|
||||||
#define PAGES_V REVERSE_V + REVERSE_HEIGHT + 5
|
|
||||||
#define PAGES_WIDTH PAPERFEED_WIDTH
|
|
||||||
#define PAGES_HEIGHT 40
|
|
||||||
|
|
||||||
#define PAGE_SELECTION_H PAPERFEED_H
|
|
||||||
#define PAGE_SELECTION_V PAGES_V + PAGES_HEIGHT + 5
|
|
||||||
#define PAGE_SELECTION_WIDTH PAPERFEED_WIDTH
|
|
||||||
#define PAGE_SELECTION_HEIGHT 3 * 16 + 30
|
|
||||||
|
|
||||||
#define PS_ALL_PAGES_H 10
|
|
||||||
#define PS_ALL_PAGES_V 20
|
|
||||||
#define PS_ALL_PAGES_WIDTH PAGE_SELECTION_WIDTH - 20
|
|
||||||
#define PS_ALL_PAGES_HEIGHT 16
|
|
||||||
|
|
||||||
#define PS_ODD_PAGES_H PS_ALL_PAGES_H
|
|
||||||
#define PS_ODD_PAGES_V PS_ALL_PAGES_V + PS_ALL_PAGES_HEIGHT
|
|
||||||
#define PS_ODD_PAGES_WIDTH PS_ALL_PAGES_WIDTH
|
|
||||||
#define PS_ODD_PAGES_HEIGHT PS_ALL_PAGES_HEIGHT
|
|
||||||
|
|
||||||
#define PS_EVEN_PAGES_H PS_ALL_PAGES_H
|
|
||||||
#define PS_EVEN_PAGES_V PS_ODD_PAGES_V + PS_ODD_PAGES_HEIGHT
|
|
||||||
#define PS_EVEN_PAGES_WIDTH PS_ALL_PAGES_WIDTH
|
|
||||||
#define PS_EVEN_PAGES_HEIGHT PS_ALL_PAGES_HEIGHT
|
|
||||||
|
|
||||||
#define PRINT_BUTTON_WIDTH 70
|
|
||||||
#define PRINT_BUTTON_HEIGHT 20
|
|
||||||
|
|
||||||
#define PRINT_LINE_V (PRINT_HEIGHT - PRINT_BUTTON_HEIGHT - 23)
|
|
||||||
|
|
||||||
#define PRINT_OK_BUTTON_H (PRINT_WIDTH - PRINT_BUTTON_WIDTH - 10)
|
|
||||||
#define PRINT_OK_BUTTON_V (PRINT_HEIGHT - PRINT_BUTTON_HEIGHT - 11)
|
|
||||||
|
|
||||||
#define PREVIEW_H (PRINT_OK_BUTTON_H - PRINT_BUTTON_WIDTH - 12)
|
|
||||||
#define PREVIEW_V (PRINT_OK_BUTTON_V)
|
|
||||||
|
|
||||||
#define PRINT_CANCEL_BUTTON_H (PREVIEW_H - PRINT_BUTTON_WIDTH - 12)
|
|
||||||
#define PRINT_CANCEL_BUTTON_V PRINT_OK_BUTTON_V
|
|
||||||
|
|
||||||
const BRect quality_rect(
|
|
||||||
QUALITY_H,
|
|
||||||
QUALITY_V,
|
|
||||||
QUALITY_H + QUALITY_WIDTH,
|
|
||||||
QUALITY_V + QUALITY_HEIGHT);
|
|
||||||
|
|
||||||
BRect bpp_rect(
|
|
||||||
BPP_H,
|
|
||||||
BPP_V,
|
|
||||||
BPP_H + BPP_WIDTH,
|
|
||||||
BPP_V + BPP_HEIGHT);
|
|
||||||
|
|
||||||
BRect dither_rect(
|
|
||||||
DITHER_H,
|
|
||||||
DITHER_V,
|
|
||||||
DITHER_H + DITHER_WIDTH,
|
|
||||||
DITHER_V + DITHER_HEIGHT);
|
|
||||||
|
|
||||||
const BRect ink_density_rect(
|
|
||||||
INK_DENSITY_H,
|
|
||||||
INK_DENSITY_V,
|
|
||||||
INK_DENSITY_H + INK_DENSITY_WIDTH,
|
|
||||||
INK_DENSITY_V + INK_DENSITY_HEIGHT);
|
|
||||||
|
|
||||||
const BRect halftone_rect(
|
|
||||||
HALFTONE_H,
|
|
||||||
HALFTONE_V,
|
|
||||||
HALFTONE_H + HALFTONE_WIDTH,
|
|
||||||
HALFTONE_V + HALFTONE_HEIGHT);
|
|
||||||
|
|
||||||
const BRect gamma_rect(
|
|
||||||
GAMMA_H,
|
|
||||||
GAMMA_V,
|
|
||||||
GAMMA_H + GAMMA_WIDTH,
|
|
||||||
GAMMA_V + GAMMA_HEIGHT);
|
|
||||||
|
|
||||||
const BRect pagerange_rect(
|
|
||||||
PAGERABGE_H,
|
|
||||||
PAGERABGE_V,
|
|
||||||
PAGERABGE_H + PAGERABGE_WIDTH,
|
|
||||||
PAGERABGE_V + PAGERABGE_HEIGHT);
|
|
||||||
|
|
||||||
const BRect all_button_rect(
|
|
||||||
ALL_H,
|
|
||||||
ALL_V,
|
|
||||||
ALL_H + ALL_WIDTH,
|
|
||||||
ALL_V + ALL_HEIGHT);
|
|
||||||
|
|
||||||
const BRect selection_rect(
|
|
||||||
SELECTION_H,
|
|
||||||
SELECTION_V,
|
|
||||||
SELECTION_H + SELECTION_WIDTH,
|
|
||||||
SELECTION_V + SELECTION_HEIGHT);
|
|
||||||
|
|
||||||
const BRect from_rect(
|
|
||||||
FROM_H,
|
|
||||||
FROM_V,
|
|
||||||
FROM_H + FROM_WIDTH,
|
|
||||||
FROM_V + FROM_HEIGHT);
|
|
||||||
|
|
||||||
const BRect to_rect(
|
|
||||||
TO_H,
|
|
||||||
TO_V,
|
|
||||||
TO_H + TO_WIDTH,
|
|
||||||
TO_V + TO_HEIGHT);
|
|
||||||
|
|
||||||
const BRect paperfeed_rect(
|
|
||||||
PAPERFEED_H,
|
|
||||||
PAPERFEED_V,
|
|
||||||
PAPERFEED_H + PAPERFEED_WIDTH,
|
|
||||||
PAPERFEED_V + PAPERFEED_HEIGHT);
|
|
||||||
|
|
||||||
BRect nup_rect(
|
|
||||||
NUP_H,
|
|
||||||
NUP_V,
|
|
||||||
NUP_H + NUP_WIDTH,
|
|
||||||
NUP_V + NUP_HEIGHT);
|
|
||||||
|
|
||||||
const BRect copies_rect(
|
|
||||||
COPIES_H,
|
|
||||||
COPIES_V,
|
|
||||||
COPIES_H + COPIES_WIDTH,
|
|
||||||
COPIES_V + COPIES_HEIGHT);
|
|
||||||
|
|
||||||
const BRect duplex_rect(
|
|
||||||
DUPLEX_H,
|
|
||||||
DUPLEX_V,
|
|
||||||
DUPLEX_H + DUPLEX_WIDTH,
|
|
||||||
DUPLEX_V + DUPLEX_HEIGHT);
|
|
||||||
|
|
||||||
const BRect collate_rect(
|
|
||||||
COLLATE_H,
|
|
||||||
COLLATE_V,
|
|
||||||
COLLATE_H + COLLATE_WIDTH,
|
|
||||||
COLLATE_V + COLLATE_HEIGHT);
|
|
||||||
|
|
||||||
const BRect reverse_rect(
|
|
||||||
REVERSE_H,
|
|
||||||
REVERSE_V,
|
|
||||||
REVERSE_H + REVERSE_WIDTH,
|
|
||||||
REVERSE_V + REVERSE_HEIGHT);
|
|
||||||
|
|
||||||
const BRect pages_rect(
|
|
||||||
PAGES_H,
|
|
||||||
PAGES_V,
|
|
||||||
PAGES_H + PAGES_WIDTH,
|
|
||||||
PAGES_V + PAGES_HEIGHT);
|
|
||||||
|
|
||||||
const BRect page_selection_rect(
|
|
||||||
PAGE_SELECTION_H,
|
|
||||||
PAGE_SELECTION_V,
|
|
||||||
PAGE_SELECTION_H + PAGE_SELECTION_WIDTH,
|
|
||||||
PAGE_SELECTION_V + PAGE_SELECTION_HEIGHT);
|
|
||||||
|
|
||||||
const BRect page_selection_all_pages_rect(
|
|
||||||
PS_ALL_PAGES_H,
|
|
||||||
PS_ALL_PAGES_V,
|
|
||||||
PS_ALL_PAGES_H + PS_ALL_PAGES_WIDTH,
|
|
||||||
PS_ALL_PAGES_V + PS_ALL_PAGES_HEIGHT);
|
|
||||||
|
|
||||||
const BRect page_selection_odd_pages_rect(
|
|
||||||
PS_ODD_PAGES_H,
|
|
||||||
PS_ODD_PAGES_V,
|
|
||||||
PS_ODD_PAGES_H + PS_ODD_PAGES_WIDTH,
|
|
||||||
PS_ODD_PAGES_V + PS_ODD_PAGES_HEIGHT);
|
|
||||||
|
|
||||||
const BRect page_selection_even_pages_rect(
|
|
||||||
PS_EVEN_PAGES_H,
|
|
||||||
PS_EVEN_PAGES_V,
|
|
||||||
PS_EVEN_PAGES_H + PS_EVEN_PAGES_WIDTH,
|
|
||||||
PS_EVEN_PAGES_V + PS_EVEN_PAGES_HEIGHT);
|
|
||||||
|
|
||||||
const BRect ok_rect(
|
|
||||||
PRINT_OK_BUTTON_H,
|
|
||||||
PRINT_OK_BUTTON_V,
|
|
||||||
PRINT_OK_BUTTON_H + PRINT_BUTTON_WIDTH,
|
|
||||||
PRINT_OK_BUTTON_V + PRINT_BUTTON_HEIGHT);
|
|
||||||
|
|
||||||
const BRect cancel_rect(
|
|
||||||
PRINT_CANCEL_BUTTON_H,
|
|
||||||
PRINT_CANCEL_BUTTON_V,
|
|
||||||
PRINT_CANCEL_BUTTON_H + PRINT_BUTTON_WIDTH,
|
|
||||||
PRINT_CANCEL_BUTTON_V + PRINT_BUTTON_HEIGHT);
|
|
||||||
|
|
||||||
const BRect preview_rect(
|
|
||||||
PREVIEW_H,
|
|
||||||
PREVIEW_V,
|
|
||||||
PREVIEW_H + PRINT_BUTTON_WIDTH,
|
|
||||||
PREVIEW_V + PRINT_BUTTON_HEIGHT);
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
struct SurfaceCap : public BaseCap {
|
struct SurfaceCap : public BaseCap {
|
||||||
color_space surface_type;
|
color_space surface_type;
|
||||||
@ -404,21 +125,24 @@ enum {
|
|||||||
kMsgDuplexChanged,
|
kMsgDuplexChanged,
|
||||||
};
|
};
|
||||||
|
|
||||||
JobSetupView::JobSetupView(BRect frame, JobData *job_data, PrinterData *printer_data, const PrinterCap *printer_cap)
|
JobSetupView::JobSetupView(JobData *job_data, PrinterData *printer_data,
|
||||||
: BView(frame, "", B_FOLLOW_ALL, B_WILL_DRAW), fJobData(job_data), fPrinterData(printer_data), fPrinterCap(printer_cap)
|
const PrinterCap *printer_cap)
|
||||||
|
: BView("jobSetup", B_WILL_DRAW)
|
||||||
|
, fJobData(job_data)
|
||||||
|
, fPrinterData(printer_data)
|
||||||
|
, fPrinterCap(printer_cap)
|
||||||
{
|
{
|
||||||
SetViewColor(ui_color(B_PANEL_BACKGROUND_COLOR));
|
SetViewColor(ui_color(B_PANEL_BACKGROUND_COLOR));
|
||||||
}
|
}
|
||||||
|
|
||||||
BRadioButton*
|
BRadioButton*
|
||||||
JobSetupView::AddPageSelectionItem(BView* parent, BRect rect, const char* name, const char* label,
|
JobSetupView::CreatePageSelectionItem(const char* name, const char* label,
|
||||||
JobData::PageSelection pageSelection)
|
JobData::PageSelection pageSelection)
|
||||||
{
|
{
|
||||||
BRadioButton* button = new BRadioButton(rect, name, label, NULL);
|
BRadioButton* button = new BRadioButton(name, label, NULL);
|
||||||
if (fJobData->getPageSelection() == pageSelection) {
|
if (fJobData->getPageSelection() == pageSelection) {
|
||||||
button->SetValue(B_CONTROL_ON);
|
button->SetValue(B_CONTROL_ON);
|
||||||
}
|
}
|
||||||
parent->AddChild(button);
|
|
||||||
return button;
|
return button;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -438,54 +162,22 @@ JobSetupView::AllowOnlyDigits(BTextView* textView, int maxDigits)
|
|||||||
void
|
void
|
||||||
JobSetupView::AttachedToWindow()
|
JobSetupView::AttachedToWindow()
|
||||||
{
|
{
|
||||||
BBox *box;
|
// quality
|
||||||
BMenuItem *item = NULL;
|
BBox* qualityBox = new BBox("quality");
|
||||||
BMenuField *menufield;
|
qualityBox->SetLabel("Quality");
|
||||||
BButton *button;
|
|
||||||
float width;
|
|
||||||
bool marked;
|
|
||||||
int count;
|
|
||||||
|
|
||||||
/* quality */
|
// color
|
||||||
|
fColorType = new BPopUpMenu("color");
|
||||||
box = new BBox(quality_rect);
|
|
||||||
AddChild(box);
|
|
||||||
box->SetLabel("Quality");
|
|
||||||
|
|
||||||
/*
|
|
||||||
// always B_RGB32
|
|
||||||
fSurfaceType = new BPopUpMenu("");
|
|
||||||
fSurfaceType->SetRadioMode(true);
|
|
||||||
|
|
||||||
count = sizeof(gSurfaces) / sizeof(gSurfaces[0]);
|
|
||||||
const SurfaceCap **surface_cap = gSurfaces;
|
|
||||||
uint32 support_flags;
|
|
||||||
while (count--) {
|
|
||||||
if (bitmaps_support_space((*surface_cap)->surface_type, &support_flags)) {
|
|
||||||
item = new BMenuItem((*surface_cap)->label.c_str(), NULL);
|
|
||||||
fSurfaceType->AddItem(item);
|
|
||||||
if ((*surface_cap)->surface_type == fJobData->getSurfaceType()) {
|
|
||||||
item->SetMarked(true);
|
|
||||||
marked = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
surface_cap++;
|
|
||||||
}
|
|
||||||
menufield = new BMenuField(bpp_rect, "", "Surface Type", fSurfaceType);
|
|
||||||
box->AddChild(menufield);
|
|
||||||
width = StringWidth("Color") + 10;
|
|
||||||
menufield->SetDivider(width);
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* color */
|
|
||||||
marked = false;
|
|
||||||
fColorType = new BPopUpMenu("");
|
|
||||||
fColorType->SetRadioMode(true);
|
fColorType->SetRadioMode(true);
|
||||||
|
|
||||||
count = fPrinterCap->countCap(PrinterCap::kColor);
|
int count = fPrinterCap->countCap(PrinterCap::kColor);
|
||||||
const ColorCap **color_cap = (const ColorCap **)fPrinterCap->enumCap(PrinterCap::kColor);
|
const ColorCap **color_cap = (const ColorCap **)fPrinterCap->enumCap(
|
||||||
|
PrinterCap::kColor);
|
||||||
|
bool marked = false;
|
||||||
|
BMenuItem* item = NULL;
|
||||||
while (count--) {
|
while (count--) {
|
||||||
item = new BMenuItem((*color_cap)->label.c_str(), new BMessage(kMsgQuality));
|
item = new BMenuItem((*color_cap)->label.c_str(),
|
||||||
|
new BMessage(kMsgQuality));
|
||||||
fColorType->AddItem(item);
|
fColorType->AddItem(item);
|
||||||
if ((*color_cap)->color == fJobData->getColor()) {
|
if ((*color_cap)->color == fJobData->getColor()) {
|
||||||
item->SetMarked(true);
|
item->SetMarked(true);
|
||||||
@ -495,23 +187,21 @@ JobSetupView::AttachedToWindow()
|
|||||||
}
|
}
|
||||||
if (!marked && item)
|
if (!marked && item)
|
||||||
item->SetMarked(true);
|
item->SetMarked(true);
|
||||||
bpp_rect.right = bpp_rect.left + StringWidth("Color:") + fColorType->MaxContentWidth() + 10;
|
|
||||||
menufield = new BMenuField(bpp_rect, "color", "Color:", fColorType);
|
|
||||||
|
|
||||||
box->AddChild(menufield);
|
BMenuField* colorMenuField = new BMenuField("color", "Color:", fColorType);
|
||||||
width = StringWidth("Color:") + 10;
|
|
||||||
menufield->SetDivider(width);
|
|
||||||
fColorType->SetTargetForItems(this);
|
fColorType->SetTargetForItems(this);
|
||||||
|
|
||||||
/* dither type */
|
// dither type
|
||||||
marked = false;
|
|
||||||
fDitherType = new BPopUpMenu("");
|
fDitherType = new BPopUpMenu("");
|
||||||
fDitherType->SetRadioMode(true);
|
fDitherType->SetRadioMode(true);
|
||||||
|
|
||||||
count = sizeof(gDitherTypes) / sizeof(gDitherTypes[0]);
|
count = sizeof(gDitherTypes) / sizeof(gDitherTypes[0]);
|
||||||
const DitherCap **dither_cap = gDitherTypes;
|
const DitherCap **dither_cap = gDitherTypes;
|
||||||
|
marked = false;
|
||||||
|
item = NULL;
|
||||||
while (count--) {
|
while (count--) {
|
||||||
item = new BMenuItem((*dither_cap)->label.c_str(), new BMessage(kMsgQuality));
|
item = new BMenuItem((*dither_cap)->label.c_str(),
|
||||||
|
new BMessage(kMsgQuality));
|
||||||
fDitherType->AddItem(item);
|
fDitherType->AddItem(item);
|
||||||
if ((*dither_cap)->dither_type == fJobData->getDitherType()) {
|
if ((*dither_cap)->dither_type == fJobData->getDitherType()) {
|
||||||
item->SetMarked(true);
|
item->SetMarked(true);
|
||||||
@ -521,68 +211,60 @@ JobSetupView::AttachedToWindow()
|
|||||||
}
|
}
|
||||||
if (!marked && item)
|
if (!marked && item)
|
||||||
item->SetMarked(true);
|
item->SetMarked(true);
|
||||||
dither_rect.right = dither_rect.left + StringWidth("Dot Pattern:") + fDitherType->MaxContentWidth() + 20;
|
BMenuField* ditherMenuField = new BMenuField("dithering", "Dot Pattern:",
|
||||||
menufield = new BMenuField(dither_rect, "dithering", "Dot Pattern:", fDitherType);
|
fDitherType);
|
||||||
|
|
||||||
box->AddChild(menufield);
|
|
||||||
width = StringWidth("Dot Pattern:") + 10;
|
|
||||||
menufield->SetDivider(width);
|
|
||||||
fDitherType->SetTargetForItems(this);
|
fDitherType->SetTargetForItems(this);
|
||||||
|
|
||||||
/* halftone preview view */
|
// halftone preview view
|
||||||
BRect rect(halftone_rect);
|
BBox* halftoneBox = new BBox("halftoneBox");
|
||||||
BBox* halftoneBorder = new BBox(rect.InsetByCopy(-1, -1));
|
halftoneBox->SetBorder(B_PLAIN_BORDER);
|
||||||
box->AddChild(halftoneBorder);
|
|
||||||
halftoneBorder->SetBorder(B_PLAIN_BORDER);
|
|
||||||
|
|
||||||
fHalftone = new HalftoneView(rect.OffsetToCopy(1, 1), "halftone", B_FOLLOW_ALL, B_WILL_DRAW);
|
// TODO make layout compatible
|
||||||
halftoneBorder->AddChild(fHalftone);
|
BSize size(240, 14 * 4);
|
||||||
fHalftone->preview(fJobData->getGamma(), fJobData->getInkDensity(), fJobData->getDitherType(), fJobData->getColor() != JobData::kMonochrome);
|
BRect rect(0, 0, size.width, size.height);
|
||||||
|
fHalftone = new HalftoneView(rect, "halftone",
|
||||||
|
B_FOLLOW_ALL, B_WILL_DRAW);
|
||||||
|
fHalftone->SetExplicitMinSize(size);
|
||||||
|
fHalftone->SetExplicitMaxSize(size);
|
||||||
|
|
||||||
/* gamma */
|
// gamma
|
||||||
fGamma = new JSDSlider(gamma_rect, "gamma", "Gamma", new BMessage(kMsgQuality), -300, 300, B_BLOCK_THUMB);
|
fGamma = new JSDSlider("gamma", "Gamma", new BMessage(kMsgQuality),
|
||||||
|
-300, 300);
|
||||||
|
|
||||||
fGamma->SetLimitLabels("Lighter", "Darker");
|
fGamma->SetLimitLabels("Lighter", "Darker");
|
||||||
fGamma->SetValue((int32)(100 * log(fJobData->getGamma()) / log(2.0)));
|
fGamma->SetValue((int32)(100 * log(fJobData->getGamma()) / log(2.0)));
|
||||||
fGamma->SetHashMarks(B_HASH_MARKS_BOTH);
|
fGamma->SetHashMarks(B_HASH_MARKS_BOTH);
|
||||||
fGamma->SetHashMarkCount(7);
|
fGamma->SetHashMarkCount(7);
|
||||||
box->AddChild(fGamma);
|
|
||||||
fGamma->SetModificationMessage(new BMessage(kMsgQuality));
|
fGamma->SetModificationMessage(new BMessage(kMsgQuality));
|
||||||
fGamma->SetTarget(this);
|
fGamma->SetTarget(this);
|
||||||
|
|
||||||
/* ink density */
|
// ink density
|
||||||
fInkDensity = new JSDSlider(ink_density_rect, "inkDensity", "Ink Usage", new BMessage(kMsgQuality), 0, 127, B_BLOCK_THUMB);
|
fInkDensity = new JSDSlider("inkDensity", "Ink Usage",
|
||||||
|
new BMessage(kMsgQuality), 0, 127);
|
||||||
|
|
||||||
fInkDensity->SetLimitLabels("Min", "Max");
|
fInkDensity->SetLimitLabels("Min", "Max");
|
||||||
fInkDensity->SetValue((int32)fJobData->getInkDensity());
|
fInkDensity->SetValue((int32)fJobData->getInkDensity());
|
||||||
fInkDensity->SetHashMarks(B_HASH_MARKS_BOTH);
|
fInkDensity->SetHashMarks(B_HASH_MARKS_BOTH);
|
||||||
fInkDensity->SetHashMarkCount(10);
|
fInkDensity->SetHashMarkCount(10);
|
||||||
box->AddChild(fInkDensity);
|
|
||||||
fInkDensity->SetModificationMessage(new BMessage(kMsgQuality));
|
fInkDensity->SetModificationMessage(new BMessage(kMsgQuality));
|
||||||
fInkDensity->SetTarget(this);
|
fInkDensity->SetTarget(this);
|
||||||
|
|
||||||
/* page range */
|
// page range
|
||||||
|
|
||||||
box = new BBox(pagerange_rect);
|
BBox* pageRangeBox = new BBox("pageRange");
|
||||||
AddChild(box);
|
pageRangeBox->SetLabel("Page Range");
|
||||||
box->SetLabel("Page Range");
|
|
||||||
|
|
||||||
fAll = new BRadioButton(all_button_rect, "all", "All", new BMessage(kMsgRangeAll));
|
fAll = new BRadioButton("all", "Print all Pages", new BMessage(kMsgRangeAll));
|
||||||
box->AddChild(fAll);
|
|
||||||
|
|
||||||
BRadioButton *from = new BRadioButton(selection_rect, "selection", "", new BMessage(kMsgRangeSelection));
|
BRadioButton *range = new BRadioButton("selection", "Print selected Pages:",
|
||||||
box->AddChild(from);
|
new BMessage(kMsgRangeSelection));
|
||||||
|
|
||||||
fFromPage = new BTextControl(from_rect, "from", "From", "", NULL);
|
fFromPage = new BTextControl("from", "From:", "", NULL);
|
||||||
box->AddChild(fFromPage);
|
|
||||||
fFromPage->SetAlignment(B_ALIGN_LEFT, B_ALIGN_RIGHT);
|
fFromPage->SetAlignment(B_ALIGN_LEFT, B_ALIGN_RIGHT);
|
||||||
fFromPage->SetDivider(StringWidth("From") + 7);
|
|
||||||
AllowOnlyDigits(fFromPage->TextView(), 6);
|
AllowOnlyDigits(fFromPage->TextView(), 6);
|
||||||
|
|
||||||
fToPage = new BTextControl(to_rect, "to", "To", "", NULL);
|
fToPage = new BTextControl("to", "To:", "", NULL);
|
||||||
box->AddChild(fToPage);
|
|
||||||
fToPage->SetAlignment(B_ALIGN_LEFT, B_ALIGN_RIGHT);
|
fToPage->SetAlignment(B_ALIGN_LEFT, B_ALIGN_RIGHT);
|
||||||
fToPage->SetDivider(StringWidth("To") + 7);
|
|
||||||
AllowOnlyDigits(fToPage->TextView(), 6);
|
AllowOnlyDigits(fToPage->TextView(), 6);
|
||||||
|
|
||||||
int first_page = fJobData->getFirstPage();
|
int first_page = fJobData->getFirstPage();
|
||||||
@ -591,7 +273,7 @@ JobSetupView::AttachedToWindow()
|
|||||||
if (first_page <= 1 && last_page <= 0) {
|
if (first_page <= 1 && last_page <= 0) {
|
||||||
fAll->SetValue(B_CONTROL_ON);
|
fAll->SetValue(B_CONTROL_ON);
|
||||||
} else {
|
} else {
|
||||||
from->SetValue(B_CONTROL_ON);
|
range->SetValue(B_CONTROL_ON);
|
||||||
if (first_page < 1)
|
if (first_page < 1)
|
||||||
first_page = 1;
|
first_page = 1;
|
||||||
if (first_page > last_page)
|
if (first_page > last_page)
|
||||||
@ -607,15 +289,16 @@ JobSetupView::AttachedToWindow()
|
|||||||
}
|
}
|
||||||
|
|
||||||
fAll->SetTarget(this);
|
fAll->SetTarget(this);
|
||||||
from->SetTarget(this);
|
range->SetTarget(this);
|
||||||
|
|
||||||
/* paper source */
|
// paper source
|
||||||
|
|
||||||
marked = false;
|
|
||||||
fPaperFeed = new BPopUpMenu("");
|
fPaperFeed = new BPopUpMenu("");
|
||||||
fPaperFeed->SetRadioMode(true);
|
fPaperFeed->SetRadioMode(true);
|
||||||
count = fPrinterCap->countCap(PrinterCap::kPaperSource);
|
count = fPrinterCap->countCap(PrinterCap::kPaperSource);
|
||||||
const PaperSourceCap **paper_source_cap = (const PaperSourceCap **)fPrinterCap->enumCap(PrinterCap::kPaperSource);
|
const PaperSourceCap **paper_source_cap =
|
||||||
|
(const PaperSourceCap **)fPrinterCap->enumCap(PrinterCap::kPaperSource);
|
||||||
|
marked = false;
|
||||||
|
item = NULL;
|
||||||
while (count--) {
|
while (count--) {
|
||||||
item = new BMenuItem((*paper_source_cap)->label.c_str(), NULL);
|
item = new BMenuItem((*paper_source_cap)->label.c_str(), NULL);
|
||||||
fPaperFeed->AddItem(item);
|
fPaperFeed->AddItem(item);
|
||||||
@ -627,18 +310,16 @@ JobSetupView::AttachedToWindow()
|
|||||||
}
|
}
|
||||||
if (!marked)
|
if (!marked)
|
||||||
item->SetMarked(true);
|
item->SetMarked(true);
|
||||||
menufield = new BMenuField(paperfeed_rect, "paperSource", "Paper Source:", fPaperFeed);
|
BMenuField* paperSourceMenufield = new BMenuField("paperSource",
|
||||||
AddChild(menufield);
|
"Paper Source:", fPaperFeed);
|
||||||
width = StringWidth("Number of Copies:") + 7;
|
|
||||||
menufield->SetDivider(width);
|
|
||||||
|
|
||||||
/* Page Per Sheet */
|
// Pages per sheet
|
||||||
|
|
||||||
marked = false;
|
|
||||||
fNup = new BPopUpMenu("");
|
fNup = new BPopUpMenu("");
|
||||||
fNup->SetRadioMode(true);
|
fNup->SetRadioMode(true);
|
||||||
count = sizeof(gNups) / sizeof(gNups[0]);
|
count = sizeof(gNups) / sizeof(gNups[0]);
|
||||||
const NupCap **nup_cap = gNups;
|
const NupCap **nup_cap = gNups;
|
||||||
|
marked = false;
|
||||||
|
item = NULL;
|
||||||
while (count--) {
|
while (count--) {
|
||||||
item = new BMenuItem((*nup_cap)->label.c_str(), NULL);
|
item = new BMenuItem((*nup_cap)->label.c_str(), NULL);
|
||||||
fNup->AddItem(item);
|
fNup->AddItem(item);
|
||||||
@ -650,15 +331,13 @@ JobSetupView::AttachedToWindow()
|
|||||||
}
|
}
|
||||||
if (!marked)
|
if (!marked)
|
||||||
item->SetMarked(true);
|
item->SetMarked(true);
|
||||||
menufield = new BMenuField(nup_rect, "pagePerSheet", "Pages Per Sheet:", fNup);
|
BMenuField* pagesPerSheet = new BMenuField("pagesPerSheet",
|
||||||
menufield->SetDivider(StringWidth("Number of Copies:") + 7);
|
"Pages Per Sheet:", fNup);
|
||||||
AddChild(menufield);
|
|
||||||
|
|
||||||
/* duplex */
|
|
||||||
|
|
||||||
|
// duplex
|
||||||
if (fPrinterCap->isSupport(PrinterCap::kPrintStyle)) {
|
if (fPrinterCap->isSupport(PrinterCap::kPrintStyle)) {
|
||||||
fDuplex = new BCheckBox(duplex_rect, "duplex", "Duplex", new BMessage(kMsgDuplexChanged));
|
fDuplex = new BCheckBox("duplex", "Duplex",
|
||||||
AddChild(fDuplex);
|
new BMessage(kMsgDuplexChanged));
|
||||||
if (fJobData->getPrintStyle() != JobData::kSimplex) {
|
if (fJobData->getPrintStyle() != JobData::kSimplex) {
|
||||||
fDuplex->SetValue(B_CONTROL_ON);
|
fDuplex->SetValue(B_CONTROL_ON);
|
||||||
}
|
}
|
||||||
@ -667,72 +346,156 @@ JobSetupView::AttachedToWindow()
|
|||||||
fDuplex = NULL;
|
fDuplex = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* copies */
|
// copies
|
||||||
|
fCopies = new BTextControl("copies", "Number of Copies:", "", NULL);
|
||||||
fCopies = new BTextControl(copies_rect, "copies", "Number of Copies:", "", NULL);
|
|
||||||
AddChild(fCopies);
|
|
||||||
fCopies->SetDivider(width);
|
|
||||||
AllowOnlyDigits(fCopies->TextView(), 3);
|
AllowOnlyDigits(fCopies->TextView(), 3);
|
||||||
|
|
||||||
BString oss4;
|
BString copies;
|
||||||
oss4 << fJobData->getCopies();
|
copies << fJobData->getCopies();
|
||||||
fCopies->SetText(oss4.String());
|
fCopies->SetText(copies.String());
|
||||||
|
|
||||||
/* collate */
|
// collate
|
||||||
|
fCollate = new BCheckBox("collate", "Collate",
|
||||||
fCollate = new BCheckBox(collate_rect, "collate", "Collate", new BMessage(kMsgCollateChanged));
|
new BMessage(kMsgCollateChanged));
|
||||||
fCollate->ResizeToPreferred();
|
|
||||||
AddChild(fCollate);
|
|
||||||
if (fJobData->getCollate()) {
|
if (fJobData->getCollate()) {
|
||||||
fCollate->SetValue(B_CONTROL_ON);
|
fCollate->SetValue(B_CONTROL_ON);
|
||||||
}
|
}
|
||||||
fCollate->SetTarget(this);
|
fCollate->SetTarget(this);
|
||||||
|
|
||||||
/* reverse */
|
// reverse
|
||||||
|
fReverse = new BCheckBox("reverse", "Reverse Order",
|
||||||
fReverse = new BCheckBox(reverse_rect, "reverse", "Reverse Order", new BMessage(kMsgReverseChanged));
|
new BMessage(kMsgReverseChanged));
|
||||||
fReverse->ResizeToPreferred();
|
|
||||||
AddChild(fReverse);
|
|
||||||
if (fJobData->getReverse()) {
|
if (fJobData->getReverse()) {
|
||||||
fReverse->SetValue(B_CONTROL_ON);
|
fReverse->SetValue(B_CONTROL_ON);
|
||||||
}
|
}
|
||||||
fReverse->SetTarget(this);
|
fReverse->SetTarget(this);
|
||||||
|
|
||||||
/* pages view */
|
// pages view
|
||||||
|
// TODO make layout API compatible
|
||||||
fPages = new PagesView(pages_rect, "pages", B_FOLLOW_ALL, B_WILL_DRAW);
|
fPages = new PagesView(BRect(0, 0, 150, 40), "pages", B_FOLLOW_ALL,
|
||||||
AddChild(fPages);
|
B_WILL_DRAW);
|
||||||
fPages->setCollate(fJobData->getCollate());
|
fPages->setCollate(fJobData->getCollate());
|
||||||
fPages->setReverse(fJobData->getReverse());
|
fPages->setReverse(fJobData->getReverse());
|
||||||
|
fPages->SetExplicitMinSize(BSize(150, 40));
|
||||||
|
fPages->SetExplicitMaxSize(BSize(150, 40));
|
||||||
|
|
||||||
/* page selection */
|
// page selection
|
||||||
BBox* pageSelectionBox = new BBox(page_selection_rect);
|
BBox* pageSelectionBox = new BBox("pageSelection");
|
||||||
AddChild(pageSelectionBox);
|
|
||||||
pageSelectionBox->SetLabel("Page Selection");
|
pageSelectionBox->SetLabel("Page Selection");
|
||||||
|
|
||||||
fAllPages = AddPageSelectionItem(pageSelectionBox, page_selection_all_pages_rect, "allPages", "All Pages", JobData::kAllPages);
|
fAllPages = CreatePageSelectionItem("allPages", "All Pages",
|
||||||
fOddNumberedPages = AddPageSelectionItem(pageSelectionBox, page_selection_odd_pages_rect, "oddPages", "Odd-Numbered Pages", JobData::kOddNumberedPages);
|
JobData::kAllPages);
|
||||||
fEvenNumberedPages = AddPageSelectionItem(pageSelectionBox, page_selection_even_pages_rect, "evenPages", "Even-Numbered Pages", JobData::kEvenNumberedPages);
|
fOddNumberedPages = CreatePageSelectionItem("oddPages",
|
||||||
|
"Odd-Numbered Pages", JobData::kOddNumberedPages);
|
||||||
|
fEvenNumberedPages = CreatePageSelectionItem("evenPages",
|
||||||
|
"Even-Numbered Pages", JobData::kEvenNumberedPages);
|
||||||
|
|
||||||
|
// separator line
|
||||||
|
BBox *separator = new BBox("separator");
|
||||||
|
separator->SetExplicitMaxSize(BSize(B_SIZE_UNLIMITED, 1));
|
||||||
|
|
||||||
|
// buttons
|
||||||
|
BButton* preview = new BButton("preview", "Preview" B_UTF8_ELLIPSIS,
|
||||||
|
new BMessage(kMsgPreview));
|
||||||
|
BButton* cancel = new BButton("cancel", "Cancel",
|
||||||
|
new BMessage(kMsgCancel));
|
||||||
|
BButton* ok = new BButton("ok", "OK", new BMessage(kMsgOK));
|
||||||
|
ok->MakeDefault(true);
|
||||||
|
|
||||||
|
BGroupView* halftoneGroup = new BGroupView(B_VERTICAL, 0);
|
||||||
|
BGroupLayout* halftoneLayout = halftoneGroup->GroupLayout();
|
||||||
|
halftoneLayout->AddView(fHalftone);
|
||||||
|
halftoneBox->AddChild(halftoneGroup);
|
||||||
|
|
||||||
|
BGridView* qualityGrid = new BGridView();
|
||||||
|
BGridLayout* qualityGridLayout = qualityGrid->GridLayout();
|
||||||
|
qualityGridLayout->AddItem(colorMenuField->CreateLabelLayoutItem(), 0, 0);
|
||||||
|
qualityGridLayout->AddItem(colorMenuField->CreateMenuBarLayoutItem(), 1, 0);
|
||||||
|
qualityGridLayout->AddItem(ditherMenuField->CreateLabelLayoutItem(), 0, 1);
|
||||||
|
qualityGridLayout->AddItem(ditherMenuField->CreateMenuBarLayoutItem(), 1,
|
||||||
|
1);
|
||||||
|
qualityGridLayout->AddView(fGamma, 0, 2, 2);
|
||||||
|
qualityGridLayout->AddView(fInkDensity, 0, 3, 2);
|
||||||
|
qualityGridLayout->AddView(halftoneBox, 0, 4, 2);
|
||||||
|
qualityGridLayout->SetSpacing(0, 0);
|
||||||
|
qualityGridLayout->SetInsets(5, 5, 5, 5);
|
||||||
|
qualityBox->AddChild(qualityGrid);
|
||||||
|
|
||||||
|
BGridView* pageRangeGrid = new BGridView();
|
||||||
|
BGridLayout* pageRangeLayout = pageRangeGrid->GridLayout();
|
||||||
|
pageRangeLayout->AddItem(fFromPage->CreateLabelLayoutItem(), 0, 0);
|
||||||
|
pageRangeLayout->AddItem(fFromPage->CreateTextViewLayoutItem(), 1, 0);
|
||||||
|
pageRangeLayout->AddItem(fToPage->CreateLabelLayoutItem(), 0, 1);
|
||||||
|
pageRangeLayout->AddItem(fToPage->CreateTextViewLayoutItem(), 1, 1);
|
||||||
|
pageRangeLayout->SetInsets(0, 0, 0, 0);
|
||||||
|
pageRangeLayout->SetSpacing(0, 0);
|
||||||
|
|
||||||
|
BGroupView* pageRangeGroup = new BGroupView(B_VERTICAL, 0);
|
||||||
|
BGroupLayout* pageRangeGroupLayout = pageRangeGroup->GroupLayout();
|
||||||
|
pageRangeGroupLayout->AddView(fAll);
|
||||||
|
pageRangeGroupLayout->AddView(range);
|
||||||
|
pageRangeGroupLayout->AddView(pageRangeGrid);
|
||||||
|
pageRangeGroupLayout->SetInsets(5, 5, 5, 5);
|
||||||
|
pageRangeBox->AddChild(pageRangeGroup);
|
||||||
|
|
||||||
|
BGridView* settings = new BGridView();
|
||||||
|
BGridLayout* settingsLayout = settings->GridLayout();
|
||||||
|
settingsLayout->AddItem(paperSourceMenufield->CreateLabelLayoutItem(), 0,
|
||||||
|
0);
|
||||||
|
settingsLayout->AddItem(paperSourceMenufield->CreateMenuBarLayoutItem(), 1,
|
||||||
|
0);
|
||||||
|
settingsLayout->AddItem(pagesPerSheet->CreateLabelLayoutItem(), 0, 1);
|
||||||
|
settingsLayout->AddItem(pagesPerSheet->CreateMenuBarLayoutItem(), 1, 1);
|
||||||
|
int row = 2;
|
||||||
|
if (fDuplex != NULL) {
|
||||||
|
settingsLayout->AddView(fDuplex, 0, row, 2);
|
||||||
|
row ++;
|
||||||
|
}
|
||||||
|
settingsLayout->AddItem(fCopies->CreateLabelLayoutItem(), 0, row);
|
||||||
|
settingsLayout->AddItem(fCopies->CreateTextViewLayoutItem(), 1, row);
|
||||||
|
settingsLayout->SetSpacing(0, 0);
|
||||||
|
|
||||||
|
|
||||||
|
BGroupView* pageSelectionGroup = new BGroupView(B_VERTICAL, 0);
|
||||||
|
BGroupLayout* groupLayout = pageSelectionGroup->GroupLayout();
|
||||||
|
groupLayout->AddView(fAllPages);
|
||||||
|
groupLayout->AddView(fOddNumberedPages);
|
||||||
|
groupLayout->AddView(fEvenNumberedPages);
|
||||||
|
groupLayout->SetInsets(5, 5, 5, 5);
|
||||||
|
pageSelectionBox->AddChild(pageSelectionGroup);
|
||||||
|
|
||||||
/* preview */
|
SetLayout(new BGroupLayout(B_VERTICAL));
|
||||||
|
AddChild(BGroupLayoutBuilder(B_VERTICAL, 0)
|
||||||
|
.AddGroup(B_HORIZONTAL, 10, 1.0f)
|
||||||
|
.AddGroup(B_VERTICAL, 10, 1.0f)
|
||||||
|
.Add(qualityBox)
|
||||||
|
.Add(pageRangeBox)
|
||||||
|
.AddGlue()
|
||||||
|
.End()
|
||||||
|
.AddGroup(B_VERTICAL, 0, 1.0f)
|
||||||
|
.Add(settings)
|
||||||
|
.AddStrut(5)
|
||||||
|
.Add(fCollate)
|
||||||
|
.Add(fReverse)
|
||||||
|
.Add(fPages)
|
||||||
|
.AddStrut(5)
|
||||||
|
.Add(pageSelectionBox)
|
||||||
|
.AddGlue()
|
||||||
|
.End()
|
||||||
|
.End()
|
||||||
|
.AddGlue()
|
||||||
|
.Add(separator)
|
||||||
|
.AddGroup(B_HORIZONTAL, 10, 1.0f)
|
||||||
|
.AddGlue()
|
||||||
|
.Add(cancel)
|
||||||
|
.Add(preview)
|
||||||
|
.Add(ok)
|
||||||
|
.End()
|
||||||
|
.SetInsets(0, 0, 0, 0)
|
||||||
|
);
|
||||||
|
|
||||||
button = new BButton(preview_rect, "preview", "Preview" B_UTF8_ELLIPSIS, new BMessage(kMsgPreview));
|
fHalftone->preview(fJobData->getGamma(), fJobData->getInkDensity(),
|
||||||
AddChild(button);
|
fJobData->getDitherType(), fJobData->getColor() != JobData::kMonochrome);
|
||||||
|
|
||||||
|
|
||||||
/* cancel */
|
|
||||||
|
|
||||||
button = new BButton(cancel_rect, "cancel", "Cancel", new BMessage(kMsgCancel));
|
|
||||||
AddChild(button);
|
|
||||||
|
|
||||||
/* ok */
|
|
||||||
|
|
||||||
// TODO OK or "Print"?
|
|
||||||
button = new BButton(ok_rect, "ok", "OK", new BMessage(kMsgOK));
|
|
||||||
AddChild(button);
|
|
||||||
button->MakeDefault(true);
|
|
||||||
|
|
||||||
UpdateButtonEnabledState();
|
UpdateButtonEnabledState();
|
||||||
}
|
}
|
||||||
@ -900,16 +663,22 @@ JobSetupView::UpdateJobData(bool showPreview)
|
|||||||
|
|
||||||
//====================================================================
|
//====================================================================
|
||||||
|
|
||||||
JobSetupDlg::JobSetupDlg(JobData *job_data, PrinterData *printer_data, const PrinterCap *printer_cap)
|
JobSetupDlg::JobSetupDlg(JobData *job_data, PrinterData *printer_data,
|
||||||
: DialogWindow(BRect(100, 100, 100 + PRINT_WIDTH, 100 + PRINT_HEIGHT),
|
const PrinterCap *printer_cap)
|
||||||
|
: DialogWindow(BRect(100, 100, 200, 200),
|
||||||
"PrintJob Setup", B_TITLED_WINDOW_LOOK, B_MODAL_APP_WINDOW_FEEL,
|
"PrintJob Setup", B_TITLED_WINDOW_LOOK, B_MODAL_APP_WINDOW_FEEL,
|
||||||
B_NOT_RESIZABLE | B_NOT_MINIMIZABLE | B_NOT_ZOOMABLE | B_ASYNCHRONOUS_CONTROLS)
|
B_NOT_RESIZABLE | B_NOT_MINIMIZABLE | B_NOT_ZOOMABLE
|
||||||
|
| B_ASYNCHRONOUS_CONTROLS | B_AUTO_UPDATE_SIZE_LIMITS)
|
||||||
{
|
{
|
||||||
SetResult(B_ERROR);
|
SetResult(B_ERROR);
|
||||||
AddShortcut('W',B_COMMAND_KEY,new BMessage(B_QUIT_REQUESTED));
|
AddShortcut('W', B_COMMAND_KEY, new BMessage(B_QUIT_REQUESTED));
|
||||||
|
|
||||||
fJobSetup = new JobSetupView(Bounds(), job_data, printer_data, printer_cap);
|
fJobSetup = new JobSetupView(job_data, printer_data, printer_cap);
|
||||||
AddChild(fJobSetup);
|
SetLayout(new BGroupLayout(B_VERTICAL));
|
||||||
|
AddChild(BGroupLayoutBuilder(B_VERTICAL, 0)
|
||||||
|
.Add(fJobSetup)
|
||||||
|
.SetInsets(10, 10, 10, 10)
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -37,6 +37,10 @@ THE SOFTWARE.
|
|||||||
|
|
||||||
|
|
||||||
#include <AppKit.h>
|
#include <AppKit.h>
|
||||||
|
#include <GridView.h>
|
||||||
|
#include <GridLayout.h>
|
||||||
|
#include <GroupLayout.h>
|
||||||
|
#include <GroupLayoutBuilder.h>
|
||||||
#include <SupportKit.h>
|
#include <SupportKit.h>
|
||||||
#include <TextControl.h>
|
#include <TextControl.h>
|
||||||
|
|
||||||
@ -72,28 +76,89 @@ const rgb_color kWhite = { 255,255,255,0 };
|
|||||||
const rgb_color kGray = { 220,220,220,0 };
|
const rgb_color kGray = { 220,220,220,0 };
|
||||||
|
|
||||||
|
|
||||||
|
PageView::PageView()
|
||||||
|
: BView("pageView", B_WILL_DRAW | B_FULL_UPDATE_ON_RESIZE)
|
||||||
|
, fPageWidth(0)
|
||||||
|
, fPageHeight(0)
|
||||||
|
, fMargins(0, 0, 0, 0)
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void
|
||||||
|
PageView::SetPageSize(float pageWidth, float pageHeight)
|
||||||
|
{
|
||||||
|
fPageWidth = pageWidth;
|
||||||
|
fPageHeight = pageHeight;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void
|
||||||
|
PageView::SetMargins(BRect margins)
|
||||||
|
{
|
||||||
|
fMargins = margins;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void
|
||||||
|
PageView::Draw(BRect bounds)
|
||||||
|
{
|
||||||
|
BRect frame(Frame());
|
||||||
|
float totalWidth = frame.Width();
|
||||||
|
float totalHeight = frame.Height();
|
||||||
|
|
||||||
|
// fit page into available space
|
||||||
|
// keeping the ratio fPageWidth : fPageHeight
|
||||||
|
float pageWidth = totalWidth;
|
||||||
|
float pageHeight = totalWidth * fPageHeight / fPageWidth;
|
||||||
|
if (pageHeight > totalHeight) {
|
||||||
|
pageHeight = totalHeight;
|
||||||
|
pageWidth = totalHeight * fPageWidth / fPageHeight;
|
||||||
|
}
|
||||||
|
|
||||||
|
// center page
|
||||||
|
BPoint offset(0, 0);
|
||||||
|
offset.x = static_cast<int>((totalWidth - pageWidth) / 2);
|
||||||
|
offset.y = static_cast<int>((totalHeight - pageHeight) / 2);
|
||||||
|
|
||||||
|
// draw the page
|
||||||
|
SetHighColor(kWhite);
|
||||||
|
BRect r = BRect(0, 0, pageWidth, pageHeight);
|
||||||
|
r.OffsetBy(offset);
|
||||||
|
FillRect(r);
|
||||||
|
SetHighColor(kBlack);
|
||||||
|
StrokeRect(r);
|
||||||
|
|
||||||
|
// draw margin
|
||||||
|
SetHighColor(kRed);
|
||||||
|
SetLowColor(kWhite);
|
||||||
|
r.top += (fMargins.top / fPageHeight) * pageHeight;
|
||||||
|
r.right -= (fMargins.right / fPageWidth) * pageWidth;
|
||||||
|
r.bottom -= (fMargins.bottom / fPageHeight) * pageHeight;
|
||||||
|
r.left += (fMargins.left / fPageWidth) * pageWidth;
|
||||||
|
StrokeRect(r, kDots);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Constructor
|
* Constructor
|
||||||
*
|
*
|
||||||
* @param frame, BRect that is the size of the view passed to the superclase
|
|
||||||
* @param pageWidth, float that is the points value of the page width
|
* @param pageWidth, float that is the points value of the page width
|
||||||
* @param pageHeight, float that is the points value of the page height
|
* @param pageHeight, float that is the points value of the page height
|
||||||
* @param margins, BRect values of margins
|
* @param margins, BRect values of margins
|
||||||
* @param units, unit32 enum for units used in view
|
* @param units, unit32 enum for units used in view
|
||||||
* @return void
|
* @return void
|
||||||
*/
|
*/
|
||||||
MarginView::MarginView(BRect frame, int32 pageWidth, int32 pageHeight,
|
MarginView::MarginView(int32 pageWidth, int32 pageHeight,
|
||||||
BRect margins, MarginUnit units)
|
BRect margins, MarginUnit units)
|
||||||
: BBox(frame, NULL, B_FOLLOW_ALL)
|
: BBox("marginView")
|
||||||
{
|
{
|
||||||
fMarginUnit = units;
|
fMarginUnit = units;
|
||||||
fUnitValue = kUnitFormat[units];
|
fUnitValue = kUnitFormat[units];
|
||||||
|
|
||||||
SetLabel("Margins");
|
SetLabel("Margins");
|
||||||
|
|
||||||
fMaxPageHeight = frame.Height() - kMinUnitHeight - kOffsetY;
|
|
||||||
fMaxPageWidth = frame.Width() - kMinFieldWidth - kOffsetX;
|
|
||||||
|
|
||||||
fMargins = margins;
|
fMargins = margins;
|
||||||
|
|
||||||
fPageWidth = pageWidth;
|
fPageWidth = pageWidth;
|
||||||
@ -128,73 +193,6 @@ MarginView::AttachedToWindow()
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Draw
|
|
||||||
*
|
|
||||||
* @param BRect, the draw bounds
|
|
||||||
* @return void
|
|
||||||
*/
|
|
||||||
void
|
|
||||||
MarginView::Draw(BRect rect)
|
|
||||||
{
|
|
||||||
BBox::Draw(rect);
|
|
||||||
|
|
||||||
float y_offset = (float)kOffsetY;
|
|
||||||
float x_offset = (float)kOffsetX;
|
|
||||||
BRect r;
|
|
||||||
|
|
||||||
// Calculate offsets depending on orientation
|
|
||||||
if (fPageWidth < fPageHeight) { // Portrait
|
|
||||||
x_offset = (fMaxPageWidth/2 + kOffsetX) - fViewWidth/2;
|
|
||||||
} else { // landscape
|
|
||||||
y_offset = (fMaxPageHeight/2 + kOffsetY) - fViewHeight/2;
|
|
||||||
}
|
|
||||||
|
|
||||||
// draw the page
|
|
||||||
SetHighColor(kWhite);
|
|
||||||
r = BRect(0, 0, fViewWidth, fViewHeight);
|
|
||||||
r.OffsetBy(x_offset, y_offset);
|
|
||||||
FillRect(r);
|
|
||||||
SetHighColor(kBlack);
|
|
||||||
StrokeRect(r);
|
|
||||||
|
|
||||||
// draw margin
|
|
||||||
SetHighColor(kRed);
|
|
||||||
SetLowColor(kWhite);
|
|
||||||
r.top += fMargins.top;
|
|
||||||
r.right -= fMargins.right;
|
|
||||||
r.bottom -= fMargins.bottom;
|
|
||||||
r.left += fMargins.left;
|
|
||||||
StrokeRect(r, kDots);
|
|
||||||
|
|
||||||
// draw the page size label
|
|
||||||
SetHighColor(kBlack);
|
|
||||||
SetLowColor(kGray);
|
|
||||||
char str[kStringSize];
|
|
||||||
sprintf(str, "%2.1f x %2.1f", fPageWidth/fUnitValue, fPageHeight/fUnitValue);
|
|
||||||
SetFontSize(10);
|
|
||||||
DrawString((const char *)str, BPoint(x_offset, fMaxPageHeight + 40));
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* BeOS Hook Function, change the size of the margin display
|
|
||||||
*
|
|
||||||
* @param width of the page
|
|
||||||
* @param height the page
|
|
||||||
* @return void
|
|
||||||
*/
|
|
||||||
void
|
|
||||||
MarginView::FrameResized(float width, float height)
|
|
||||||
{
|
|
||||||
fMaxPageHeight = height - kMinUnitHeight - kOffsetX;
|
|
||||||
fMaxPageWidth = width - kMinFieldWidth - kOffsetY;
|
|
||||||
|
|
||||||
_CalculateViewSize(MARGIN_CHANGED);
|
|
||||||
Invalidate();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* MesssageReceived()
|
* MesssageReceived()
|
||||||
*
|
*
|
||||||
@ -297,32 +295,32 @@ MarginView::Margin() const
|
|||||||
BRect margin;
|
BRect margin;
|
||||||
|
|
||||||
// convert the field text to values
|
// convert the field text to values
|
||||||
float ftop = atof(fTop->Text());
|
float top = atof(fTop->Text());
|
||||||
float fright = atof(fRight->Text());
|
float right = atof(fRight->Text());
|
||||||
float fleft = atof(fLeft->Text());
|
float left = atof(fLeft->Text());
|
||||||
float fbottom = atof(fBottom->Text());
|
float bottom = atof(fBottom->Text());
|
||||||
|
|
||||||
// convert to units to points
|
// convert to units to points
|
||||||
switch (fMarginUnit) {
|
switch (fMarginUnit) {
|
||||||
case kUnitInch:
|
case kUnitInch:
|
||||||
// convert to points
|
// convert to points
|
||||||
ftop *= kInchUnits;
|
top *= kInchUnits;
|
||||||
fright *= kInchUnits;
|
right *= kInchUnits;
|
||||||
fleft *= kInchUnits;
|
left *= kInchUnits;
|
||||||
fbottom *= kInchUnits;
|
bottom *= kInchUnits;
|
||||||
break;
|
break;
|
||||||
case kUnitCM:
|
case kUnitCM:
|
||||||
// convert to points
|
// convert to points
|
||||||
ftop *= kCMUnits;
|
top *= kCMUnits;
|
||||||
fright *= kCMUnits;
|
right *= kCMUnits;
|
||||||
fleft *= kCMUnits;
|
left *= kCMUnits;
|
||||||
fbottom *= kCMUnits;
|
bottom *= kCMUnits;
|
||||||
break;
|
break;
|
||||||
case kUnitPoint:
|
case kUnitPoint:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
margin.Set(fleft, ftop, fright, fbottom);
|
margin.Set(left, top, right, bottom);
|
||||||
|
|
||||||
return margin;
|
return margin;
|
||||||
}
|
}
|
||||||
@ -353,7 +351,19 @@ void
|
|||||||
MarginView::UpdateView(uint32 msg)
|
MarginView::UpdateView(uint32 msg)
|
||||||
{
|
{
|
||||||
Window()->Lock();
|
Window()->Lock();
|
||||||
_CalculateViewSize(msg); // only Preview in Margins BBox!
|
|
||||||
|
{
|
||||||
|
char pageSize[kStringSize];
|
||||||
|
sprintf(pageSize, "%2.1f x %2.1f",
|
||||||
|
fPageWidth / fUnitValue,
|
||||||
|
fPageHeight / fUnitValue);
|
||||||
|
fPageSize->SetText(pageSize);
|
||||||
|
|
||||||
|
fPage->SetPageSize(fPageWidth, fPageHeight);
|
||||||
|
fPage->SetMargins(Margin());
|
||||||
|
fPage->Invalidate();
|
||||||
|
}
|
||||||
|
|
||||||
Invalidate();
|
Invalidate();
|
||||||
Window()->Unlock();
|
Window()->Unlock();
|
||||||
}
|
}
|
||||||
@ -373,85 +383,53 @@ MarginView::UpdateView(uint32 msg)
|
|||||||
void
|
void
|
||||||
MarginView::_ConstructGUI()
|
MarginView::_ConstructGUI()
|
||||||
{
|
{
|
||||||
|
fPage = new PageView();
|
||||||
|
fPage->SetViewColor(ViewColor());
|
||||||
|
|
||||||
|
fPageSize = new BStringView("pageSize", "?x?");
|
||||||
|
|
||||||
BString str;
|
BString str;
|
||||||
// Create text fields
|
// Create text fields
|
||||||
BRect r(Frame().Width() - be_plain_font->StringWidth("Top#") - kWidth,
|
|
||||||
kOffsetY, Frame().Width() - kOffsetX, kWidth);
|
|
||||||
|
|
||||||
// top
|
// top
|
||||||
str << fMargins.top/fUnitValue;
|
str << fMargins.top/fUnitValue;
|
||||||
fTop = new BTextControl( r, "top", "Top:", str.String(), NULL,
|
fTop = new BTextControl("top", "Top:", str.String(), NULL);
|
||||||
B_FOLLOW_RIGHT);
|
|
||||||
|
|
||||||
fTop->SetModificationMessage(new BMessage(TOP_MARGIN_CHANGED));
|
fTop->SetModificationMessage(new BMessage(TOP_MARGIN_CHANGED));
|
||||||
fTop->SetDivider(be_plain_font->StringWidth("Top#"));
|
|
||||||
fTop->SetTarget(this);
|
fTop->SetTarget(this);
|
||||||
_AllowOnlyNumbers(fTop, kNumCount);
|
_AllowOnlyNumbers(fTop, kNumCount);
|
||||||
AddChild(fTop);
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//left
|
//left
|
||||||
r.OffsetBy(0, kOffsetY);
|
|
||||||
r.left = Frame().Width() - be_plain_font->StringWidth("Left#") - kWidth;
|
|
||||||
str = "";
|
str = "";
|
||||||
str << fMargins.left/fUnitValue;
|
str << fMargins.left/fUnitValue;
|
||||||
fLeft = new BTextControl( r, "left", "Left:", str.String(), NULL,
|
fLeft = new BTextControl("left", "Left:", str.String(), NULL);
|
||||||
B_FOLLOW_RIGHT);
|
|
||||||
|
|
||||||
fLeft->SetModificationMessage(new BMessage(LEFT_MARGIN_CHANGED));
|
fLeft->SetModificationMessage(new BMessage(LEFT_MARGIN_CHANGED));
|
||||||
fLeft->SetDivider(be_plain_font->StringWidth("Left#"));
|
|
||||||
fLeft->SetTarget(this);
|
fLeft->SetTarget(this);
|
||||||
_AllowOnlyNumbers(fLeft, kNumCount);
|
_AllowOnlyNumbers(fLeft, kNumCount);
|
||||||
AddChild(fLeft);
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//bottom
|
//bottom
|
||||||
r.OffsetBy(0, kOffsetY);
|
|
||||||
r.left = Frame().Width() - be_plain_font->StringWidth("Bottom#") - kWidth;
|
|
||||||
str = "";
|
str = "";
|
||||||
str << fMargins.bottom/fUnitValue;
|
str << fMargins.bottom/fUnitValue;
|
||||||
fBottom = new BTextControl( r, "bottom", "Bottom:", str.String(), NULL,
|
fBottom = new BTextControl("bottom", "Bottom:", str.String(), NULL);
|
||||||
B_FOLLOW_RIGHT);
|
|
||||||
|
|
||||||
fBottom->SetModificationMessage(new BMessage(BOTTOM_MARGIN_CHANGED));
|
fBottom->SetModificationMessage(new BMessage(BOTTOM_MARGIN_CHANGED));
|
||||||
fBottom->SetDivider(be_plain_font->StringWidth("Bottom#"));
|
|
||||||
fBottom->SetTarget(this);
|
fBottom->SetTarget(this);
|
||||||
|
|
||||||
_AllowOnlyNumbers(fBottom, kNumCount);
|
_AllowOnlyNumbers(fBottom, kNumCount);
|
||||||
AddChild(fBottom);
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//right
|
//right
|
||||||
r.OffsetBy(0, kOffsetY);
|
|
||||||
r.left = Frame().Width() - be_plain_font->StringWidth("Right#") - kWidth;
|
|
||||||
str = "";
|
str = "";
|
||||||
str << fMargins.right/fUnitValue;
|
str << fMargins.right/fUnitValue;
|
||||||
fRight = new BTextControl( r, "right", "Right:", str.String(), NULL,
|
fRight = new BTextControl("right", "Right:", str.String(), NULL);
|
||||||
B_FOLLOW_RIGHT);
|
|
||||||
|
|
||||||
fRight->SetModificationMessage(new BMessage(RIGHT_MARGIN_CHANGED));
|
fRight->SetModificationMessage(new BMessage(RIGHT_MARGIN_CHANGED));
|
||||||
fRight->SetDivider(be_plain_font->StringWidth("Right#"));
|
|
||||||
fRight->SetTarget(this);
|
fRight->SetTarget(this);
|
||||||
_AllowOnlyNumbers(fRight, kNumCount);
|
_AllowOnlyNumbers(fRight, kNumCount);
|
||||||
AddChild(fRight);
|
|
||||||
|
|
||||||
|
// Create Units popup
|
||||||
|
|
||||||
// Create Units popup
|
|
||||||
r.OffsetBy(-kOffsetX, kOffsetY);
|
|
||||||
r.right += kOffsetY;
|
|
||||||
|
|
||||||
BPopUpMenu *menu = new BPopUpMenu("units");
|
BPopUpMenu *menu = new BPopUpMenu("units");
|
||||||
BMenuField *mf = new BMenuField(r, "units", "Units", menu,
|
BMenuField *units = new BMenuField("units", "Units:", menu);
|
||||||
B_FOLLOW_BOTTOM | B_FOLLOW_RIGHT);
|
|
||||||
mf->ResizeToPreferred();
|
|
||||||
mf->SetDivider(be_plain_font->StringWidth("Units#"));
|
|
||||||
|
|
||||||
BMenuItem *item;
|
BMenuItem *item;
|
||||||
// Construct menu items
|
// Construct menu items
|
||||||
@ -463,10 +441,35 @@ MarginView::_ConstructGUI()
|
|||||||
if (fMarginUnit == kUnitMsg[i])
|
if (fMarginUnit == kUnitMsg[i])
|
||||||
item->SetMarked(true);
|
item->SetMarked(true);
|
||||||
}
|
}
|
||||||
AddChild(mf);
|
|
||||||
|
|
||||||
// calculate the sizes for drawing page view
|
BGridView* settings = new BGridView();
|
||||||
_CalculateViewSize(MARGIN_CHANGED);
|
BGridLayout* settingsLayout = settings->GridLayout();
|
||||||
|
settingsLayout->AddItem(fTop->CreateLabelLayoutItem(), 0, 0);
|
||||||
|
settingsLayout->AddItem(fTop->CreateTextViewLayoutItem(), 1, 0);
|
||||||
|
settingsLayout->AddItem(fLeft->CreateLabelLayoutItem(), 0, 1);
|
||||||
|
settingsLayout->AddItem(fLeft->CreateTextViewLayoutItem(), 1, 1);
|
||||||
|
settingsLayout->AddItem(fBottom->CreateLabelLayoutItem(), 0, 2);
|
||||||
|
settingsLayout->AddItem(fBottom->CreateTextViewLayoutItem(), 1, 2);
|
||||||
|
settingsLayout->AddItem(fRight->CreateLabelLayoutItem(), 0, 3);
|
||||||
|
settingsLayout->AddItem(fRight->CreateTextViewLayoutItem(), 1, 3);
|
||||||
|
settingsLayout->AddItem(units->CreateLabelLayoutItem(), 0, 4);
|
||||||
|
settingsLayout->AddItem(units->CreateMenuBarLayoutItem(), 1, 4);
|
||||||
|
settingsLayout->SetSpacing(0, 0);
|
||||||
|
|
||||||
|
BGroupView* groupView = new BGroupView(B_HORIZONTAL, 10);
|
||||||
|
BGroupLayout* groupLayout = groupView->GroupLayout();
|
||||||
|
groupLayout->AddView(BGroupLayoutBuilder(B_VERTICAL, 0)
|
||||||
|
.Add(fPage)
|
||||||
|
.Add(fPageSize)
|
||||||
|
.SetInsets(0, 0, 0, 0)
|
||||||
|
.TopView()
|
||||||
|
);
|
||||||
|
groupLayout->AddView(settings);
|
||||||
|
groupLayout->SetInsets(5, 5, 5, 5);
|
||||||
|
|
||||||
|
AddChild(groupView);
|
||||||
|
|
||||||
|
UpdateView(MARGIN_CHANGED);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -489,6 +492,7 @@ MarginView::_AllowOnlyNumbers(BTextControl *textControl, int32 maxNum)
|
|||||||
tv->AllowChar(i);
|
tv->AllowChar(i);
|
||||||
|
|
||||||
tv->AllowChar(B_BACKSPACE);
|
tv->AllowChar(B_BACKSPACE);
|
||||||
|
// TODO internationalization; e.g. "." or ","
|
||||||
tv->AllowChar('.');
|
tv->AllowChar('.');
|
||||||
tv->SetMaxBytes(maxNum);
|
tv->SetMaxBytes(maxNum);
|
||||||
}
|
}
|
||||||
@ -524,56 +528,56 @@ MarginView::_SetMarginUnit(MarginUnit unit)
|
|||||||
fUnitValue = kUnitFormat[unit];
|
fUnitValue = kUnitFormat[unit];
|
||||||
|
|
||||||
// convert the field text to values
|
// convert the field text to values
|
||||||
float ftop = atof(fTop->Text());
|
float top = atof(fTop->Text());
|
||||||
float fright = atof(fRight->Text());
|
float right = atof(fRight->Text());
|
||||||
float fleft = atof(fLeft->Text());
|
float left = atof(fLeft->Text());
|
||||||
float fbottom = atof(fBottom->Text());
|
float bottom = atof(fBottom->Text());
|
||||||
|
|
||||||
// convert to target units
|
// convert to target units
|
||||||
switch (fMarginUnit)
|
switch (fMarginUnit)
|
||||||
{
|
{
|
||||||
case kUnitInch:
|
case kUnitInch:
|
||||||
// convert to points
|
// convert to points
|
||||||
ftop *= kInchUnits;
|
top *= kInchUnits;
|
||||||
fright *= kInchUnits;
|
right *= kInchUnits;
|
||||||
fleft *= kInchUnits;
|
left *= kInchUnits;
|
||||||
fbottom *= kInchUnits;
|
bottom *= kInchUnits;
|
||||||
// check for target unit is cm
|
// check for target unit is cm
|
||||||
if (unit == kUnitCM) {
|
if (unit == kUnitCM) {
|
||||||
ftop /= kCMUnits;
|
top /= kCMUnits;
|
||||||
fright /= kCMUnits;
|
right /= kCMUnits;
|
||||||
fleft /= kCMUnits;
|
left /= kCMUnits;
|
||||||
fbottom /= kCMUnits;
|
bottom /= kCMUnits;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case kUnitCM:
|
case kUnitCM:
|
||||||
// convert to points
|
// convert to points
|
||||||
ftop *= kCMUnits;
|
top *= kCMUnits;
|
||||||
fright *= kCMUnits;
|
right *= kCMUnits;
|
||||||
fleft *= kCMUnits;
|
left *= kCMUnits;
|
||||||
fbottom *= kCMUnits;
|
bottom *= kCMUnits;
|
||||||
// check for target unit is inches
|
// check for target unit is inches
|
||||||
if (unit == kUnitInch) {
|
if (unit == kUnitInch) {
|
||||||
ftop /= kInchUnits;
|
top /= kInchUnits;
|
||||||
fright /= kInchUnits;
|
right /= kInchUnits;
|
||||||
fleft /= kInchUnits;
|
left /= kInchUnits;
|
||||||
fbottom /= kInchUnits;
|
bottom /= kInchUnits;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case kUnitPoint:
|
case kUnitPoint:
|
||||||
// check for target unit is cm
|
// check for target unit is cm
|
||||||
if (unit == kUnitCM) {
|
if (unit == kUnitCM) {
|
||||||
ftop /= kCMUnits;
|
top /= kCMUnits;
|
||||||
fright /= kCMUnits;
|
right /= kCMUnits;
|
||||||
fleft /= kCMUnits;
|
left /= kCMUnits;
|
||||||
fbottom /= kCMUnits;
|
bottom /= kCMUnits;
|
||||||
}
|
}
|
||||||
// check for target unit is inches
|
// check for target unit is inches
|
||||||
if (unit == kUnitInch) {
|
if (unit == kUnitInch) {
|
||||||
ftop /= kInchUnits;
|
top /= kInchUnits;
|
||||||
fright /= kInchUnits;
|
right /= kInchUnits;
|
||||||
fleft /= kInchUnits;
|
left /= kInchUnits;
|
||||||
fbottom /= kInchUnits;
|
bottom /= kInchUnits;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -584,137 +588,24 @@ MarginView::_SetMarginUnit(MarginUnit unit)
|
|||||||
|
|
||||||
// set the fields to new units
|
// set the fields to new units
|
||||||
BString str;
|
BString str;
|
||||||
str << ftop;
|
str << top;
|
||||||
fTop->SetText(str.String());
|
fTop->SetText(str.String());
|
||||||
|
|
||||||
str = "";
|
str = "";
|
||||||
str << fleft;
|
str << left;
|
||||||
fLeft->SetText(str.String());
|
fLeft->SetText(str.String());
|
||||||
|
|
||||||
str = "";
|
str = "";
|
||||||
str << fright;
|
str << right;
|
||||||
fRight->SetText(str.String());
|
fRight->SetText(str.String());
|
||||||
|
|
||||||
str = "";
|
str = "";
|
||||||
str << fbottom;
|
str << bottom;
|
||||||
fBottom->SetText(str.String());
|
fBottom->SetText(str.String());
|
||||||
|
|
||||||
// update UI
|
// update UI
|
||||||
_CalculateViewSize(MARGIN_CHANGED);
|
|
||||||
Invalidate();
|
Invalidate();
|
||||||
|
|
||||||
Window()->Unlock();
|
Window()->Unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* CalculateViewSize
|
|
||||||
*
|
|
||||||
* calculate the size of the view that is used
|
|
||||||
* to show the page inside the margin box. This is dependent
|
|
||||||
* on the size of the box and the room we have to show it and
|
|
||||||
* the units that we are using and the orientation of the page.
|
|
||||||
*
|
|
||||||
* @param msg, the message for which field changed to check value bounds
|
|
||||||
* @return void
|
|
||||||
*/
|
|
||||||
void
|
|
||||||
MarginView::_CalculateViewSize(uint32 msg)
|
|
||||||
{
|
|
||||||
// determine page orientation
|
|
||||||
if (fPageHeight < fPageWidth) { // LANDSCAPE
|
|
||||||
fViewWidth = fMaxPageWidth;
|
|
||||||
fViewHeight = fPageHeight * (fViewWidth/fPageWidth);
|
|
||||||
float hdiff = fViewHeight - fMaxPageHeight;
|
|
||||||
if (hdiff > 0) {
|
|
||||||
fViewHeight -= hdiff;
|
|
||||||
fViewWidth -= hdiff;
|
|
||||||
}
|
|
||||||
} else { // PORTRAIT
|
|
||||||
fViewHeight = fMaxPageHeight;
|
|
||||||
fViewWidth = fPageWidth * (fViewHeight/fPageHeight);
|
|
||||||
float wdiff = fViewWidth - fMaxPageWidth;
|
|
||||||
if (wdiff > 0) {
|
|
||||||
fViewHeight -= wdiff;
|
|
||||||
fViewWidth -= wdiff;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// calculate margins based on view size
|
|
||||||
|
|
||||||
// find the length of 1 pixel in points
|
|
||||||
// ex: 80px/800pt = 0.1px/pt
|
|
||||||
float pixelLength = fViewHeight/fPageHeight;
|
|
||||||
|
|
||||||
// convert the margins to points
|
|
||||||
// The text field will have a number that us in the current unit
|
|
||||||
// ex 0.2" * 72pt = 14.4pts
|
|
||||||
float ftop = atof(fTop->Text()) * fUnitValue;
|
|
||||||
float fright = atof(fRight->Text()) * fUnitValue;
|
|
||||||
float fbottom = atof(fBottom->Text()) * fUnitValue;
|
|
||||||
float fleft = atof(fLeft->Text()) * fUnitValue;
|
|
||||||
|
|
||||||
// Check that the margins don't overlap each other...
|
|
||||||
float delta = 72.0;
|
|
||||||
// minimum printable rect = 1 inch * 1 inch
|
|
||||||
float ph = fPageHeight-delta;
|
|
||||||
float pw = fPageWidth-delta;
|
|
||||||
BString str;
|
|
||||||
|
|
||||||
// Bounds calculation rules:
|
|
||||||
if (msg == TOP_MARGIN_CHANGED) {
|
|
||||||
// top must be <= bottom
|
|
||||||
if (ftop > (ph - fbottom)) {
|
|
||||||
ftop = ph - fbottom;
|
|
||||||
str = "";
|
|
||||||
str << ftop / fUnitValue;
|
|
||||||
Window()->Lock();
|
|
||||||
fTop->SetText(str.String());
|
|
||||||
Window()->Unlock();
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
if (msg == BOTTOM_MARGIN_CHANGED) {
|
|
||||||
// bottom must be <= pageHeight
|
|
||||||
if (fbottom > (ph - ftop)) {
|
|
||||||
fbottom = ph - ftop;
|
|
||||||
str = "";
|
|
||||||
str << fbottom / fUnitValue;
|
|
||||||
Window()->Lock();
|
|
||||||
fBottom->SetText(str.String());
|
|
||||||
Window()->Unlock();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (msg == LEFT_MARGIN_CHANGED) {
|
|
||||||
// left must be <= right
|
|
||||||
if (fleft > (pw - fright)) {
|
|
||||||
fleft = pw - fright;
|
|
||||||
str = "";
|
|
||||||
str << fleft / fUnitValue;
|
|
||||||
Window()->Lock();
|
|
||||||
fLeft->SetText(str.String());
|
|
||||||
Window()->Unlock();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (msg == RIGHT_MARGIN_CHANGED) {
|
|
||||||
// right must be <= fPageWidth
|
|
||||||
if (fright > (pw - fleft)) {
|
|
||||||
fright = pw - fleft;
|
|
||||||
str = "";
|
|
||||||
str << fright / fUnitValue;
|
|
||||||
Window()->Lock();
|
|
||||||
fRight->SetText(str.String());
|
|
||||||
Window()->Unlock();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// convert the unit value to pixels
|
|
||||||
// ex: 14.4pt * 0.1px/pt = 1.44px
|
|
||||||
fMargins.top = ftop * pixelLength;
|
|
||||||
fMargins.right = fright * pixelLength;
|
|
||||||
fMargins.bottom = fbottom * pixelLength;
|
|
||||||
fMargins.left = fleft * pixelLength;
|
|
||||||
}
|
|
||||||
|
@ -15,6 +15,9 @@
|
|||||||
#include <Box.h>
|
#include <Box.h>
|
||||||
#include <Button.h>
|
#include <Button.h>
|
||||||
#include <Font.h>
|
#include <Font.h>
|
||||||
|
#include <GridView.h>
|
||||||
|
#include <GroupLayout.h>
|
||||||
|
#include <GroupLayoutBuilder.h>
|
||||||
#include <Looper.h>
|
#include <Looper.h>
|
||||||
#include <MessageFilter.h>
|
#include <MessageFilter.h>
|
||||||
#include <MenuField.h>
|
#include <MenuField.h>
|
||||||
@ -46,97 +49,6 @@ using namespace std;
|
|||||||
#define std
|
#define std
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define MENU_HEIGHT 16
|
|
||||||
#define MENU_WIDTH 200
|
|
||||||
#define BUTTON_WIDTH 70
|
|
||||||
#define BUTTON_HEIGHT 20
|
|
||||||
#define TEXT_HEIGHT 16
|
|
||||||
|
|
||||||
#define MARGIN_H 10
|
|
||||||
#define MARGIN_V 10
|
|
||||||
#define MARGIN_WIDTH 180
|
|
||||||
#define MARGIN_HEIGHT 140
|
|
||||||
|
|
||||||
#define PAGESETUP_WIDTH MARGIN_H + MARGIN_WIDTH + 15 + MENU_WIDTH + 10
|
|
||||||
#define PAGESETUP_HEIGHT MARGIN_V + MARGIN_HEIGHT + BUTTON_HEIGHT + 20
|
|
||||||
|
|
||||||
#define PAPER_H MARGIN_H + MARGIN_WIDTH + 15
|
|
||||||
#define PAPER_V 10
|
|
||||||
#define PAPER_WIDTH MENU_WIDTH
|
|
||||||
#define PAPER_HEIGHT MENU_HEIGHT
|
|
||||||
#define PAPER_TEXT "Paper Size:"
|
|
||||||
|
|
||||||
#define ORIENT_H PAPER_H
|
|
||||||
#define ORIENT_V PAPER_V + 24
|
|
||||||
#define ORIENT_WIDTH MENU_WIDTH
|
|
||||||
#define ORIENT_HEIGHT MENU_HEIGHT
|
|
||||||
#define ORIENTATION_TEXT "Orientation:"
|
|
||||||
#define PORTRAIT_TEXT "Portrait"
|
|
||||||
#define LANDSCAPE_TEXT "Landscape"
|
|
||||||
|
|
||||||
#define RES_H PAPER_H
|
|
||||||
#define RES_V ORIENT_V + 24
|
|
||||||
#define RES_WIDTH MENU_WIDTH
|
|
||||||
#define RES_HEIGHT MENU_HEIGHT
|
|
||||||
#define RES_TEXT "Resolution:"
|
|
||||||
|
|
||||||
#define SCALE_H PAPER_H
|
|
||||||
#define SCALE_V RES_V + 24
|
|
||||||
#define SCALE_WIDTH 100
|
|
||||||
#define SCALE_HEIGHT TEXT_HEIGHT
|
|
||||||
#define SCALE_TEXT "Scale [%]:"
|
|
||||||
|
|
||||||
#define OK_H (PAGESETUP_WIDTH - BUTTON_WIDTH - 11)
|
|
||||||
#define OK_V (PAGESETUP_HEIGHT - BUTTON_HEIGHT - 11)
|
|
||||||
#define OK_TEXT "OK"
|
|
||||||
|
|
||||||
#define CANCEL_H (OK_H - BUTTON_WIDTH - 12)
|
|
||||||
#define CANCEL_V OK_V
|
|
||||||
#define CANCEL_TEXT "Cancel"
|
|
||||||
|
|
||||||
#define PRINT_LINE_V (PAGESETUP_HEIGHT - BUTTON_HEIGHT - 23)
|
|
||||||
|
|
||||||
const BRect MARGIN_RECT(
|
|
||||||
MARGIN_H,
|
|
||||||
MARGIN_V,
|
|
||||||
MARGIN_H + MARGIN_WIDTH,
|
|
||||||
MARGIN_V + MARGIN_HEIGHT);
|
|
||||||
|
|
||||||
const BRect ORIENTATION_RECT(
|
|
||||||
ORIENT_H,
|
|
||||||
ORIENT_V,
|
|
||||||
ORIENT_H + ORIENT_WIDTH,
|
|
||||||
ORIENT_V + ORIENT_HEIGHT);
|
|
||||||
|
|
||||||
const BRect PAPER_RECT(
|
|
||||||
PAPER_H,
|
|
||||||
PAPER_V,
|
|
||||||
PAPER_H + PAPER_WIDTH,
|
|
||||||
PAPER_V + PAPER_HEIGHT);
|
|
||||||
|
|
||||||
const BRect RESOLUTION_RECT(
|
|
||||||
RES_H,
|
|
||||||
RES_V,
|
|
||||||
RES_H + RES_WIDTH,
|
|
||||||
RES_V + RES_HEIGHT);
|
|
||||||
|
|
||||||
const BRect SCALE_RECT(
|
|
||||||
SCALE_H,
|
|
||||||
SCALE_V,
|
|
||||||
SCALE_H + SCALE_WIDTH,
|
|
||||||
SCALE_V + SCALE_HEIGHT);
|
|
||||||
|
|
||||||
const BRect OK_RECT(
|
|
||||||
OK_H,
|
|
||||||
OK_V,
|
|
||||||
OK_H + BUTTON_WIDTH,
|
|
||||||
OK_V + BUTTON_HEIGHT);
|
|
||||||
|
|
||||||
const BRect CANCEL_RECT(
|
|
||||||
CANCEL_H,
|
|
||||||
CANCEL_V,
|
|
||||||
CANCEL_H + BUTTON_WIDTH,
|
|
||||||
CANCEL_V + BUTTON_HEIGHT);
|
|
||||||
|
|
||||||
enum MSGS {
|
enum MSGS {
|
||||||
kMsgCancel = 1,
|
kMsgCancel = 1,
|
||||||
@ -145,8 +57,12 @@ enum MSGS {
|
|||||||
kMsgPaperChanged,
|
kMsgPaperChanged,
|
||||||
};
|
};
|
||||||
|
|
||||||
PageSetupView::PageSetupView(BRect frame, JobData *job_data, PrinterData *printer_data, const PrinterCap *printer_cap)
|
PageSetupView::PageSetupView(JobData *job_data, PrinterData *printer_data,
|
||||||
: BView(frame, "", B_FOLLOW_ALL, B_WILL_DRAW), fJobData(job_data), fPrinterData(printer_data), fPrinterCap(printer_cap)
|
const PrinterCap *printer_cap)
|
||||||
|
: BView("pageSetupView", B_WILL_DRAW)
|
||||||
|
, fJobData(job_data)
|
||||||
|
, fPrinterData(printer_data)
|
||||||
|
, fPrinterCap(printer_cap)
|
||||||
{
|
{
|
||||||
SetViewColor(ui_color(B_PANEL_BACKGROUND_COLOR));
|
SetViewColor(ui_color(B_PANEL_BACKGROUND_COLOR));
|
||||||
}
|
}
|
||||||
@ -175,12 +91,10 @@ void
|
|||||||
PageSetupView::AttachedToWindow()
|
PageSetupView::AttachedToWindow()
|
||||||
{
|
{
|
||||||
BMenuItem *item = NULL;
|
BMenuItem *item = NULL;
|
||||||
BMenuField *menuField;
|
|
||||||
BButton *button;
|
|
||||||
bool marked;
|
bool marked;
|
||||||
int count;
|
int count;
|
||||||
|
|
||||||
/* margin */
|
// margin
|
||||||
MarginUnit units = fJobData->getMarginUnit();
|
MarginUnit units = fJobData->getMarginUnit();
|
||||||
BRect paper = fJobData->getPaperRect();
|
BRect paper = fJobData->getPaperRect();
|
||||||
BRect margin = fJobData->getPrintableRect();
|
BRect margin = fJobData->getPrintableRect();
|
||||||
@ -191,16 +105,14 @@ PageSetupView::AttachedToWindow()
|
|||||||
margin.right = paper.right - margin.right;
|
margin.right = paper.right - margin.right;
|
||||||
margin.bottom = paper.bottom - margin.bottom;
|
margin.bottom = paper.bottom - margin.bottom;
|
||||||
|
|
||||||
fMarginView = new MarginView(MARGIN_RECT,
|
fMarginView = new MarginView(
|
||||||
paper.IntegerWidth(),
|
paper.IntegerWidth(),
|
||||||
paper.IntegerHeight(),
|
paper.IntegerHeight(),
|
||||||
margin, units);
|
margin, units);
|
||||||
AddChild(fMarginView);
|
|
||||||
|
|
||||||
/* paper selection */
|
|
||||||
|
|
||||||
|
// paper selection
|
||||||
marked = false;
|
marked = false;
|
||||||
fPaper = new BPopUpMenu("");
|
fPaper = new BPopUpMenu("paperSize");
|
||||||
fPaper->SetRadioMode(true);
|
fPaper->SetRadioMode(true);
|
||||||
count = fPrinterCap->countCap(PrinterCap::kPaper);
|
count = fPrinterCap->countCap(PrinterCap::kPaper);
|
||||||
PaperCap **paper_cap = (PaperCap **)fPrinterCap->enumCap(PrinterCap::kPaper);
|
PaperCap **paper_cap = (PaperCap **)fPrinterCap->enumCap(PrinterCap::kPaper);
|
||||||
@ -218,22 +130,18 @@ PageSetupView::AttachedToWindow()
|
|||||||
}
|
}
|
||||||
if (!marked)
|
if (!marked)
|
||||||
item->SetMarked(true);
|
item->SetMarked(true);
|
||||||
menuField = new BMenuField(PAPER_RECT, "", PAPER_TEXT, fPaper);
|
BMenuField* paperSize = new BMenuField("paperSize", "Paper Size:", fPaper);
|
||||||
AddChild(menuField);
|
|
||||||
float width = StringWidth(PAPER_TEXT) + 7;
|
|
||||||
menuField->SetDivider(width);
|
|
||||||
|
|
||||||
/* orientaion */
|
// orientation
|
||||||
fOrientation = new BPopUpMenu("orientation");
|
fOrientation = new BPopUpMenu("orientation");
|
||||||
fOrientation->SetRadioMode(true);
|
fOrientation->SetRadioMode(true);
|
||||||
|
|
||||||
menuField = new BMenuField(ORIENTATION_RECT, "orientation", ORIENTATION_TEXT, fOrientation);
|
BMenuField* orientation = new BMenuField("orientation", "Orientation:", fOrientation);
|
||||||
menuField->SetDivider(width);
|
|
||||||
|
|
||||||
count = fPrinterCap->countCap(PrinterCap::kOrientation);
|
count = fPrinterCap->countCap(PrinterCap::kOrientation);
|
||||||
if (count == 0) {
|
if (count == 0) {
|
||||||
AddOrientationItem(PORTRAIT_TEXT, JobData::kPortrait);
|
AddOrientationItem("Portrait", JobData::kPortrait);
|
||||||
AddOrientationItem(LANDSCAPE_TEXT, JobData::kLandscape);
|
AddOrientationItem("Landscape", JobData::kLandscape);
|
||||||
} else {
|
} else {
|
||||||
OrientationCap **orientation_cap = (OrientationCap **)fPrinterCap->enumCap(PrinterCap::kOrientation);
|
OrientationCap **orientation_cap = (OrientationCap **)fPrinterCap->enumCap(PrinterCap::kOrientation);
|
||||||
while (count--) {
|
while (count--) {
|
||||||
@ -243,12 +151,9 @@ PageSetupView::AttachedToWindow()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
AddChild(menuField);
|
// resolution
|
||||||
|
|
||||||
/* resolution */
|
|
||||||
|
|
||||||
marked = false;
|
marked = false;
|
||||||
fResolution = new BPopUpMenu("");
|
fResolution = new BPopUpMenu("resolution");
|
||||||
fResolution->SetRadioMode(true);
|
fResolution->SetRadioMode(true);
|
||||||
count = fPrinterCap->countCap(PrinterCap::kResolution);
|
count = fPrinterCap->countCap(PrinterCap::kResolution);
|
||||||
ResolutionCap **resolution_cap = (ResolutionCap **)fPrinterCap->enumCap(PrinterCap::kResolution);
|
ResolutionCap **resolution_cap = (ResolutionCap **)fPrinterCap->enumCap(PrinterCap::kResolution);
|
||||||
@ -264,16 +169,14 @@ PageSetupView::AttachedToWindow()
|
|||||||
}
|
}
|
||||||
if (!marked)
|
if (!marked)
|
||||||
item->SetMarked(true);
|
item->SetMarked(true);
|
||||||
menuField = new BMenuField(RESOLUTION_RECT, "", RES_TEXT, fResolution);
|
BMenuField* resolution = new BMenuField("resolution", "Resolution:", fResolution);
|
||||||
AddChild(menuField);
|
|
||||||
menuField->SetDivider(width);
|
|
||||||
|
|
||||||
/* scale */
|
// scale
|
||||||
BString scale;
|
BString scale;
|
||||||
scale << (int)fJobData->getScaling();
|
scale << (int)fJobData->getScaling();
|
||||||
fScaling = new BTextControl(SCALE_RECT, "scale", "Scale [%]:",
|
fScaling = new BTextControl("scale", "Scale [%]:",
|
||||||
scale.String(),
|
scale.String(),
|
||||||
NULL, B_FOLLOW_RIGHT);
|
NULL);
|
||||||
int num;
|
int num;
|
||||||
for (num = 0; num <= 255; num++) {
|
for (num = 0; num <= 255; num++) {
|
||||||
fScaling->TextView()->DisallowChar(num);
|
fScaling->TextView()->DisallowChar(num);
|
||||||
@ -282,20 +185,44 @@ PageSetupView::AttachedToWindow()
|
|||||||
fScaling->TextView()->AllowChar('0' + num);
|
fScaling->TextView()->AllowChar('0' + num);
|
||||||
}
|
}
|
||||||
fScaling->TextView()->SetMaxBytes(3);
|
fScaling->TextView()->SetMaxBytes(3);
|
||||||
fScaling->SetDivider(width);
|
|
||||||
|
|
||||||
AddChild(fScaling);
|
// cancel and ok
|
||||||
|
BButton* cancel = new BButton("cancel", "Cancel", new BMessage(kMsgCancel));
|
||||||
|
BButton* ok = new BButton("ok", "OK", new BMessage(kMsgOK));
|
||||||
|
|
||||||
/* cancel */
|
ok->MakeDefault(true);
|
||||||
|
|
||||||
button = new BButton(CANCEL_RECT, "", CANCEL_TEXT, new BMessage(kMsgCancel));
|
BGridView* settings = new BGridView();
|
||||||
AddChild(button);
|
BGridLayout* settingsLayout = settings->GridLayout();
|
||||||
|
settingsLayout->AddItem(paperSize->CreateLabelLayoutItem(), 0, 0);
|
||||||
|
settingsLayout->AddItem(paperSize->CreateMenuBarLayoutItem(), 1, 0);
|
||||||
|
settingsLayout->AddItem(orientation->CreateLabelLayoutItem(), 0, 1);
|
||||||
|
settingsLayout->AddItem(orientation->CreateMenuBarLayoutItem(), 1, 1);
|
||||||
|
settingsLayout->AddItem(resolution->CreateLabelLayoutItem(), 0, 2);
|
||||||
|
settingsLayout->AddItem(resolution->CreateMenuBarLayoutItem(), 1, 2);
|
||||||
|
settingsLayout->AddItem(fScaling->CreateLabelLayoutItem(), 0, 3);
|
||||||
|
settingsLayout->AddItem(fScaling->CreateTextViewLayoutItem(), 1, 3);
|
||||||
|
settingsLayout->SetSpacing(0, 0);
|
||||||
|
|
||||||
/* ok */
|
SetLayout(new BGroupLayout(B_VERTICAL));
|
||||||
|
AddChild(BGroupLayoutBuilder(B_VERTICAL, 0)
|
||||||
button = new BButton(OK_RECT, "", OK_TEXT, new BMessage(kMsgOK));
|
.AddGroup(B_HORIZONTAL, 5, 1.0f)
|
||||||
AddChild(button);
|
.AddGroup(B_VERTICAL, 0, 1.0f)
|
||||||
button->MakeDefault(true);
|
.Add(fMarginView)
|
||||||
|
.AddGlue()
|
||||||
|
.End()
|
||||||
|
.AddGroup(B_VERTICAL, 0, 1.0f)
|
||||||
|
.Add(settings)
|
||||||
|
.AddGlue()
|
||||||
|
.End()
|
||||||
|
.End()
|
||||||
|
.AddGroup(B_HORIZONTAL, 10, 1.0f)
|
||||||
|
.AddGlue()
|
||||||
|
.Add(cancel)
|
||||||
|
.Add(ok)
|
||||||
|
.End()
|
||||||
|
.SetInsets(10, 10, 10, 10)
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void
|
inline void
|
||||||
@ -424,15 +351,22 @@ PageSetupView::MessageReceived(BMessage *msg)
|
|||||||
|
|
||||||
//====================================================================
|
//====================================================================
|
||||||
|
|
||||||
|
// TODO center window on screen
|
||||||
PageSetupDlg::PageSetupDlg(JobData *job_data, PrinterData *printer_data, const PrinterCap *printer_cap)
|
PageSetupDlg::PageSetupDlg(JobData *job_data, PrinterData *printer_data, const PrinterCap *printer_cap)
|
||||||
: DialogWindow(BRect(100, 100, 100 + PAGESETUP_WIDTH, 100 + PAGESETUP_HEIGHT),
|
: DialogWindow(BRect(100, 100, 160, 160),
|
||||||
"Page Setup", B_TITLED_WINDOW_LOOK, B_MODAL_APP_WINDOW_FEEL,
|
"Page Setup", B_TITLED_WINDOW_LOOK, B_MODAL_APP_WINDOW_FEEL,
|
||||||
B_NOT_RESIZABLE | B_NOT_MINIMIZABLE | B_NOT_ZOOMABLE)
|
B_NOT_RESIZABLE | B_NOT_MINIMIZABLE | B_NOT_ZOOMABLE
|
||||||
|
| B_AUTO_UPDATE_SIZE_LIMITS)
|
||||||
{
|
{
|
||||||
AddShortcut('W',B_COMMAND_KEY,new BMessage(B_QUIT_REQUESTED));
|
AddShortcut('W',B_COMMAND_KEY,new BMessage(B_QUIT_REQUESTED));
|
||||||
|
|
||||||
PageSetupView *view = new PageSetupView(Bounds(), job_data, printer_data, printer_cap);
|
fPageSetupView = new PageSetupView(job_data, printer_data,
|
||||||
AddChild(view);
|
printer_cap);
|
||||||
|
|
||||||
|
SetLayout(new BGroupLayout(B_HORIZONTAL));
|
||||||
|
AddChild(BGroupLayoutBuilder(B_HORIZONTAL, 0)
|
||||||
|
.Add(fPageSetupView)
|
||||||
|
);
|
||||||
|
|
||||||
SetResult(B_ERROR);
|
SetResult(B_ERROR);
|
||||||
}
|
}
|
||||||
@ -443,7 +377,7 @@ PageSetupDlg::MessageReceived(BMessage *msg)
|
|||||||
switch (msg->what) {
|
switch (msg->what) {
|
||||||
case kMsgOK:
|
case kMsgOK:
|
||||||
Lock();
|
Lock();
|
||||||
((PageSetupView *)ChildAt(0))->UpdateJobData();
|
fPageSetupView->UpdateJobData();
|
||||||
Unlock();
|
Unlock();
|
||||||
SetResult(B_NO_ERROR);
|
SetResult(B_NO_ERROR);
|
||||||
PostMessage(B_QUIT_REQUESTED);
|
PostMessage(B_QUIT_REQUESTED);
|
||||||
|
@ -22,8 +22,8 @@
|
|||||||
StatusWindow::StatusWindow(bool oddPages, bool evenPages, uint32 firstPage, uint32 numPages, uint32 numCopies, uint32 nup)
|
StatusWindow::StatusWindow(bool oddPages, bool evenPages, uint32 firstPage, uint32 numPages, uint32 numCopies, uint32 nup)
|
||||||
: BWindow (BRect(200, 200, 650, 270), "Print Status", B_DOCUMENT_WINDOW, B_NOT_RESIZABLE | B_NOT_CLOSABLE | B_NOT_ZOOMABLE)
|
: BWindow (BRect(200, 200, 650, 270), "Print Status", B_DOCUMENT_WINDOW, B_NOT_RESIZABLE | B_NOT_CLOSABLE | B_NOT_ZOOMABLE)
|
||||||
{
|
{
|
||||||
// oddPages - if true, only print odd umbered pages
|
// oddPages - if true, only print odd numbered pages
|
||||||
// evenPages - if true, only print even umbered pages
|
// evenPages - if true, only print even numbered pages
|
||||||
// firstPage - number of first page
|
// firstPage - number of first page
|
||||||
// numPages - total number of pages (must be recalculate if odd/even is used)
|
// numPages - total number of pages (must be recalculate if odd/even is used)
|
||||||
// numCopies - total number of document copies
|
// numCopies - total number of document copies
|
||||||
|
@ -117,14 +117,16 @@ LeftAlign(BView* view)
|
|||||||
{
|
{
|
||||||
return BGroupLayoutBuilder(B_HORIZONTAL)
|
return BGroupLayoutBuilder(B_HORIZONTAL)
|
||||||
.Add(view)
|
.Add(view)
|
||||||
.AddGlue();
|
.AddGlue()
|
||||||
|
.SetInsets(0, 0, 0, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
ConfigWindow::ConfigWindow(config_setup_kind kind, Printer* defaultPrinter,
|
ConfigWindow::ConfigWindow(config_setup_kind kind, Printer* defaultPrinter,
|
||||||
BMessage* settings, AutoReply* sender)
|
BMessage* settings, AutoReply* sender)
|
||||||
:
|
:
|
||||||
BWindow(ConfigWindow::GetWindowFrame(), B_TRANSLATE("Page setup"),
|
BWindow(ConfigWindow::GetWindowFrame(),
|
||||||
|
B_TRANSLATE("Page setup"),
|
||||||
B_TITLED_WINDOW,
|
B_TITLED_WINDOW,
|
||||||
B_NOT_RESIZABLE | B_NOT_ZOOMABLE | B_AUTO_UPDATE_SIZE_LIMITS),
|
B_NOT_RESIZABLE | B_NOT_ZOOMABLE | B_AUTO_UPDATE_SIZE_LIMITS),
|
||||||
fKind(kind),
|
fKind(kind),
|
||||||
@ -174,8 +176,7 @@ ConfigWindow::ConfigWindow(config_setup_kind kind, Printer* defaultPrinter,
|
|||||||
}
|
}
|
||||||
|
|
||||||
// separator line
|
// separator line
|
||||||
BBox* separator = new BBox(dummyRect, "line",
|
BBox* separator = new BBox("separator");
|
||||||
B_FOLLOW_LEFT_RIGHT | B_FOLLOW_TOP);
|
|
||||||
separator->SetExplicitMaxSize(BSize(B_SIZE_UNLIMITED, 1));
|
separator->SetExplicitMaxSize(BSize(B_SIZE_UNLIMITED, 1));
|
||||||
|
|
||||||
// Cancel & OK button
|
// Cancel & OK button
|
||||||
@ -191,41 +192,36 @@ ConfigWindow::ConfigWindow(config_setup_kind kind, Printer* defaultPrinter,
|
|||||||
|
|
||||||
builder
|
builder
|
||||||
.Add(fPrinters)
|
.Add(fPrinters)
|
||||||
.AddStrut(5)
|
.Add(BGroupLayoutBuilder(B_HORIZONTAL, 10)
|
||||||
.Add(BGroupLayoutBuilder(B_HORIZONTAL)
|
|
||||||
.Add(fPageSetup)
|
.Add(fPageSetup)
|
||||||
.AddStrut(5)
|
.Add(BGroupLayoutBuilder(B_VERTICAL, 0)
|
||||||
.Add(BGroupLayoutBuilder(B_VERTICAL)
|
|
||||||
.Add(LeftAlign(pageFormatTitle))
|
.Add(LeftAlign(pageFormatTitle))
|
||||||
.Add(LeftAlign(fPageFormatText))
|
.Add(LeftAlign(fPageFormatText))
|
||||||
|
.SetInsets(0, 0, 0, 0)
|
||||||
)
|
)
|
||||||
.AddGlue()
|
.AddGlue()
|
||||||
);
|
);
|
||||||
|
|
||||||
if (fJobSetup != NULL) {
|
if (fJobSetup != NULL) {
|
||||||
builder
|
builder
|
||||||
.AddStrut(5)
|
.Add(BGroupLayoutBuilder(B_HORIZONTAL, 10)
|
||||||
.Add(BGroupLayoutBuilder(B_HORIZONTAL)
|
|
||||||
.Add(fJobSetup)
|
.Add(fJobSetup)
|
||||||
.AddStrut(5)
|
.Add(BGroupLayoutBuilder(B_VERTICAL, 0)
|
||||||
.Add(BGroupLayoutBuilder(B_VERTICAL)
|
|
||||||
.Add(LeftAlign(jobSetupTitle))
|
.Add(LeftAlign(jobSetupTitle))
|
||||||
.Add(LeftAlign(fJobSetupText))
|
.Add(LeftAlign(fJobSetupText))
|
||||||
|
.SetInsets(0, 0, 0, 0)
|
||||||
)
|
)
|
||||||
.AddGlue()
|
.AddGlue()
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
builder
|
builder
|
||||||
.AddStrut(5)
|
.AddGlue()
|
||||||
.Add(separator)
|
.Add(separator)
|
||||||
.AddStrut(5)
|
|
||||||
.Add(BGroupLayoutBuilder(B_HORIZONTAL)
|
.Add(BGroupLayoutBuilder(B_HORIZONTAL)
|
||||||
.AddGlue()
|
.AddGlue()
|
||||||
.Add(cancel)
|
.Add(cancel)
|
||||||
.AddStrut(5)
|
|
||||||
.Add(fOk)
|
.Add(fOk)
|
||||||
.AddGlue()
|
|
||||||
)
|
)
|
||||||
.SetInsets(5, 5, 5, 5);
|
.SetInsets(5, 5, 5, 5);
|
||||||
|
|
||||||
@ -328,11 +324,13 @@ ConfigWindow::FrameMoved(BPoint p)
|
|||||||
BRect
|
BRect
|
||||||
ConfigWindow::GetWindowFrame()
|
ConfigWindow::GetWindowFrame()
|
||||||
{
|
{
|
||||||
|
BRect frame(0, 0, 10, 10);
|
||||||
BAutolock lock(gLock);
|
BAutolock lock(gLock);
|
||||||
if (lock.IsLocked())
|
if (lock.IsLocked())
|
||||||
return Settings::GetSettings()->ConfigWindowFrame();
|
frame.OffsetBy(Settings::GetSettings()->ConfigWindowFrame().LeftTop());
|
||||||
|
|
||||||
return BRect(30, 30, 300, 300);
|
frame.OffsetBy(30, 30);
|
||||||
|
return frame;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user