diff options
author | Caolán McNamara <caolanm@redhat.com> | 2014-01-31 09:57:37 +0000 |
---|---|---|
committer | Caolán McNamara <caolanm@redhat.com> | 2014-01-31 21:21:37 +0000 |
commit | 344a1abd2f28f4556746f72a06358a08dd23abbe (patch) | |
tree | 299581c3fe10457dbb9809e74a0f1f491e0be40a | |
parent | b0da0f644330b78a2c11842a90ff71fe95d8419d (diff) |
introduce a layout aware GraphicFilterDialog
Change-Id: I932e4be6b7f4a2717748de561c424302ef429d63
-rw-r--r-- | cui/source/dialogs/cuigrfflt.cxx | 148 | ||||
-rw-r--r-- | cui/source/inc/cuigrfflt.hxx | 62 |
2 files changed, 198 insertions, 12 deletions
diff --git a/cui/source/dialogs/cuigrfflt.cxx b/cui/source/dialogs/cuigrfflt.cxx index d7ac4bafb91f..06381de76367 100644 --- a/cui/source/dialogs/cuigrfflt.cxx +++ b/cui/source/dialogs/cuigrfflt.cxx @@ -29,10 +29,6 @@ #include <cuires.hrc> #include <svx/dialogs.hrc> -// -------------------------------------- -// - oldGraphicFilterDialog::PreviewWindow - -// -------------------------------------- - oldGraphicFilterDialog::PreviewWindow::PreviewWindow( Window* pParent, const ResId& rResId ) : Control( pParent, rResId ) { @@ -74,10 +70,6 @@ void oldGraphicFilterDialog::PreviewWindow::SetGraphic( const Graphic& rGraphic Paint( Rectangle( Point(), GetOutputSizePixel() ) ); } -// ----------------------- -// - oldGraphicFilterDialog - -// ----------------------- - oldGraphicFilterDialog::oldGraphicFilterDialog( Window* pParent, const ResId& rResId, const Graphic& rGraphic ) : ModalDialog ( pParent, rResId ), maModifyHdl ( LINK( this, oldGraphicFilterDialog, ImplModifyHdl ) ), @@ -151,6 +143,146 @@ IMPL_LINK_NOARG(oldGraphicFilterDialog, ImplModifyHdl) return 0; } +GraphicFilterDialog::PreviewWindow::PreviewWindow(Window* pParent, + const WinBits nStyle) + : Control(pParent, nStyle) + , mpOrigGraphic(NULL) + , mfScaleX(0.0) + , mfScaleY(0.0) +{ +} + +Size GraphicFilterDialog::PreviewWindow::GetOptimalSize() const +{ + return LogicToPixel(Size(81, 73), MAP_APPFONT); +} + +// ----------------------------------------------------------------------------- + +void GraphicFilterDialog::PreviewWindow::Paint( const Rectangle& rRect ) +{ + Control::Paint( rRect ); + + const Size aOutputSize( GetOutputSizePixel() ); + + if( maPreview.IsAnimated() ) + { + const Size aGraphicSize( LogicToPixel( maPreview.GetPrefSize(), maPreview.GetPrefMapMode() ) ); + const Point aGraphicPosition( ( aOutputSize.Width() - aGraphicSize.Width() ) >> 1, + ( aOutputSize.Height() - aGraphicSize.Height() ) >> 1 ); + maPreview.StartAnimation( this, aGraphicPosition, aGraphicSize ); + } + else + { + const Size aGraphicSize( maPreview.GetSizePixel() ); + const Point aGraphicPosition( ( aOutputSize.Width() - aGraphicSize.Width() ) >> 1, + ( aOutputSize.Height() - aGraphicSize.Height() ) >> 1 ); + maPreview.Draw( this, aGraphicPosition, aGraphicSize ); + } +} + +// ----------------------------------------------------------------------------- + +void GraphicFilterDialog::PreviewWindow::SetPreview( const Graphic& rGraphic ) +{ + maPreview = rGraphic; + + if( maPreview.IsAnimated() || maPreview.IsTransparent() ) + Invalidate(); + else + Paint( Rectangle( Point(), GetOutputSizePixel() ) ); +} + +void GraphicFilterDialog::PreviewWindow::ScaleImageToFit() +{ + if (!mpOrigGraphic) + return; + + const Size aPreviewSize( GetOutputSizePixel() ); + Size aSizePixel(LogicToPixel(mpOrigGraphic->GetPrefSize(), + mpOrigGraphic->GetPrefMapMode())); + Size aGrfSize(aSizePixel); + + if( mpOrigGraphic->GetType() == GRAPHIC_BITMAP && + aPreviewSize.Width() && aPreviewSize.Height() && + aGrfSize.Width() && aGrfSize.Height() ) + { + const double fGrfWH = (double) aGrfSize.Width() / aGrfSize.Height(); + const double fPreWH = (double) aPreviewSize.Width() / aPreviewSize.Height(); + + if( fGrfWH < fPreWH ) + { + aGrfSize.Width() = (long) ( aPreviewSize.Height() * fGrfWH ); + aGrfSize.Height() = aPreviewSize.Height(); + } + else + { + aGrfSize.Width() = aPreviewSize.Width(); + aGrfSize.Height() = (long) ( aPreviewSize.Width() / fGrfWH ); + } + + mfScaleX = (double) aGrfSize.Width() / aSizePixel.Width(); + mfScaleY = (double) aGrfSize.Height() / aSizePixel.Height(); + + if( !mpOrigGraphic->IsAnimated() ) + { + BitmapEx aBmpEx( mpOrigGraphic->GetBitmapEx() ); + + if( aBmpEx.Scale( aGrfSize, BMP_SCALE_DEFAULT ) ) + maPreview = aBmpEx; + } + } +} + +void GraphicFilterDialog::PreviewWindow::Resize() +{ + Control::Resize(); + ScaleImageToFit(); +} + +GraphicFilterDialog::GraphicFilterDialog(Window* pParent, + const OString& rID, const OUString& rUIXMLDescription, + const Graphic& rGraphic) + : ModalDialog(pParent, rID, rUIXMLDescription) + , maModifyHdl(LINK( this, GraphicFilterDialog, ImplModifyHdl)) + , maSizePixel(LogicToPixel(rGraphic.GetPrefSize(), + rGraphic.GetPrefMapMode())) +{ + bIsBitmap = rGraphic.GetType() == GRAPHIC_BITMAP; + + get(mpPreview, "preview"); + mpPreview->init(&rGraphic); + + maTimer.SetTimeoutHdl( LINK( this, GraphicFilterDialog, ImplPreviewTimeoutHdl ) ); + maTimer.SetTimeout( 100 ); + ImplModifyHdl( NULL ); +} + + +// ----------------------------------------------------------------------------- + +IMPL_LINK_NOARG(GraphicFilterDialog, ImplPreviewTimeoutHdl) +{ + maTimer.Stop(); + mpPreview->SetPreview(GetFilteredGraphic(mpPreview->GetScaledOriginal(), + mpPreview->GetScaleX(), mpPreview->GetScaleY())); + + return 0; +} + +// ----------------------------------------------------------------------------- + +IMPL_LINK_NOARG(GraphicFilterDialog, ImplModifyHdl) +{ + if (bIsBitmap) + { + maTimer.Stop(); + maTimer.Start(); + } + + return 0; +} + // ---------------- // - FilterMosaic - // ---------------- diff --git a/cui/source/inc/cuigrfflt.hxx b/cui/source/inc/cuigrfflt.hxx index b4fcfac12fa1..04d8da269bd7 100644 --- a/cui/source/inc/cuigrfflt.hxx +++ b/cui/source/inc/cuigrfflt.hxx @@ -32,10 +32,6 @@ #include <svx/dlgctrl.hxx> #include <svx/rectenum.hxx> -// ----------------------- -// - oldGraphicFilterDialog - -// ----------------------- - class oldGraphicFilterDialog : public ModalDialog { private: @@ -84,6 +80,64 @@ public: virtual Graphic GetFilteredGraphic( const Graphic& rGraphic, double fScaleX, double fScaleY ) = 0; }; +class GraphicFilterDialog : public ModalDialog +{ +private: + + class PreviewWindow : public Control + { + private: + const Graphic* mpOrigGraphic; + Graphic maScaledOrig; + Graphic maPreview; + double mfScaleX; + double mfScaleY; + + virtual void Paint(const Rectangle& rRect); + virtual void Resize(); + virtual Size GetOptimalSize() const; + + void ScaleImageToFit(); + + public: + + PreviewWindow(Window* pParent, WinBits nStyle); + void init(const Graphic *pOrigGraphic) + { + mpOrigGraphic = pOrigGraphic; + ScaleImageToFit(); + } + + void SetPreview(const Graphic& rGraphic); + const Graphic& GetScaledOriginal() const { return maScaledOrig; } + double GetScaleX() const { return mfScaleX; } + double GetScaleY() const { return mfScaleY; } + }; + +private: + + Timer maTimer; + Link maModifyHdl; + Size maSizePixel; + bool bIsBitmap; + + DECL_LINK(ImplPreviewTimeoutHdl, void *); + DECL_LINK( ImplModifyHdl, void* p ); + +protected: + PreviewWindow* mpPreview; + + const Link& GetModifyHdl() const { return maModifyHdl; } + const Size& GetGraphicSizePixel() const { return maSizePixel; } + +public: + + GraphicFilterDialog(Window* pParent, const OString& rID, const OUString& rUIXMLDescription, const Graphic& rGraphic); + + virtual Graphic GetFilteredGraphic( const Graphic& rGraphic, double fScaleX, double fScaleY ) = 0; +}; + + // ------------------------- // - GraphicFilterSmooth - // ------------------------- |