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

View File

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

View File

@ -56,6 +56,7 @@ class PreviewView : public BView {
float ZoomFactor() const;
BRect PageRect() const;
BRect PrintableRect() const;
public:
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 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
{
private:
@ -151,5 +159,4 @@ public:
inline float scale(float f) { return fScale * f; }
};
#endif