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:
parent
034a4d2e0d
commit
43a3d8de3f
@ -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);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -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();
|
||||
}
|
||||
|
||||
|
@ -56,6 +56,7 @@ class PreviewView : public BView {
|
||||
|
||||
float ZoomFactor() const;
|
||||
BRect PageRect() const;
|
||||
BRect PrintableRect() const;
|
||||
|
||||
public:
|
||||
PreviewView(BFile* jobFile, BRect rect);
|
||||
|
@ -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;
|
||||
}
|
@ -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
|
||||
|
Loading…
Reference in New Issue
Block a user