[Libreoffice-commits] core.git: extensions/source extensions/uiconfig extras/source
Caolán McNamara
caolanm at redhat.com
Wed Jun 11 06:28:41 PDT 2014
extensions/source/scanner/sanedlg.cxx | 288 ++++++++++++++++---------
extensions/source/scanner/sanedlg.hrc | 31 --
extensions/source/scanner/sanedlg.hxx | 29 --
extensions/uiconfig/scanner/ui/sanedialog.ui | 4
extras/source/glade/libreoffice-catalog.xml.in | 4
5 files changed, 205 insertions(+), 151 deletions(-)
New commits:
commit d6eeb8a48903488a8d09948173af5845e2f3b729
Author: Caolán McNamara <caolanm at redhat.com>
Date: Wed Jun 11 13:42:45 2014 +0100
extract Scan Preview code into a preview widget
instead of scribbling over the parent dialog directly. Doing is this way allows
the .ui-ification to work right.
Change-Id: Ia0c33eae4cd5a4c94896436fe5a5afad8d60a577
diff --git a/extensions/source/scanner/sanedlg.cxx b/extensions/source/scanner/sanedlg.cxx
index 1ccfa51..4a83424 100644
--- a/extensions/source/scanner/sanedlg.cxx
+++ b/extensions/source/scanner/sanedlg.cxx
@@ -21,9 +21,9 @@
#include <stdlib.h>
#include <tools/config.hxx>
#include <vcl/dibtools.hxx>
+#include <vcl/layout.hxx>
#include <vcl/msgbox.hxx>
#include <sanedlg.hxx>
-#include <sanedlg.hrc>
#include <grid.hxx>
#include <math.h>
#include <sal/macros.h>
@@ -36,15 +36,128 @@ ResId SaneResId( sal_uInt32 nID )
return ResId( nID, *pResMgr );
}
+#define PREVIEW_WIDTH 113
+#define PREVIEW_HEIGHT 160
+
+class ScanPreview : public Window
+{
+private:
+ enum DragDirection { TopLeft, Top, TopRight, Right, BottomRight, Bottom,
+ BottomLeft, Left };
+
+ Bitmap maPreviewBitmap;
+ Rectangle maPreviewRect;
+ Point maTopLeft, maBottomRight;
+ Point maMinTopLeft, maMaxBottomRight;
+ SaneDlg* mpParentDialog;
+ DragDirection meDragDirection;
+ bool mbDragEnable;
+ bool mbDragDrawn;
+ bool mbIsDragging;
+
+ void DrawRectangles(Point& rUL, Point& rBR);
+public:
+ ScanPreview(Window* pParent, WinBits nStyle)
+ : Window(pParent, nStyle)
+ , maMaxBottomRight(PREVIEW_WIDTH, PREVIEW_HEIGHT)
+ , mpParentDialog(NULL)
+ , meDragDirection(TopLeft)
+ , mbDragEnable(false)
+ , mbDragDrawn(false)
+ , mbIsDragging(false)
+ {
+ }
+ void Init(SaneDlg *pParent)
+ {
+ mpParentDialog = pParent;
+ }
+ void EnableDrag() { mbDragEnable = true; }
+ void DisableDrag() { mbDragEnable = false; }
+ bool IsDragEnabled() { return mbDragEnable; }
+ virtual void Paint(const Rectangle& rRect) SAL_OVERRIDE;
+ virtual void MouseButtonDown(const MouseEvent& rMEvt) SAL_OVERRIDE;
+ virtual void MouseMove(const MouseEvent& rMEvt) SAL_OVERRIDE;
+ virtual void MouseButtonUp(const MouseEvent& rMEvt) SAL_OVERRIDE;
+ Point GetPixelPos(const Point& rIn) const;
+ Point GetLogicPos(const Point& rIn) const;
+ void GetPreviewLogicRect(Point& rTopLeft, Point &rBottomRight) const
+ {
+ rTopLeft = GetLogicPos(maTopLeft);
+ rBottomRight = GetLogicPos(maBottomRight);
+ }
+ void GetMaxLogicRect(Point& rTopLeft, Point &rBottomRight) const
+ {
+ rTopLeft = maMinTopLeft;
+ rBottomRight = maMaxBottomRight;
+
+ }
+ void ChangePreviewLogicTopLeftY(long Y)
+ {
+ Point aPoint(0, Y);
+ aPoint = GetPixelPos(aPoint);
+ maTopLeft.Y() = aPoint.Y();
+ }
+ void ChangePreviewLogicTopLeftX(long X)
+ {
+ Point aPoint(X, 0);
+ aPoint = GetPixelPos(aPoint);
+ maTopLeft.X() = aPoint.X();
+ }
+ void ChangePreviewLogicBottomRightY(long Y)
+ {
+ Point aPoint(0, Y);
+ aPoint = GetPixelPos(aPoint);
+ maBottomRight.Y() = aPoint.Y();
+ }
+ void ChangePreviewLogicBottomRightX(long X)
+ {
+ Point aPoint(X, 0);
+ aPoint = GetPixelPos(aPoint);
+ maBottomRight.X() = aPoint.X();
+ }
+ void SetPreviewLogicRect(const Point& rTopLeft, const Point &rBottomRight)
+ {
+ maTopLeft = GetPixelPos(rTopLeft);
+ maBottomRight = GetPixelPos(rBottomRight);
+ maPreviewRect = Rectangle( maTopLeft,
+ Size( maBottomRight.X() - maTopLeft.X(),
+ maBottomRight.Y() - maTopLeft.Y() )
+ );
+ }
+ void SetPreviewMaxRect(const Point& rTopLeft, const Point &rBottomRight)
+ {
+ maMinTopLeft = rTopLeft;
+ maMaxBottomRight = rBottomRight;
+ }
+ void DrawDrag();
+ void UpdatePreviewBounds();
+ void SetBitmap(SvStream &rStream)
+ {
+ ReadDIB(maPreviewBitmap, rStream, true);
+ }
+ virtual Size GetOptimalSize() const SAL_OVERRIDE
+ {
+ Size aSize(LogicToPixel(Size(PREVIEW_WIDTH, PREVIEW_HEIGHT), MAP_APPFONT));
+ aSize.setWidth(aSize.getWidth()+1);
+ aSize.setHeight(aSize.getHeight()+1);
+ return aSize;
+ }
+};
+
+extern "C" SAL_DLLPUBLIC_EXPORT Window* SAL_CALL makeScanPreview(Window *pParent, VclBuilder::stringmap &rMap)
+{
+ WinBits nWinStyle = 0;
+ OString sBorder = VclBuilder::extractCustomProperty(rMap);
+ if (!sBorder.isEmpty())
+ nWinStyle |= WB_BORDER;
+ ScanPreview *pWindow = new ScanPreview(pParent, nWinStyle);
+ return pWindow;
+}
+
SaneDlg::SaneDlg( Window* pParent, Sane& rSane, bool bScanEnabled ) :
ModalDialog(pParent, "SaneDialog", "modules/scanner/ui/sanedialog.ui"),
mrSane( rSane ),
- mbDragEnable( false ),
- mbIsDragging( false ),
mbScanEnabled( bScanEnabled ),
- mbDragDrawn( false ),
- meDragDirection( TopLeft ),
- maMapMode( MAP_APPFONT ),
mnCurrentOption(0),
mnCurrentElement(0),
mpRange(0),
@@ -82,9 +195,7 @@ SaneDlg::SaneDlg( Window* pParent, Sane& rSane, bool bScanEnabled ) :
mpOptionBox->set_height_request(aSize.Height());
get(mpBoolCheckBox, "boolCheckbutton");
get(mpPreview, "preview");
- aSize = LogicToPixel(Size(PREVIEW_WIDTH, PREVIEW_HEIGHT), MAP_APPFONT);
- mpPreview->set_width_request(aSize.Width());
- mpPreview->set_height_request(aSize.Height());
+ mpPreview->Init(this);
if( Sane::IsSane() )
{
InitDevices(); // opens first sane device
@@ -180,10 +291,12 @@ void SaneDlg::InitFields()
"preview"
};
- mbDragEnable = true;
+ mpPreview->EnableDrag();
mpReslBox->Clear();
- maMinTopLeft = Point( 0, 0 );
- maMaxBottomRight = Point( PREVIEW_WIDTH, PREVIEW_HEIGHT );
+ Point aTopLeft, aBottomRight;
+ mpPreview->GetPreviewLogicRect(aTopLeft, aBottomRight);
+ Point aMinTopLeft, aMaxBottomRight;
+ mpPreview->GetMaxLogicRect(aMinTopLeft, aMaxBottomRight);
mpScanButton->Show( mbScanEnabled );
if( ! mrSane.IsOpen() )
@@ -285,10 +398,10 @@ void SaneDlg::InitFields()
pField->SetCustomUnitText(OUString("Pixel"));
}
switch( i ) {
- case 0: maTopLeft.X() = (int)fValue;break;
- case 1: maTopLeft.Y() = (int)fValue;break;
- case 2: maBottomRight.X() = (int)fValue;break;
- case 3: maBottomRight.Y() = (int)fValue;break;
+ case 0: aTopLeft.X() = (int)fValue;break;
+ case 1: aTopLeft.Y() = (int)fValue;break;
+ case 2: aBottomRight.X() = (int)fValue;break;
+ case 3: aBottomRight.Y() = (int)fValue;break;
}
}
double *pDouble = NULL;
@@ -305,49 +418,49 @@ void SaneDlg::InitFields()
delete [] pDouble;
}
switch( i ) {
- case 0: maMinTopLeft.X() = pField->GetMin();break;
- case 1: maMinTopLeft.Y() = pField->GetMin();break;
- case 2: maMaxBottomRight.X() = pField->GetMax();break;
- case 3: maMaxBottomRight.Y() = pField->GetMax();break;
+ case 0: aMinTopLeft.X() = pField->GetMin();break;
+ case 1: aMinTopLeft.Y() = pField->GetMin();break;
+ case 2: aMaxBottomRight.X() = pField->GetMax();break;
+ case 3: aMaxBottomRight.Y() = pField->GetMax();break;
}
}
else
{
switch( i ) {
- case 0: maMinTopLeft.X() = (int)fValue;break;
- case 1: maMinTopLeft.Y() = (int)fValue;break;
- case 2: maMaxBottomRight.X() = (int)fValue;break;
- case 3: maMaxBottomRight.Y() = (int)fValue;break;
+ case 0: aMinTopLeft.X() = (int)fValue;break;
+ case 1: aMinTopLeft.Y() = (int)fValue;break;
+ case 2: aMaxBottomRight.X() = (int)fValue;break;
+ case 3: aMaxBottomRight.Y() = (int)fValue;break;
}
}
pField->Enable( true );
}
else
{
- mbDragEnable = false;
+ mpPreview->DisableDrag();
pField->SetMin( 0 );
switch( i ) {
case 0:
- maMinTopLeft.X() = 0;
- maTopLeft.X() = 0;
+ aMinTopLeft.X() = 0;
+ aTopLeft.X() = 0;
pField->SetMax( PREVIEW_WIDTH );
pField->SetValue( 0 );
break;
case 1:
- maMinTopLeft.Y() = 0;
- maTopLeft.Y() = 0;
+ aMinTopLeft.Y() = 0;
+ aTopLeft.Y() = 0;
pField->SetMax( PREVIEW_HEIGHT );
pField->SetValue( 0 );
break;
case 2:
- maMaxBottomRight.X() = PREVIEW_WIDTH;
- maBottomRight.X() = PREVIEW_WIDTH;
+ aMaxBottomRight.X() = PREVIEW_WIDTH;
+ aBottomRight.X() = PREVIEW_WIDTH;
pField->SetMax( PREVIEW_WIDTH );
pField->SetValue( PREVIEW_WIDTH );
break;
case 3:
- maMaxBottomRight.Y() = PREVIEW_HEIGHT;
- maBottomRight.Y() = PREVIEW_HEIGHT;
+ aMaxBottomRight.Y() = PREVIEW_HEIGHT;
+ aBottomRight.Y() = PREVIEW_HEIGHT;
pField->SetMax( PREVIEW_HEIGHT );
pField->SetValue( PREVIEW_HEIGHT );
break;
@@ -355,12 +468,11 @@ void SaneDlg::InitFields()
pField->Enable( false );
}
}
- maTopLeft = GetPixelPos( maTopLeft );
- maBottomRight = GetPixelPos( maBottomRight );
- maPreviewRect = Rectangle( maTopLeft,
- Size( maBottomRight.X() - maTopLeft.X(),
- maBottomRight.Y() - maTopLeft.Y() )
- );
+
+ mpPreview->SetPreviewMaxRect(aMinTopLeft, aMaxBottomRight);
+ mpPreview->SetPreviewLogicRect(aTopLeft, aBottomRight);
+ mpPreview->Invalidate();
+
// fill OptionBox
mpOptionBox->Clear();
SvTreeListEntry* pParentEntry = 0;
@@ -470,7 +582,7 @@ IMPL_LINK( SaneDlg, ClickBtnHdl, Button*, pButton )
{
double fRes = (double)mpReslBox->GetValue();
SetAdjustedNumericalValue( "resolution", fRes );
- UpdateScanArea( true );
+ UpdateScanArea(true);
SaveState();
EndDialog( mrSane.IsOpen() ? 1 : 0 );
doScan = (pButton == mpScanButton);
@@ -651,31 +763,23 @@ IMPL_LINK( SaneDlg, ModifyHdl, Edit*, pEdit )
}
else if( pEdit == mpTopField )
{
- Point aPoint( 0, mpTopField->GetValue() );
- aPoint = GetPixelPos( aPoint );
- maTopLeft.Y() = aPoint.Y();
- DrawDrag();
+ mpPreview->ChangePreviewLogicTopLeftY(mpTopField->GetValue());
+ mpPreview->DrawDrag();
}
else if( pEdit == mpLeftField )
{
- Point aPoint( mpLeftField->GetValue(), 0 );
- aPoint = GetPixelPos( aPoint );
- maTopLeft.X() = aPoint.X();
- DrawDrag();
+ mpPreview->ChangePreviewLogicTopLeftX(mpLeftField->GetValue());
+ mpPreview->DrawDrag();
}
else if( pEdit == mpBottomField )
{
- Point aPoint( 0, mpBottomField->GetValue() );
- aPoint = GetPixelPos( aPoint );
- maBottomRight.Y() = aPoint.Y();
- DrawDrag();
+ mpPreview->ChangePreviewLogicBottomRightY(mpBottomField->GetValue());
+ mpPreview->DrawDrag();
}
else if( pEdit == mpRightField )
{
- Point aPoint( mpRightField->GetValue(), 0 );
- aPoint = GetPixelPos( aPoint );
- maBottomRight.X() = aPoint.X();
- DrawDrag();
+ mpPreview->ChangePreviewLogicBottomRightX(mpRightField->GetValue());
+ mpPreview->DrawDrag();
}
}
return 0;
@@ -686,13 +790,8 @@ IMPL_LINK( SaneDlg, ReloadSaneOptionsHdl, Sane*, /*pSane*/ )
mnCurrentOption = -1;
mnCurrentElement = 0;
DisableOption();
- // #92024# preserve preview rect, should only be set
- // initially or in AcquirePreview
- Rectangle aPreviewRect = maPreviewRect;
InitFields();
- maPreviewRect = aPreviewRect;
- Rectangle aDummyRect( Point( 0, 0 ), GetSizePixel() );
- Paint( aDummyRect );
+ mpPreview->Invalidate();
return 0;
}
@@ -731,12 +830,18 @@ void SaneDlg::AcquirePreview()
fprintf( stderr, "Previewbitmapstream contains %d bytes\n", (int)aTransporter.getStream().Tell() );
#endif
aTransporter.getStream().Seek( STREAM_SEEK_TO_BEGIN );
- ReadDIB(maPreviewBitmap, aTransporter.getStream(), true);
+ mpPreview->SetBitmap(aTransporter.getStream());
}
SetAdjustedNumericalValue( "resolution", fResl );
mpReslBox->SetValue( (sal_uLong)fResl );
+ mpPreview->UpdatePreviewBounds();
+ mpPreview->Invalidate();
+}
+
+void ScanPreview::UpdatePreviewBounds()
+{
if( mbDragEnable )
{
maPreviewRect = Rectangle( maTopLeft,
@@ -762,16 +867,15 @@ void SaneDlg::AcquirePreview()
maBottomRight.Y() - maTopLeft.Y() ) );
}
}
-
- Paint( Rectangle( Point( 0, 0 ), GetSizePixel() ) );
}
-void SaneDlg::Paint( const Rectangle& rRect )
+void ScanPreview::Paint(const Rectangle& rRect)
{
- SetMapMode( maMapMode );
+ Window::Paint(rRect);
+ SetMapMode(MAP_APPFONT);
SetFillColor( Color( COL_WHITE ) );
SetLineColor( Color( COL_WHITE ) );
- DrawRect( Rectangle( Point( PREVIEW_UPPER_LEFT, PREVIEW_UPPER_TOP ),
+ DrawRect( Rectangle( Point( 0, 0 ),
Size( PREVIEW_WIDTH, PREVIEW_HEIGHT ) ) );
SetMapMode( MapMode( MAP_PIXEL ) );
// check for sane values
@@ -780,8 +884,6 @@ void SaneDlg::Paint( const Rectangle& rRect )
mbDragDrawn = false;
DrawDrag();
-
- ModalDialog::Paint( rRect );
}
void SaneDlg::DisableOption()
@@ -915,7 +1017,7 @@ void SaneDlg::EstablishButtonOption()
#define RECT_SIZE_PIX 7
-void SaneDlg::MouseMove( const MouseEvent& rMEvt )
+void ScanPreview::MouseMove(const MouseEvent& rMEvt)
{
if( mbIsDragging )
{
@@ -955,12 +1057,12 @@ void SaneDlg::MouseMove( const MouseEvent& rMEvt )
maBottomRight.Y() = nSwap;
}
DrawDrag();
- UpdateScanArea( false );
+ mpParentDialog->UpdateScanArea(false);
}
- ModalDialog::MouseMove( rMEvt );
+ Window::MouseMove( rMEvt );
}
-void SaneDlg::MouseButtonDown( const MouseEvent& rMEvt )
+void ScanPreview::MouseButtonDown( const MouseEvent& rMEvt )
{
Point aMousePixel = rMEvt.GetPosPixel();
@@ -1042,21 +1144,21 @@ void SaneDlg::MouseButtonDown( const MouseEvent& rMEvt )
SetPointerPosPixel( aMousePixel );
DrawDrag();
}
- ModalDialog::MouseButtonDown( rMEvt );
+ Window::MouseButtonDown( rMEvt );
}
-void SaneDlg::MouseButtonUp( const MouseEvent& rMEvt )
+void ScanPreview::MouseButtonUp( const MouseEvent& rMEvt )
{
if( mbIsDragging )
{
- UpdateScanArea( true );
+ mpParentDialog->UpdateScanArea(true);
}
mbIsDragging = false;
- ModalDialog::MouseButtonUp( rMEvt );
+ Window::MouseButtonUp( rMEvt );
}
-void SaneDlg::DrawRectangles( Point& rUL, Point& rBR )
+void ScanPreview::DrawRectangles( Point& rUL, Point& rBR )
{
int nMiddleX, nMiddleY;
Point aBL, aUR;
@@ -1080,7 +1182,7 @@ void SaneDlg::DrawRectangles( Point& rUL, Point& rBR )
DrawRect( Rectangle( Point( rBR.X(), nMiddleY - RECT_SIZE_PIX/2 ), Size( -RECT_SIZE_PIX, RECT_SIZE_PIX ) ) );
}
-void SaneDlg::DrawDrag()
+void ScanPreview::DrawDrag()
{
static Point aLastUL, aLastBR;
@@ -1100,27 +1202,25 @@ void SaneDlg::DrawDrag()
mbDragDrawn = true;
SetRasterOp( eROP );
- SetMapMode( maMapMode );
+ SetMapMode(MAP_APPFONT);
}
-Point SaneDlg::GetPixelPos( const Point& rIn )
+Point ScanPreview::GetPixelPos( const Point& rIn) const
{
Point aConvert(
( ( rIn.X() * PREVIEW_WIDTH ) /
( maMaxBottomRight.X() - maMinTopLeft.X() ) )
- + PREVIEW_UPPER_LEFT,
+ ,
( ( rIn.Y() * PREVIEW_HEIGHT )
/ ( maMaxBottomRight.Y() - maMinTopLeft.Y() ) )
- + PREVIEW_UPPER_TOP );
+ );
- return LogicToPixel( aConvert, maMapMode );
+ return LogicToPixel(aConvert, MAP_APPFONT);
}
-Point SaneDlg::GetLogicPos( const Point& rIn )
+Point ScanPreview::GetLogicPos(const Point& rIn) const
{
- Point aConvert = PixelToLogic( rIn, maMapMode );
- aConvert.X() -= PREVIEW_UPPER_LEFT;
- aConvert.Y() -= PREVIEW_UPPER_TOP;
+ Point aConvert = PixelToLogic(rIn, MAP_APPFONT);
if( aConvert.X() < 0 )
aConvert.X() = 0;
if( aConvert.X() >= PREVIEW_WIDTH )
@@ -1137,20 +1237,20 @@ Point SaneDlg::GetLogicPos( const Point& rIn )
return aConvert;
}
-void SaneDlg::UpdateScanArea( bool bSend )
+void SaneDlg::UpdateScanArea(bool bSend)
{
- if( ! mbDragEnable )
+ if (!mpPreview->IsDragEnabled())
return;
- Point aUL = GetLogicPos( maTopLeft );
- Point aBR = GetLogicPos( maBottomRight );
+ Point aUL, aBR;
+ mpPreview->GetPreviewLogicRect(aUL, aBR);
mpLeftField->SetValue( aUL.X() );
mpTopField->SetValue( aUL.Y() );
mpRightField->SetValue( aBR.X() );
mpBottomField->SetValue( aBR.Y() );
- if( ! bSend )
+ if (!bSend)
return;
if( mrSane.IsOpen() )
diff --git a/extensions/source/scanner/sanedlg.hrc b/extensions/source/scanner/sanedlg.hrc
deleted file mode 100644
index ebf2dbe..0000000
--- a/extensions/source/scanner/sanedlg.hrc
+++ /dev/null
@@ -1,31 +0,0 @@
-/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
-/*
- * This file is part of the LibreOffice project.
- *
- * This Source Code Form is subject to the terms of the Mozilla Public
- * License, v. 2.0. If a copy of the MPL was not distributed with this
- * file, You can obtain one at http://mozilla.org/MPL/2.0/.
- *
- * This file incorporates work covered by the following license notice:
- *
- * Licensed to the Apache Software Foundation (ASF) under one or more
- * contributor license agreements. See the NOTICE file distributed
- * with this work for additional information regarding copyright
- * ownership. The ASF licenses this file to you under the Apache
- * License, Version 2.0 (the "License"); you may not use this file
- * except in compliance with the License. You may obtain a copy of
- * the License at http://www.apache.org/licenses/LICENSE-2.0 .
- */
-#ifndef _SVT_SANEDLG_HRC
-#define _SVT_SANEDLG_HRC
-
-#define SCAN_AREA_TOP 17
-#define SCAN_AREA_LEFT 8
-#define PREVIEW_UPPER_LEFT SCAN_AREA_LEFT
-#define PREVIEW_UPPER_TOP SCAN_AREA_TOP + 80
-#define PREVIEW_WIDTH 113
-#define PREVIEW_HEIGHT 160
-
-#endif
-
-/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
diff --git a/extensions/source/scanner/sanedlg.hxx b/extensions/source/scanner/sanedlg.hxx
index d45642b..45750e5 100644
--- a/extensions/source/scanner/sanedlg.hxx
+++ b/extensions/source/scanner/sanedlg.hxx
@@ -30,24 +30,13 @@
#include <sane.hxx>
+class ScanPreview;
+
class SaneDlg : public ModalDialog
{
private:
- enum DragDirection { TopLeft, Top, TopRight, Right, BottomRight, Bottom,
- BottomLeft, Left };
-
Sane& mrSane;
- Bitmap maPreviewBitmap;
- Rectangle maPreviewRect;
- Point maTopLeft, maBottomRight;
- Point maMinTopLeft, maMaxBottomRight;
- bool mbDragEnable;
- bool mbIsDragging;
bool mbScanEnabled;
- bool mbDragDrawn;
- DragDirection meDragDirection;
-
- MapMode maMapMode;
Link maOldLink;
@@ -82,7 +71,7 @@ private:
SvTreeListBox* mpOptionBox;
- Window* mpPreview;
+ ScanPreview* mpPreview;
int mnCurrentOption;
int mnCurrentElement;
@@ -111,24 +100,14 @@ private:
void EstablishNumericOption();
void EstablishButtonOption();
- void DrawRectangles( Point&, Point& );
- void DrawDrag();
- Point GetPixelPos( const Point& );
- Point GetLogicPos( const Point& );
- void UpdateScanArea( bool );
-
// helper
bool SetAdjustedNumericalValue( const char* pOption, double fValue, int nElement = 0 );
-
- virtual void Paint( const Rectangle& ) SAL_OVERRIDE;
- virtual void MouseMove( const MouseEvent& rMEvt ) SAL_OVERRIDE;
- virtual void MouseButtonDown( const MouseEvent& rMEvt ) SAL_OVERRIDE;
- virtual void MouseButtonUp( const MouseEvent& rMEvt ) SAL_OVERRIDE;
public:
SaneDlg( Window*, Sane&, bool );
virtual ~SaneDlg();
virtual short Execute() SAL_OVERRIDE;
+ void UpdateScanArea( bool );
bool getDoScan() { return doScan;}
};
diff --git a/extensions/uiconfig/scanner/ui/sanedialog.ui b/extensions/uiconfig/scanner/ui/sanedialog.ui
index 794bca0..33075f6 100644
--- a/extensions/uiconfig/scanner/ui/sanedialog.ui
+++ b/extensions/uiconfig/scanner/ui/sanedialog.ui
@@ -190,9 +190,11 @@
<property name="top_padding">6</property>
<property name="left_padding">12</property>
<child>
- <object class="GtkDrawingArea" id="preview">
+ <object class="scnlo-ScanPreview" id="preview">
<property name="visible">True</property>
<property name="can_focus">False</property>
+ <property name="halign">center</property>
+ <property name="valign">start</property>
<property name="hexpand">True</property>
<property name="vexpand">True</property>
</object>
diff --git a/extras/source/glade/libreoffice-catalog.xml.in b/extras/source/glade/libreoffice-catalog.xml.in
index 67e1d51..d005444 100644
--- a/extras/source/glade/libreoffice-catalog.xml.in
+++ b/extras/source/glade/libreoffice-catalog.xml.in
@@ -248,6 +248,10 @@
</properties>
</glade-widget-class>
+ <glade-widget-class title="Scan Preview" name="scnlo-ScanPreview"
+ generic-name="Scan Preview Window" parent="GtkDrawingArea"
+ icon-name="widget-gtk-drawingarea"/>
+
<glade-widget-class title="Token Window" name="swuilo-SwTokenWindow"
generic-name="Token Window" parent="GtkDrawingArea"
icon-name="widget-gtk-drawingarea"/>
More information about the Libreoffice-commits
mailing list