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
|
// 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);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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);
|
||||||
|
@ -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 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
|
||||||
|
Loading…
Reference in New Issue
Block a user