* make use of libprint inbuild Preview class

git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@26821 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
Karsten Heimrich 2008-08-05 20:39:11 +00:00
parent 8169e6b4e6
commit 1c08970124
6 changed files with 15 additions and 937 deletions

View File

@ -10,10 +10,9 @@ Addon Preview :
PageSetupWindow.cpp PageSetupWindow.cpp
JobSetupWindow.cpp JobSetupWindow.cpp
Driver.cpp Driver.cpp
Preview.cpp
PrinterDriver.cpp PrinterDriver.cpp
PreviewDriver.cpp PreviewDriver.cpp
: be libprint.a : be libprint.a $(TARGET_LIBSTDC++)
; ;
Package haiku-printingkit-cvs : Package haiku-printingkit-cvs :

View File

@ -1,778 +0,0 @@
/*
* Copyright 2002-2008, Haiku. All rights reserved.
* Distributed under the terms of the MIT License.
*
* Authors:
* Michael Pfeiffer
* Hartmut Reh
* julun <host.haiku@gmx.de>
*/
#include "Preview.h"
#include "PrintUtils.h"
#include <stdlib.h>
#include <Application.h>
#include <Button.h>
#include <Debug.h>
#include <Region.h>
#include <Screen.h>
#include <String.h>
#include <ScrollView.h>
#include <StringView.h>
#include <TextControl.h>
// #pragma mark - PreviewPage
PreviewPage::PreviewPage(int32 page, PrintJobPage* pjp)
: fPage(page)
, fStatus(B_ERROR)
, fNumberOfPictures(0)
, fRects(NULL)
, fPoints(NULL)
, fPictures(NULL)
{
fNumberOfPictures = pjp->NumberOfPictures();
fRects = new BRect[fNumberOfPictures];
fPoints = new BPoint[fNumberOfPictures];
fPictures = new BPicture[fNumberOfPictures];
for (int32 i = 0; i < fNumberOfPictures; ++i) {
fStatus = pjp->NextPicture(fPictures[i], fPoints[i], fRects[i]);
if (fStatus != B_OK)
break;
}
}
PreviewPage::~PreviewPage()
{
delete [] fRects;
delete [] fPoints;
delete [] fPictures;
}
status_t
PreviewPage::InitCheck() const
{
return fStatus;
}
void
PreviewPage::Draw(BView* view, const BRect& printRect)
{
ASSERT(fStatus == B_OK);
for (int32 i = 0; i < fNumberOfPictures; i++)
view->DrawPicture(&fPictures[i], printRect.LeftTop() + fPoints[i]);
}
// #pragma mark - PreviewView
const float kPreviewTopMargin = 10;
const float kPreviewBottomMargin = 30;
const float kPreviewLeftMargin = 10;
const float kPreviewRightMargin = 30;
const uint8 ZOOM_IN[] = { 16, 1, 6, 6, 0, 0, 15, 128, 48, 96, 32, 32, 66, 16,
66, 16, 79, 144, 66, 16, 66, 16, 32, 32, 48, 112, 15, 184, 0, 28, 0, 14, 0,
6, 0, 0, 15, 128, 63, 224, 127, 240, 127, 240, 255, 248, 255, 248, 255, 248,
255, 248, 255, 248, 127, 248, 127, 248, 63, 252, 15, 254, 0, 31, 0, 15, 0, 7 };
const uint8 ZOOM_OUT[] = { 16, 1, 6, 6, 0, 0, 15, 128, 48, 96, 32, 32, 64, 16,
64, 16, 79, 144, 64, 16, 64, 16, 32, 32, 48, 112, 15, 184, 0, 28, 0, 14, 0,
6, 0, 0, 15, 128, 63, 224, 127, 240, 127, 240, 255, 248, 255, 248, 255, 248,
255, 248, 255, 248, 127, 248, 127, 248, 63, 252, 15, 254, 0, 31, 0, 15, 0, 7 };
PreviewView::PreviewView(BFile* jobFile, BRect rect)
: BView(rect, "PreviewView", B_FOLLOW_ALL, B_WILL_DRAW | B_FRAME_EVENTS |
B_NAVIGABLE | B_SUBPIXEL_PRECISE)
, fPage(0)
, fZoom(0)
, fTracking(false)
, fInsideView(true)
, fReader(jobFile)
, fCachedPage(NULL)
{
}
PreviewView::~PreviewView() {
delete fCachedPage;
}
void
PreviewView::Show()
{
BView::Show();
be_app->SetCursor(ZOOM_IN);
}
void
PreviewView::Draw(BRect rect)
{
if (fReader.InitCheck() == B_OK) {
if (!_IsPageLoaded(fPage))
_LoadPage(fPage);
if (_IsPageValid()) {
_DrawPageFrame(rect);
_DrawPage(rect);
_DrawMarginFrame(rect);
}
}
}
void
PreviewView::FrameResized(float width, float height)
{
Invalidate();
FixScrollbars();
}
void
PreviewView::MouseDown(BPoint point)
{
MakeFocus(true);
BMessage *message = Window()->CurrentMessage();
int32 button;
if (message && message->FindInt32("buttons", &button) == B_OK) {
if (button == B_PRIMARY_MOUSE_BUTTON) {
int32 modifier;
if (message->FindInt32("modifiers", &modifier) == B_OK) {
if (modifier & B_SHIFT_KEY)
ZoomOut();
else
ZoomIn();
}
}
if (button == B_SECONDARY_MOUSE_BUTTON) {
fTracking = true;
be_app->SetCursor(B_HAND_CURSOR);
SetMouseEventMask(B_POINTER_EVENTS,
B_LOCK_WINDOW_FOCUS | B_NO_POINTER_HISTORY);
fScrollStart = Bounds().LeftTop() + ConvertToScreen(point);
}
}
}
void
PreviewView::MouseMoved(BPoint point, uint32 transit, const BMessage* message)
{
if (fTracking) {
uint32 button;
GetMouse(&point, &button, false);
point = fScrollStart - ConvertToScreen(point);
float hMin, hMax;
BScrollBar *hBar = ScrollBar(B_HORIZONTAL);
hBar->GetRange(&hMin, &hMax);
float vMin, vMax;
BScrollBar *vBar = ScrollBar(B_VERTICAL);
vBar->GetRange(&vMin, &vMax);
if (point.x < 0.0) point.x = 0.0;
if (point.y < 0.0) point.y = 0.0;
if (point.x > hMax) point.x = hMax;
if (point.y > vMax) point.y = vMax;
ScrollTo(point);
} else {
switch (transit) {
case B_ENTERED_VIEW: {
fInsideView = true;
be_app->SetCursor(ZOOM_IN);
} break;
case B_EXITED_VIEW: {
fInsideView = false;
be_app->SetCursor(B_HAND_CURSOR);
} break;
default: {
if (modifiers() & B_SHIFT_KEY)
be_app->SetCursor(ZOOM_OUT);
else
be_app->SetCursor(ZOOM_IN);
} break;
}
}
}
void
PreviewView::MouseUp(BPoint point)
{
(void)point;
fTracking = false;
fScrollStart.Set(0.0, 0.0);
if (fInsideView && ((modifiers() & B_SHIFT_KEY) == 0))
be_app->SetCursor(ZOOM_IN);
}
void
PreviewView::KeyDown(const char* bytes, int32 numBytes)
{
MakeFocus(true);
switch (bytes[0]) {
case '-': {
if (modifiers() & B_CONTROL_KEY)
ZoomOut();
} break;
case '+' : {
if (modifiers() & B_CONTROL_KEY)
ZoomIn();
} break;
default: {
BView::KeyDown(bytes, numBytes);
} break;
}
}
void
PreviewView::ShowFirstPage()
{
if (!ShowsFirstPage()) {
fPage = 0;
Invalidate();
}
}
void
PreviewView::ShowPrevPage()
{
if (!ShowsFirstPage()) {
fPage--;
Invalidate();
}
}
void
PreviewView::ShowNextPage()
{
if (!ShowsLastPage()) {
fPage++;
Invalidate();
}
}
void
PreviewView::ShowLastPage()
{
if (!ShowsLastPage()) {
fPage = NumberOfPages()-1;
Invalidate();
}
}
bool
PreviewView::ShowsFirstPage() const
{
return fPage == 0;
}
bool
PreviewView::ShowsLastPage() const
{
return fPage == NumberOfPages() - 1;
}
void
PreviewView::ShowFindPage(int32 page)
{
page--;
if (page < 0) {
page = 0;
} else if (page > (NumberOfPages()-1)) {
page = NumberOfPages()-1;
}
fPage = (int32)page;
Invalidate();
}
void
PreviewView::ZoomIn()
{
if (CanZoomIn()) {
fZoom++;
FixScrollbars();
Invalidate();
}
}
bool
PreviewView::CanZoomIn() const
{
return fZoom < 4;
}
void
PreviewView::ZoomOut()
{
if (CanZoomOut()) {
fZoom--;
FixScrollbars();
Invalidate();
}
}
bool
PreviewView::CanZoomOut() const
{
return fZoom > -2;
}
void
PreviewView::FixScrollbars()
{
float width = _PageRect().Width() + kPreviewLeftMargin + kPreviewRightMargin;
float height = _PageRect().Height() + kPreviewTopMargin + kPreviewBottomMargin;
BRect frame(Bounds());
float x = width - frame.Width();
if (x < 0.0)
x = 0.0;
float y = height - frame.Height();
if (y < 0.0)
y = 0.0;
BScrollBar * scroll = ScrollBar(B_HORIZONTAL);
scroll->SetRange(0.0, x);
scroll->SetProportion((width - x) / width);
float bigStep = frame.Width() - 2;
float smallStep = bigStep / 10.;
scroll->SetSteps(smallStep, bigStep);
scroll = ScrollBar(B_VERTICAL);
scroll->SetRange(0.0, y);
scroll->SetProportion((height - y) / height);
bigStep = frame.Height() - 2;
smallStep = bigStep / 10.;
scroll->SetSteps(smallStep, bigStep);
}
BRect
PreviewView::ViewRect() const
{
BRect r(_PageRect());
r.right += kPreviewLeftMargin + kPreviewRightMargin;
r.bottom += kPreviewTopMargin + kPreviewBottomMargin;
return r;
}
status_t
PreviewView::InitCheck() const
{
return fReader.InitCheck();
}
int32
PreviewView::NumberOfPages() const
{
return fReader.NumberOfPages();
}
BRect
PreviewView::_PageRect() const
{
float f = _ZoomFactor();
BRect r = fReader.PaperRect();
return ScaleRect(r, f);
}
// returns 2 ^ fZoom
float
PreviewView::_ZoomFactor() const
{
const int32 b = 4;
int32 zoom;
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::_PrintableRect() const
{
float f = _ZoomFactor();
BRect r = fReader.PrintableRect();
return ScaleRect(r, f);
}
bool
PreviewView::_IsPageValid() const
{
return fCachedPage && fCachedPage->InitCheck() == B_OK;
}
void
PreviewView::_LoadPage(int32 page)
{
delete fCachedPage;
fCachedPage = NULL;
PrintJobPage pjp;
if (fReader.GetPage(page, pjp) == B_OK)
fCachedPage = new PreviewPage(page, &pjp);
}
bool
PreviewView::_IsPageLoaded(int32 page) const
{
return fCachedPage != NULL && fCachedPage->Page() == page;
}
BRect
PreviewView::_ContentRect() const
{
float offsetX = kPreviewLeftMargin;
float offsetY = kPreviewTopMargin;
BRect rect = Bounds();
BRect paperRect = _PageRect();
float min, max;
ScrollBar(B_HORIZONTAL)->GetRange(&min, &max);
if (min == max) {
if ((paperRect.right + 2 * offsetX) < rect.right)
offsetX = (rect.right - (paperRect.right + 2 * offsetX)) / 2;
}
ScrollBar(B_VERTICAL)->GetRange(&min, &max);
if (min == max) {
if ((paperRect.bottom + 2 * offsetY) < rect.bottom)
offsetY = (rect.bottom - (paperRect.bottom + 2 * offsetY)) / 2;
}
paperRect.OffsetTo(offsetX, offsetY);
return paperRect;
}
void
PreviewView::_DrawPageFrame(BRect rect)
{
const float kShadowIndent = 3;
const float kShadowWidth = 3;
rgb_color frameColor = { 0, 0, 0, 0 };
rgb_color shadowColor = { 90, 90, 90, 0 };
PushState();
// draw page border around page
BRect r(_ContentRect().InsetByCopy(-1, -1));
SetHighColor(frameColor);
StrokeRect(r);
// draw page shadow
SetHighColor(shadowColor);
float x = r.right + 1;
float right = x + kShadowWidth;
float bottom = r.bottom + 1 + kShadowWidth;
float y = r.top + kShadowIndent;
FillRect(BRect(x, y, right, bottom));
x = r.left + kShadowIndent;
y = r.bottom + 1;
FillRect(BRect(x, y, r.right, bottom));
PopState();
}
BRect
ScaleDown(BRect rect, float factor)
{
rect.left /= factor;
rect.top /= factor;
rect.right /= factor;
rect.bottom /= factor;
return rect;
}
void
PreviewView::_DrawPage(BRect rect)
{
BRect printRect(_PrintableRect());
printRect.OffsetBy(_ContentRect().LeftTop());
printRect = ScaleDown(printRect, _ZoomFactor());
BRegion clip(printRect);
ConstrainClippingRegion(&clip);
SetScale(_ZoomFactor());
fCachedPage->Draw(this, printRect);
SetScale(1.0);
ConstrainClippingRegion(NULL);
}
void
PreviewView::_DrawMarginFrame(BRect rect)
{
BRect paperRect(_ContentRect());
BRect printRect(_PrintableRect());
printRect.OffsetBy(paperRect.LeftTop());
BeginLineArray(4);
SetHighColor(ui_color(B_PANEL_BACKGROUND_COLOR));
StrokeLine(BPoint(printRect.left, paperRect.top),
BPoint(printRect.left, paperRect.bottom), B_MIXED_COLORS);
StrokeLine(BPoint(printRect.right, paperRect.top),
BPoint(printRect.right, paperRect.bottom), B_MIXED_COLORS);
StrokeLine(BPoint(paperRect.left, printRect.top),
BPoint(paperRect.right, printRect.top), B_MIXED_COLORS);
StrokeLine(BPoint(paperRect.left, printRect.bottom),
BPoint(paperRect.right, printRect.bottom), B_MIXED_COLORS);
EndLineArray();
}
// #pragma mark - PreviewWindow
PreviewWindow::PreviewWindow(BFile* jobFile)
: BlockingWindow(BRect(20, 24, 400, 600), "Preview", B_DOCUMENT_WINDOW,
B_ASYNCHRONOUS_CONTROLS)
, fButtonBarHeight(0.0)
{
BRect bounds(Bounds());
bounds.OffsetBy(10.0, 10.0);
fFirst = new BButton(bounds, "first", "First Page", new BMessage(MSG_FIRST_PAGE));
AddChild(fFirst);
fFirst->ResizeToPreferred();
bounds.OffsetBy(fFirst->Bounds().Width() + 10.0, 0.0);
fPrev = new BButton(bounds, "previous", "Previous Page", new BMessage(MSG_PREV_PAGE));
AddChild(fPrev);
fPrev->ResizeToPreferred();
bounds.OffsetBy(fPrev->Bounds().Width() + 10.0, 0.0);
fNext = new BButton(bounds, "next", "Next Page", new BMessage(MSG_NEXT_PAGE));
AddChild(fNext);
fNext->ResizeToPreferred();
bounds.OffsetBy(fNext->Bounds().Width() + 10.0, 0.0);
fLast = new BButton(bounds, "last", "Last Page", new BMessage(MSG_LAST_PAGE));
AddChild(fLast);
fLast->ResizeToPreferred();
bounds = fLast->Frame();
bounds.OffsetBy(fLast->Bounds().Width() + 10.0, 0.0);
fPageNumber = new BTextControl(bounds, "numOfPage", "99", "",
new BMessage(MSG_FIND_PAGE));
AddChild(fPageNumber);
fPageNumber->ResizeToPreferred();
fPageNumber->SetDivider(0.0);
fPageNumber->SetAlignment(B_ALIGN_RIGHT, B_ALIGN_RIGHT);
fPageNumber->MoveBy(0.0, bounds.Height() - fPageNumber->Bounds().Height());
uint32 num;
for (num = 0; num <= 255; num++)
fPageNumber->TextView()->DisallowChar(num);
for (num = 0; num <= 9; num++)
fPageNumber->TextView()->AllowChar('0' + num);
fPageNumber->TextView()-> SetMaxBytes(5);
bounds.OffsetBy(fPageNumber->Bounds().Width() + 5.0, 0.0);
fPageText = new BStringView(bounds, "pageText", "");
AddChild(fPageText);
fPageText->ResizeTo(fPageText->StringWidth("of 99999 Pages"),
fFirst->Bounds().Height());
bounds.OffsetBy(fPageText->Bounds().Width() + 10.0, 0.0);
fZoomIn = new BButton(bounds, "zoomIn", "Zoom In", new BMessage(MSG_ZOOM_IN));
AddChild(fZoomIn);
fZoomIn->ResizeToPreferred();
bounds.OffsetBy(fZoomIn->Bounds().Width() + 10.0, 0.0);
fZoomOut = new BButton(bounds, "ZoomOut", "Zoom Out", new BMessage(MSG_ZOOM_OUT));
AddChild(fZoomOut);
fZoomOut->ResizeToPreferred();
fButtonBarHeight = fZoomOut->Frame().bottom + 10.0;
bounds = Bounds();
bounds.top = fButtonBarHeight;
bounds.right -= B_V_SCROLL_BAR_WIDTH;
bounds.bottom -= B_H_SCROLL_BAR_HEIGHT;
fPreview = new PreviewView(jobFile, bounds);
fPreviewScroller = new BScrollView("PreviewScroller", fPreview, B_FOLLOW_ALL,
B_FRAME_EVENTS, true, true, B_FANCY_BORDER);
fPreviewScroller->SetViewColor(ui_color(B_PANEL_BACKGROUND_COLOR));
AddChild(fPreviewScroller);
if (fPreview->InitCheck() == B_OK) {
_ResizeToPage();
fPreview->FixScrollbars();
_UpdateControls();
fPreview->MakeFocus(true);
}
}
void
PreviewWindow::MessageReceived(BMessage* m)
{
switch (m->what) {
case MSG_FIRST_PAGE:
fPreview->ShowFirstPage();
break;
case MSG_NEXT_PAGE:
fPreview->ShowNextPage();
break;
case MSG_PREV_PAGE:
fPreview->ShowPrevPage();
break;
case MSG_LAST_PAGE:
fPreview->ShowLastPage();
break;
case MSG_FIND_PAGE:
fPreview->ShowFindPage(atoi(fPageNumber->Text())) ;
break;
case MSG_ZOOM_IN:
fPreview->ZoomIn();
break;
case MSG_ZOOM_OUT:
fPreview->ZoomOut();
break;
case B_MODIFIERS_CHANGED:
fPreview->MouseMoved(BPoint(), B_INSIDE_VIEW, m);
break;
default:
BlockingWindow::MessageReceived(m);
return;
}
_UpdateControls();
}
status_t
PreviewWindow::Go()
{
status_t st = InitCheck();
if (st == B_OK)
return BlockingWindow::Go();
Quit();
return st;
}
void
PreviewWindow::_ResizeToPage()
{
BScreen screen;
if (screen.Frame().right == 0.0)
return;
const float windowBorderWidth = 5;
const float windowBorderHeight = 5;
BRect rect(fPreview->ViewRect());
float width = rect.Width() + 1 + B_V_SCROLL_BAR_WIDTH;
float height = rect.Height() + 1 + fButtonBarHeight + B_H_SCROLL_BAR_HEIGHT;
rect = screen.Frame();
// dimensions so that window does not reach outside of screen
float maxWidth = rect.Width() + 1 - windowBorderWidth - Frame().left;
float maxHeight = rect.Height() + 1 - windowBorderHeight - Frame().top;
// width so that all buttons are visible
float minWidth = fZoomOut->Frame().right + 10;
if (width < minWidth) width = minWidth;
if (width > maxWidth) width = maxWidth;
if (height > maxHeight) height = maxHeight;
ResizeTo(width, height);
}
void
PreviewWindow::_UpdateControls()
{
fFirst->SetEnabled(!fPreview->ShowsFirstPage());
fPrev->SetEnabled(!fPreview->ShowsFirstPage());
fNext->SetEnabled(!fPreview->ShowsLastPage());
fLast->SetEnabled(!fPreview->ShowsLastPage());
fZoomIn->SetEnabled(fPreview->CanZoomIn());
fZoomOut->SetEnabled(fPreview->CanZoomOut());
BString text;
text << fPreview->CurrentPage();
fPageNumber->SetText(text.String());
text.SetTo("of ");
text << fPreview->NumberOfPages() << " Page";
if (fPreview->NumberOfPages() > 1)
text.Append("s");
fPageText->SetText(text.String());
}

View File

@ -1,149 +0,0 @@
/*
* Copyright 2002-2008, Haiku. All rights reserved.
* Distributed under the terms of the MIT License.
*
* Authors:
* Michael Pfeiffer
* Hartmut Reh
* julun <host.haiku@gmx.de>
*/
#include "BlockingWindow.h"
#include "PrintJobReader.h"
#include <View.h>
class BButton;
class BFile;
class BMessage;
class BPicture;
class BScrollView;
class BStringView;
class BTextControl;
// #pragma mark - PreviewPage
class PreviewPage {
public:
PreviewPage(int32 page, PrintJobPage* pjp);
~PreviewPage();
void Draw(BView* view, const BRect& printRect);
status_t InitCheck() const;
int32 Page() const { return fPage; }
private:
int32 fPage;
status_t fStatus;
int32 fNumberOfPictures;
BRect* fRects;
BPoint* fPoints;
BPicture* fPictures;
};
// #pragma mark - PreviewView
class PreviewView : public BView {
public:
PreviewView(BFile* jobFile, BRect rect);
~PreviewView();
virtual void Show();
virtual void Draw(BRect r);
virtual void FrameResized(float width, float height);
virtual void MouseDown(BPoint point);
virtual void MouseMoved(BPoint point, uint32 transit,
const BMessage* message);
virtual void MouseUp(BPoint point);
virtual void KeyDown(const char* bytes, int32 numBytes);
void ShowFirstPage();
void ShowPrevPage();
void ShowNextPage();
void ShowLastPage();
bool ShowsFirstPage() const;
bool ShowsLastPage() const;
void ShowFindPage(int32 page);
void ZoomIn();
bool CanZoomIn() const;
void ZoomOut();
bool CanZoomOut() const;
void FixScrollbars();
BRect ViewRect() const;
status_t InitCheck() const;
int32 NumberOfPages() const;
int32 CurrentPage() const { return fPage + 1; }
private:
BRect _PageRect() const;
float _ZoomFactor() const;
BRect _PrintableRect() const;
void _LoadPage(int32 page);
bool _IsPageValid() const;
bool _IsPageLoaded(int32 page) const;
BRect _ContentRect() const;
void _DrawPageFrame(BRect rect);
void _DrawPage(BRect updateRect);
void _DrawMarginFrame(BRect rect);
private:
int32 fPage;
int32 fZoom;
bool fTracking;
bool fInsideView;
BPoint fScrollStart;
PrintJobReader fReader;
PreviewPage* fCachedPage;
};
// #pragma mark - PreviewWindow
class PreviewWindow : public BlockingWindow {
public:
PreviewWindow(BFile* jobFile);
virtual void MessageReceived(BMessage* m);
status_t Go();
status_t InitCheck() const { return fPreview->InitCheck(); }
private:
void _ResizeToPage();
void _UpdateControls();
private:
BButton* fFirst;
BButton* fNext;
BButton* fPrev;
BButton* fLast;
BButton* fZoomIn;
BButton* fZoomOut;
BTextControl* fPageNumber;
BStringView* fPageText;
PreviewView* fPreview;
BScrollView* fPreviewScroller;
float fButtonBarHeight;
enum {
MSG_FIRST_PAGE = 'pwfp',
MSG_NEXT_PAGE = 'pwnp',
MSG_PREV_PAGE = 'pwpp',
MSG_LAST_PAGE = 'pwlp',
MSG_FIND_PAGE = 'pwsp',
MSG_ZOOM_IN = 'pwzi',
MSG_ZOOM_OUT = 'pwzo',
};
};

View File

@ -7,6 +7,7 @@
*/ */
#include "PreviewDriver.h" #include "PreviewDriver.h"
#include "Preview.h"
#define PREVIEW_DRIVER_DEBUG 0 #define PREVIEW_DRIVER_DEBUG 0

View File

@ -6,9 +6,9 @@
* Michael Pfeiffer * Michael Pfeiffer
*/ */
#include "Preview.h"
#include "PrinterDriver.h" #include "PrinterDriver.h"
class PreviewDriver : public PrinterDriver { class PreviewDriver : public PrinterDriver {
public: public:
PreviewDriver(BNode* spoolDir); PreviewDriver(BNode* spoolDir);

View File

@ -212,8 +212,13 @@ PreviewView::PreviewView(BFile* jobFile, BRect rect)
if (fReader.JobSettings()->FindInt32(kJDPageSelection, &value32) == B_OK) if (fReader.JobSettings()->FindInt32(kJDPageSelection, &value32) == B_OK)
fPageSelection = (JobData::PageSelection)value32; fPageSelection = (JobData::PageSelection)value32;
fReader.JobSettings()->FindInt32(kJDNup, &fNumberOfPagesPerPage); bool value;
fReader.JobSettings()->FindBool(kJDReverse, &fReverse); if (fReader.JobSettings()->FindBool(kJDReverse, &value) == B_OK)
fReverse = value;
if (fReader.JobSettings()->FindInt32(kJDNup, &value32) == B_OK)
fNumberOfPagesPerPage = value32;
fNumberOfPages = (fReader.NumberOfPages() + fNumberOfPagesPerPage - 1) fNumberOfPages = (fReader.NumberOfPages() + fNumberOfPagesPerPage - 1)
/ fNumberOfPagesPerPage; / fNumberOfPagesPerPage;