Changed the scaling ability to mimic the scaling behaviour of the Epson printer driver.

git-svn-id: file:///srv/svn/repos/haiku/trunk/current@10614 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
Michael Pfeiffer 2005-01-08 09:12:12 +00:00
parent 034a4d2e0d
commit 43a3d8de3f
5 changed files with 83 additions and 49 deletions

View File

@ -116,10 +116,9 @@ PageSetupWindow::PageSetupWindow(BMessage *msg, const char *printerName)
// load orientation // load orientation
fSetupMsg->FindInt32("orientation", &orient); fSetupMsg->FindInt32("orientation", &orient);
// (new BAlert("", "orientation not in msg", "Shit"))->Go();
// load page rect // load page rect
if (fSetupMsg->FindRect("paper_rect", &r) == B_OK) { if (fSetupMsg->FindRect("preview:paper_rect", &r) == B_OK) {
width = r.Width(); width = r.Width();
height = r.Height(); height = r.Height();
page = r; page = r;
@ -142,7 +141,7 @@ PageSetupWindow::PageSetupWindow(BMessage *msg, const char *printerName)
// re-calculate the margin from the printable rect in points // re-calculate the margin from the printable rect in points
margin = page; margin = page;
if (fSetupMsg->FindRect("printable_rect", &margin) == B_OK) { if (fSetupMsg->FindRect("preview:printable_rect", &margin) == B_OK) {
margin.top -= page.top; margin.top -= page.top;
margin.left -= page.left; margin.left -= page.left;
margin.right = page.right - margin.right; margin.right = page.right - margin.right;
@ -238,7 +237,7 @@ PageSetupWindow::PageSetupWindow(BMessage *msg, const char *printerName)
BString scale; BString scale;
float scale0; float scale0;
if (fSetupMsg->FindFloat("scale", &scale0) == B_OK) { if (fSetupMsg->FindFloat("scale", &scale0) == B_OK) {
scale << (int)(100.0 * scale0); scale << (int)scale0;
} else { } else {
scale = "100"; scale = "100";
} }
@ -295,13 +294,18 @@ PageSetupWindow::UpdateSetupMessage()
if (item) { if (item) {
BMessage *msg = item->Message(); BMessage *msg = item->Message();
msg->FindInt32("orientation", &orientation); msg->FindInt32("orientation", &orientation);
if (fSetupMsg->HasInt32("orientation", orientation)) { SetInt32(fSetupMsg, "orientation", orientation);
fSetupMsg->ReplaceInt32("orientation", orientation);
} else {
fSetupMsg->AddInt32("orientation", orientation);
}
} }
// Save scaling factor
float scale = atoi(fScaleControl->Text());
if (scale <= 0.0) { // sanity check
scale = 100.0;
}
SetFloat(fSetupMsg, "scale", scale);
float scaleR = 100.0 / scale;
item = fPageSizeMenu->Menu()->FindMarked(); item = fPageSizeMenu->Menu()->FindMarked();
if (item) { if (item) {
float w, h; float w, h;
@ -309,15 +313,13 @@ PageSetupWindow::UpdateSetupMessage()
msg->FindFloat("width", &w); msg->FindFloat("width", &w);
msg->FindFloat("height", &h); msg->FindFloat("height", &h);
BRect r; BRect r;
if (orientation == 0) if (orientation == 0) {
r.Set(0, 0, w, h); r.Set(0, 0, w, h);
else
r.Set(0, 0, h, w);
if (fSetupMsg->HasRect("paper_rect")) {
fSetupMsg->ReplaceRect("paper_rect", r);
} else { } else {
fSetupMsg->AddRect("paper_rect", r); r.Set(0, 0, h, w);
} }
SetRect(fSetupMsg, "preview:paper_rect", r);
SetRect(fSetupMsg, "paper_rect", ScaleRect(r, scaleR));
// Save the printable_rect // Save the printable_rect
BRect margin = fMarginView->GetMargin(); BRect margin = fMarginView->GetMargin();
@ -328,30 +330,12 @@ PageSetupWindow::UpdateSetupMessage()
margin.right = h - margin.right; margin.right = h - margin.right;
margin.bottom = w - margin.bottom; margin.bottom = w - margin.bottom;
} }
if (fSetupMsg->HasRect("printable_rect")) { SetRect(fSetupMsg, "preview:printable_rect", margin);
fSetupMsg->ReplaceRect("printable_rect", margin); SetRect(fSetupMsg, "printable_rect", ScaleRect(margin, scaleR));
} else {
fSetupMsg->AddRect("printable_rect", margin);
}
// save the units used // save the units used
int32 units = fMarginView->GetUnits(); int32 units = fMarginView->GetUnits();
if (fSetupMsg->HasInt32("units")) { SetInt32(fSetupMsg, "units", units);
fSetupMsg->ReplaceInt32("units", units);
} else {
fSetupMsg->AddInt32("units", units);
}
}
// scaling factor
float scale = atoi(fScaleControl->Text()) / 100.0;
if (scale <= 0.0) { // sanity check
scale = 1.0;
}
if (fSetupMsg->HasFloat("scale")) {
fSetupMsg->ReplaceFloat("scale", scale);
} else {
fSetupMsg->AddFloat("scale", scale);
} }
} }

View File

@ -29,6 +29,7 @@ THE SOFTWARE.
#include <Debug.h> #include <Debug.h>
#include <String.h> #include <String.h>
#include "Utils.h"
#include "Preview.h" #include "Preview.h"
@ -92,16 +93,25 @@ PreviewView::~PreviewView() {
float PreviewView::ZoomFactor() const { float PreviewView::ZoomFactor() const {
const int32 b = 4; const int32 b = 4;
int32 zoom; int32 zoom;
if (fZoom > 0) zoom = (1 << b) << fZoom; if (fZoom > 0) {
else zoom = (1 << b) >> -fZoom; zoom = (1 << b) << fZoom;
return zoom / (float)(1 << b); } else {
zoom = (1 << b) >> -fZoom;
}
float factor = zoom / (float)(1 << b);
return factor * fReader.GetScale() / 100.0;
} }
BRect PreviewView::PageRect() const { BRect PreviewView::PageRect() const {
float f = ZoomFactor(); float f = ZoomFactor();
BRect r = fReader.PaperRect(); BRect r = fReader.PaperRect();
r.left *= f; r.right *= f; r.top *= f; r.bottom *= f; return ScaleRect(r, f);
return r; }
BRect PreviewView::PrintableRect() const {
float f = ZoomFactor();
BRect r = fReader.PrintableRect();
return ScaleRect(r, f);
} }
BRect PreviewView::ViewRect() const { BRect PreviewView::ViewRect() const {
@ -166,8 +176,8 @@ void PreviewView::DrawPageFrame(BRect rect) {
void PreviewView::DrawPage(BRect rect) void PreviewView::DrawPage(BRect rect)
{ {
// constrain clipping region to paper dimensions // constrain clipping region to printable rectangle
BRect r(PageRect()); BRect r(PrintableRect());
r.OffsetBy(kPreviewLeftMargin, kPreviewTopMargin); r.OffsetBy(kPreviewLeftMargin, kPreviewTopMargin);
BRegion clip(r); BRegion clip(r);
ConstrainClippingRegion(&clip); ConstrainClippingRegion(&clip);
@ -177,11 +187,13 @@ void PreviewView::DrawPage(BRect rect)
// print job coordinates are relative to the printable rect // print job coordinates are relative to the printable rect
BRect printRect = fReader.PrintableRect(); BRect printRect = fReader.PrintableRect();
SetOrigin(kPreviewLeftMargin + printRect.left*ZoomFactor(), SetOrigin(kPreviewLeftMargin + printRect.left * ZoomFactor(),
kPreviewTopMargin + printRect.top*ZoomFactor() ); kPreviewTopMargin + printRect.top * ZoomFactor());
SetScale(ZoomFactor());
SetScale(ZoomFactor() * fReader.GetScale());
fCachedPage->Draw(this); fCachedPage->Draw(this);
PopState(); PopState();
} }

View File

@ -56,6 +56,7 @@ class PreviewView : public BView {
float ZoomFactor() const; float ZoomFactor() const;
BRect PageRect() const; BRect PageRect() const;
BRect PrintableRect() const;
public: public:
PreviewView(BFile* jobFile, BRect rect); PreviewView(BFile* jobFile, BRect rect);

View File

@ -104,4 +104,34 @@ void AddString(BMessage* m, const char* name, const char* value) {
} }
} }
void SetRect(BMessage* msg, const char* name, BRect rect) {
if (msg->HasRect(name)) {
msg->ReplaceRect(name, rect);
} else {
msg->AddRect(name, rect);
}
}
void SetFloat(BMessage* msg, const char* name, float value) {
if (msg->HasFloat(name)) {
msg->ReplaceFloat(name, value);
} else {
msg->AddFloat(name, value);
}
}
void SetInt32(BMessage* msg, const char* name, int32 value) {
if (msg->HasInt32(name)) {
msg->ReplaceInt32(name, value);
} else {
msg->AddInt32(name, value);
}
}
BRect ScaleRect(BRect rect, float scale) {
rect.left *= scale;
rect.right *= scale;
rect.top *= scale;
rect.bottom *= scale;
return rect;
}

View File

@ -41,6 +41,14 @@ THE SOFTWARE.
void AddFields(BMessage* to, const BMessage* from, const char* excludeList[] = NULL, const char* includeList[] = NULL); void AddFields(BMessage* to, const BMessage* from, const char* excludeList[] = NULL, const char* includeList[] = NULL);
void AddString(BMessage* m, const char* name, const char* value); void AddString(BMessage* m, const char* name, const char* value);
// set or replace a value in a BMessage
void SetRect(BMessage* msg, const char* name, BRect rect);
void SetFloat(BMessage* msg, const char* name, float value);
void SetInt32(BMessage* msg, const char* name, int32 value);
// scalar multiplication
BRect ScaleRect(BRect rect, float scale);
class EscapeMessageFilter : public BMessageFilter class EscapeMessageFilter : public BMessageFilter
{ {
private: private:
@ -151,5 +159,4 @@ public:
inline float scale(float f) { return fScale * f; } inline float scale(float f) { return fScale * f; }
}; };
#endif #endif