summaryrefslogtreecommitdiff
path: root/sc/source/ui
diff options
context:
space:
mode:
authorJan Holesovsky <kendy@collabora.com>2015-12-11 10:24:28 +0100
committerJan Holesovsky <kendy@collabora.com>2015-12-11 10:43:00 +0100
commit007543f9672b69de4dcf1dba1ccca0fc9d165897 (patch)
tree02f1e20742e201debc5cb0b1a581a337336d7389 /sc/source/ui
parent5639a769fbcf672b1f32638764b4492674b894e6 (diff)
sc: Merge ScMultiTextWnd into ScTextWnd.
Change-Id: I21ed0e37feec0e7c078c2e284b7f4169f0cff432
Diffstat (limited to 'sc/source/ui')
-rw-r--r--sc/source/ui/app/inputwin.cxx248
-rw-r--r--sc/source/ui/inc/inputwin.hxx85
2 files changed, 83 insertions, 250 deletions
diff --git a/sc/source/ui/app/inputwin.cxx b/sc/source/ui/app/inputwin.cxx
index f63884fb8bb5..e35e1d41505e 100644
--- a/sc/source/ui/app/inputwin.cxx
+++ b/sc/source/ui/app/inputwin.cxx
@@ -878,7 +878,7 @@ void ScInputWindow::MouseButtonUp( const MouseEvent& rMEvt )
ScInputBarGroup::ScInputBarGroup(vcl::Window* pParent, ScTabViewShell* pViewSh)
: ScTextWndBase(pParent, WinBits(WB_HIDE | WB_TABSTOP)),
- maTextWnd(VclPtr<ScMultiTextWnd>::Create(this, pViewSh)),
+ maTextWnd(VclPtr<ScTextWnd>::Create(this, pViewSh)),
maButton(VclPtr<ImageButton>::Create(this, WB_TABSTOP | WB_RECTSTYLE | WB_SMALLSTYLE)),
maScrollbar(VclPtr<ScrollBar>::Create(this, WB_TABSTOP | WB_VERT | WB_DRAG)),
mnVertOffset(0)
@@ -1125,23 +1125,7 @@ void ScInputBarGroup::TextGrabFocus()
maTextWnd->TextGrabFocus();
}
-ScMultiTextWnd::ScMultiTextWnd( ScInputBarGroup* pParen, ScTabViewShell* pViewSh )
- : ScTextWnd( pParen, pViewSh ),
- mrGroupBar(* pParen ),
- mnLines( 1 ),
- mnLastExpandedLines( INPUTWIN_MULTILINES ),
- mbInvalidate( false )
-{
- Size aBorder;
- aBorder = CalcWindowSize(aBorder);
- mnBorderHeight = aBorder.Height();
-}
-
-ScMultiTextWnd::~ScMultiTextWnd()
-{
-}
-
-void ScMultiTextWnd::Paint( vcl::RenderContext& rRenderContext, const Rectangle& rRect )
+void ScTextWnd::Paint( vcl::RenderContext& rRenderContext, const Rectangle& rRect )
{
EditView* pView = GetEditView();
if (pView)
@@ -1155,20 +1139,20 @@ void ScMultiTextWnd::Paint( vcl::RenderContext& rRenderContext, const Rectangle&
}
}
-EditView* ScMultiTextWnd::GetEditView()
+EditView* ScTextWnd::GetEditView()
{
if ( !pEditView )
InitEditEngine();
return pEditView;
}
-long ScMultiTextWnd::GetPixelHeightForLines( long nLines )
+long ScTextWnd::GetPixelHeightForLines(long nLines)
{
// add padding ( for the borders of the window )
return ( nLines * LogicToPixel( Size( 0, GetTextHeight() ) ).Height() ) + mnBorderHeight;
}
-void ScMultiTextWnd::SetNumLines( long nLines )
+void ScTextWnd::SetNumLines(long nLines)
{
mnLines = nLines;
if ( nLines > 1 )
@@ -1178,7 +1162,7 @@ void ScMultiTextWnd::SetNumLines( long nLines )
}
}
-void ScMultiTextWnd::Resize()
+void ScTextWnd::Resize()
{
// Only Height is recalculated here, Width is applied from
// parent/container window
@@ -1187,7 +1171,7 @@ void ScMultiTextWnd::Resize()
aTextBoxSize.Height() = GetPixelHeightForLines( mnLines );
SetSizePixel( aTextBoxSize );
- if(pEditView)
+ if (pEditView)
{
Size aOutputSize = GetOutputSizePixel();
Rectangle aOutputArea = PixelToLogic( Rectangle( Point(), aOutputSize ));
@@ -1206,29 +1190,12 @@ void ScMultiTextWnd::Resize()
SetScrollBarRange();
}
-IMPL_LINK_NOARG_TYPED(ScMultiTextWnd, ModifyHdl, LinkParamNone*, void)
-{
- ScTextWnd::NotifyHdl(nullptr);
-}
-
-IMPL_LINK_TYPED(ScMultiTextWnd, NotifyHdl, EENotify&, rNotify, void)
-{
- // need to process EE_NOTIFY_TEXTVIEWSCROLLED here
- // sometimes we don't seem to get EE_NOTIFY_TEXTVIEWSCROLLED e.g. when
- // we insert text at the beginning of the text so the cursor never moves
- // down to generate a scroll event
-
- if ( rNotify.eNotificationType == EE_NOTIFY_TEXTVIEWSCROLLED
- || rNotify.eNotificationType == EE_NOTIFY_TEXTHEIGHTCHANGED )
- SetScrollBarRange();
-}
-
-long ScMultiTextWnd::GetEditEngTxtHeight()
+long ScTextWnd::GetEditEngTxtHeight()
{
return pEditView ? pEditView->GetEditEngine()->GetTextHeight() : 0;
}
-void ScMultiTextWnd::SetScrollBarRange()
+void ScTextWnd::SetScrollBarRange()
{
if ( pEditView )
{
@@ -1239,8 +1206,7 @@ void ScMultiTextWnd::SetScrollBarRange()
}
}
-void
-ScMultiTextWnd::DoScroll()
+void ScTextWnd::DoScroll()
{
if ( pEditView )
{
@@ -1253,7 +1219,7 @@ ScMultiTextWnd::DoScroll()
}
}
-void ScMultiTextWnd::StartEditEngine()
+void ScTextWnd::StartEditEngine()
{
// Don't activate if we're a modal dialog ourselves (Doc-modal dialog)
SfxObjectShell* pObjSh = SfxObjectShell::Current();
@@ -1316,7 +1282,7 @@ static void lcl_ModifyRTLVisArea( EditView* pEditView )
pEditView->SetVisArea(aVisArea);
}
-void ScMultiTextWnd::InitEditEngine()
+void ScTextWnd::InitEditEngine()
{
ScFieldEditEngine* pNew;
ScTabViewShell* pViewSh = GetViewShell();
@@ -1380,8 +1346,8 @@ void ScMultiTextWnd::InitEditEngine()
if ( bIsRTL )
lcl_ModifyRTLVisArea( pEditView );
- pEditEngine->SetModifyHdl(LINK(this, ScMultiTextWnd, ModifyHdl));
- pEditEngine->SetNotifyHdl(LINK(this, ScMultiTextWnd, NotifyHdl));
+ pEditEngine->SetModifyHdl(LINK(this, ScTextWnd, ModifyHdl));
+ pEditEngine->SetNotifyHdl(LINK(this, ScTextWnd, NotifyHdl));
if (!maAccTextDatas.empty())
maAccTextDatas.back()->StartEdit();
@@ -1397,27 +1363,7 @@ void ScMultiTextWnd::InitEditEngine()
}
}
-void ScMultiTextWnd::StopEditEngine( bool bAll )
-{
- if ( pEditEngine )
- pEditEngine->SetNotifyHdl(Link<EENotify&,void>());
- ScTextWnd::StopEditEngine( bAll );
-}
-
-void ScMultiTextWnd::SetTextString( const OUString& rNewString )
-{
- // Ideally it would be best to create on demand the EditEngine/EditView here, but... for
- // the initialisation scenario where a cell is first clicked on we end up with the text in the
- // inputbar window scrolled to the bottom if we do that here ( because the tableview and topview
- // are synced I guess ).
- // should fix that I suppose :-/ need to look a bit further into that
- mbInvalidate = true; // ensure next Paint ( that uses editengine ) call will call Invalidate first
- ScTextWnd::SetTextString( rNewString );
- SetScrollBarRange();
- DoScroll();
-}
-
-ScTextWnd::ScTextWnd( vcl::Window* pParent, ScTabViewShell* pViewSh )
+ScTextWnd::ScTextWnd(ScInputBarGroup* pParent, ScTabViewShell* pViewSh)
: ScTextWndBase(pParent, WinBits(WB_HIDE | WB_BORDER)),
DragSourceHelper(this),
pEditEngine (nullptr),
@@ -1425,7 +1371,11 @@ ScTextWnd::ScTextWnd( vcl::Window* pParent, ScTabViewShell* pViewSh )
bIsInsertMode(true),
bFormulaMode (false),
bInputMode (false),
- mpViewShell(pViewSh)
+ mpViewShell(pViewSh),
+ mrGroupBar(*pParent),
+ mnLines(1),
+ mnLastExpandedLines(INPUTWIN_MULTILINES),
+ mbInvalidate(false)
{
EnableRTL(false); // EditEngine can't be used with VCL EnableRTL
@@ -1457,6 +1407,10 @@ ScTextWnd::ScTextWnd( vcl::Window* pParent, ScTabViewShell* pViewSh )
SetMapMode(MAP_TWIP);
SetPointer(PointerStyle::Text);
SetFont(aTextFont);
+
+ Size aBorder;
+ aBorder = CalcWindowSize(aBorder);
+ mnBorderHeight = aBorder.Height();
}
ScTextWnd::~ScTextWnd()
@@ -1477,43 +1431,6 @@ void ScTextWnd::dispose()
ScTextWndBase::dispose();
}
-void ScTextWnd::Paint(vcl::RenderContext& rRenderContext, const Rectangle& rRect)
-{
- if (pEditView)
- {
- Size aSize(GetOutputSizePixel());
- long nDiff = aSize.Height() - rRenderContext.LogicToPixel(Size(0, rRenderContext.GetTextHeight())).Height();
- pEditView->SetOutputArea(rRenderContext.PixelToLogic(Rectangle(Point(0, (nDiff > 0) ? nDiff / 2 : 1), aSize)));
-
- pEditView->Paint(rRect, &rRenderContext);
- }
- else
- {
- Size aSize = GetOutputSizePixel();
- SetFont(aTextFont);
-
- long nDiff = aSize.Height() - rRenderContext.LogicToPixel(Size(0, rRenderContext.GetTextHeight())).Height();
-
-// if (nDiff<2) nDiff=2; // At least 1 pixel
-
- long nStartPos = 0;
- if (bIsRTL)
- {
- // right-align
- nStartPos += aSize.Width() - rRenderContext.LogicToPixel(Size(rRenderContext.GetTextWidth(aString), 0)).Width();
-
- // LayoutMode isn't changed as long as ModifyRTLDefaults doesn't include SvxFrameDirectionItem
- }
- rRenderContext.DrawText(rRenderContext.PixelToLogic(Point(nStartPos, nDiff / 2)), aString);
- }
- rRenderContext.Pop();
-}
-
-void ScTextWnd::Resize()
-{
- Invalidate();
-}
-
void ScTextWnd::MouseMove( const MouseEvent& rMEvt )
{
if (pEditView)
@@ -1690,100 +1607,19 @@ void ScTextWnd::UpdateAutoCorrFlag()
}
}
-void ScTextWnd::StartEditEngine()
+IMPL_LINK_TYPED(ScTextWnd, NotifyHdl, EENotify&, rNotify, void)
{
- // Don't activate if we're a modal ourselves (Doc modal Dialog)
- SfxObjectShell* pObjSh = SfxObjectShell::Current();
- if ( pObjSh && pObjSh->IsInModalMode() )
- return;
-
- if ( !pEditView || !pEditEngine )
- {
- ScFieldEditEngine* pNew;
- ScTabViewShell* pViewSh = ScTabViewShell::GetActiveViewShell();
- if ( pViewSh )
- {
- ScDocument* pDoc = pViewSh->GetViewData().GetDocument();
- pNew = new ScFieldEditEngine(pDoc, pDoc->GetEnginePool(), pDoc->GetEditPool());
- }
- else
- pNew = new ScFieldEditEngine(nullptr, EditEngine::CreatePool(), nullptr, true);
- pNew->SetExecuteURL( false );
- pEditEngine = pNew;
-
- pEditEngine->SetUpdateMode( false );
- pEditEngine->SetPaperSize( Size( bIsRTL ? USHRT_MAX : THESIZE, 300 ) );
- pEditEngine->SetWordDelimiters(
- ScEditUtil::ModifyDelimiters( pEditEngine->GetWordDelimiters() ) );
-
- UpdateAutoCorrFlag();
-
- {
- SfxItemSet* pSet = new SfxItemSet( pEditEngine->GetEmptyItemSet() );
- EditEngine::SetFontInfoInItemSet( *pSet, aTextFont );
- lcl_ExtendEditFontAttribs( *pSet );
-
- // turn off script spacing to match DrawText output
- pSet->Put( SvxScriptSpaceItem( false, EE_PARA_ASIANCJKSPACING ) );
- if ( bIsRTL )
- lcl_ModifyRTLDefaults( *pSet );
- pEditEngine->SetDefaults( pSet );
- }
-
- // If the Cell contains URLFields, they need to be taken over into the entry row,
- // or else the position is not correct anymore
- bool bFilled = false;
- ScInputHandler* pHdl = SC_MOD()->GetInputHdl();
- if ( pHdl ) //! Check if it's the right InputHdl?
- bFilled = pHdl->GetTextAndFields( *pEditEngine );
-
- pEditEngine->SetUpdateMode( true );
-
- // aString is the truth...
- if (bFilled && pEditEngine->GetText() == aString)
- Invalidate(); // Repaint for (filled) Fields
- else
- pEditEngine->SetText(aString); // At least the right text then
-
- pEditView = new EditView( pEditEngine, this );
- pEditView->SetInsertMode(bIsInsertMode);
-
- // The text from the Clipboard is taken over as ASCII in a single row
- EVControlBits n = pEditView->GetControlWord();
- pEditView->SetControlWord( n | EVControlBits::SINGLELINEPASTE );
-
- pEditEngine->InsertView( pEditView, EE_APPEND );
-
- Resize();
-
- if ( bIsRTL )
- lcl_ModifyRTLVisArea( pEditView );
-
- pEditEngine->SetModifyHdl(LINK(this, ScTextWnd, NotifyHdl));
-
- if (!maAccTextDatas.empty())
- maAccTextDatas.back()->StartEdit();
-
- // as long as EditEngine and DrawText sometimes differ for CTL text,
- // repaint now to have the EditEngine's version visible
-// SfxObjectShell* pObjSh = SfxObjectShell::Current();
- if ( pObjSh && dynamic_cast<const ScDocShell*>( pObjSh) != nullptr )
- {
- ScDocument& rDoc = static_cast<ScDocShell*>(pObjSh)->GetDocument(); // any document
- SvtScriptType nScript = rDoc.GetStringScriptType( aString );
- if ( nScript & SvtScriptType::COMPLEX )
- Invalidate();
- }
- }
-
- SC_MOD()->SetInputMode( SC_INPUT_TOP );
+ // need to process EE_NOTIFY_TEXTVIEWSCROLLED here
+ // sometimes we don't seem to get EE_NOTIFY_TEXTVIEWSCROLLED e.g. when
+ // we insert text at the beginning of the text so the cursor never moves
+ // down to generate a scroll event
- SfxViewFrame* pViewFrm = SfxViewFrame::Current();
- if (pViewFrm)
- pViewFrm->GetBindings().Invalidate( SID_ATTR_INSERT );
+ if ( rNotify.eNotificationType == EE_NOTIFY_TEXTVIEWSCROLLED
+ || rNotify.eNotificationType == EE_NOTIFY_TEXTHEIGHTCHANGED )
+ SetScrollBarRange();
}
-IMPL_LINK_NOARG_TYPED(ScTextWnd, NotifyHdl, LinkParamNone*, void)
+IMPL_LINK_NOARG_TYPED(ScTextWnd, ModifyHdl, LinkParamNone*, void)
{
if (pEditView && !bInputMode)
{
@@ -1799,6 +1635,9 @@ IMPL_LINK_NOARG_TYPED(ScTextWnd, NotifyHdl, LinkParamNone*, void)
void ScTextWnd::StopEditEngine( bool bAll )
{
+ if (pEditEngine)
+ pEditEngine->SetNotifyHdl(Link<EENotify&, void>());
+
if (pEditView)
{
if (!maAccTextDatas.empty())
@@ -1848,6 +1687,13 @@ static sal_Int32 findFirstNonMatchingChar(const OUString& rStr1, const OUString&
void ScTextWnd::SetTextString( const OUString& rNewString )
{
+ // Ideally it would be best to create on demand the EditEngine/EditView here, but... for
+ // the initialisation scenario where a cell is first clicked on we end up with the text in the
+ // inputbar window scrolled to the bottom if we do that here ( because the tableview and topview
+ // are synced I guess ).
+ // should fix that I suppose :-/ need to look a bit further into that
+ mbInvalidate = true; // ensure next Paint ( that uses editengine ) call will call Invalidate first
+
if ( rNewString != aString )
{
bInputMode = true;
@@ -1920,6 +1766,9 @@ void ScTextWnd::SetTextString( const OUString& rNewString )
bInputMode = false;
}
+
+ SetScrollBarRange();
+ DoScroll();
}
const OUString& ScTextWnd::GetTextString() const
@@ -1932,11 +1781,6 @@ bool ScTextWnd::IsInputActive()
return HasFocus();
}
-EditView* ScTextWnd::GetEditView()
-{
- return pEditView;
-}
-
void ScTextWnd::MakeDialogEditView()
{
if ( pEditView ) return;
diff --git a/sc/source/ui/inc/inputwin.hxx b/sc/source/ui/inc/inputwin.hxx
index bb94592b1b0f..1b84501c2773 100644
--- a/sc/source/ui/inc/inputwin.hxx
+++ b/sc/source/ui/inc/inputwin.hxx
@@ -30,15 +30,16 @@
#include <vcl/window.hxx>
#include <svtools/transfer.hxx>
-class ScEditEngineDefaulter;
+class Accelerator;
class EditView;
-struct ESelection;
-class ScInputHandler;
class ScAccessibleEditLineTextData;
-struct EENotify;
+class ScEditEngineDefaulter;
+class ScInputBarGroup;
+class ScInputHandler;
class ScRangeList;
class ScTabViewShell;
-class Accelerator;
+struct EENotify;
+struct ESelection;
class ScTextWndBase : public vcl::Window
{
@@ -60,14 +61,14 @@ public:
class ScTextWnd : public ScTextWndBase, public DragSourceHelper // edit window
{
public:
- ScTextWnd( vcl::Window* pParent, ScTabViewShell* pViewSh );
+ ScTextWnd(ScInputBarGroup* pParent, ScTabViewShell* pViewSh);
virtual ~ScTextWnd();
virtual void dispose() override;
virtual void SetTextString( const OUString& rString ) override;
virtual const OUString& GetTextString() const override;
- bool IsInputActive() override;
+ bool IsInputActive() override;
virtual EditView* GetEditView() override;
// for function autopilots
@@ -78,7 +79,7 @@ public:
virtual void TextGrabFocus() override;
- virtual void DataChanged( const DataChangedEvent& rDCEvt ) override;
+ virtual void DataChanged(const DataChangedEvent& rDCEvt) override;
virtual void SetFormulaMode( bool bSet ) override;
@@ -87,11 +88,22 @@ public:
virtual void InsertAccessibleTextData( ScAccessibleEditLineTextData& rTextData ) override;
virtual void RemoveAccessibleTextData( ScAccessibleEditLineTextData& rTextData ) override;
- DECL_LINK_TYPED( NotifyHdl, LinkParamNone*, void );
+ virtual void Resize() override;
+
+ long GetPixelHeightForLines(long nLines);
+ long GetEditEngTxtHeight();
+
+ long GetNumLines() { return mnLines; }
+ void SetNumLines(long nLines);
+ long GetLastNumExpandedLines() { return mnLastExpandedLines; }
+
+ void DoScroll();
+
+ DECL_LINK_TYPED(NotifyHdl, EENotify&, void);
+ DECL_LINK_TYPED(ModifyHdl, LinkParamNone*, void);
protected:
virtual void Paint( vcl::RenderContext& rRenderContext, const Rectangle& rRect ) override;
- virtual void Resize() override;
virtual void MouseMove( const MouseEvent& rMEvt ) override;
virtual void MouseButtonDown( const MouseEvent& rMEvt ) override;
@@ -108,6 +120,10 @@ protected:
void ImplInitSettings();
void UpdateAutoCorrFlag();
+ void SetScrollBarRange();
+
+ void InitEditEngine();
+
ScTabViewShell* GetViewShell() { return mpViewShell;}
typedef ::std::vector< ScAccessibleEditLineTextData* > AccTextDataVector;
@@ -127,6 +143,11 @@ protected:
private:
ScTabViewShell* mpViewShell;
+ ScInputBarGroup& mrGroupBar;
+ long mnLines;
+ long mnLastExpandedLines;
+ long mnBorderHeight;
+ bool mbInvalidate;
};
class ScPosWnd : public ComboBox, public SfxListener // Display position
@@ -162,40 +183,6 @@ private:
void ReleaseFocus_Impl();
};
-class ScInputBarGroup;
-
-class ScMultiTextWnd : public ScTextWnd
-{
-public:
- ScMultiTextWnd( ScInputBarGroup* pParent, ScTabViewShell* pViewSh );
- virtual ~ScMultiTextWnd();
- virtual void StartEditEngine() override;
- virtual void StopEditEngine( bool bAll ) override;
- virtual void Resize() override;
- virtual EditView* GetEditView() override;
- long GetPixelHeightForLines( long nLines );
- long GetEditEngTxtHeight();
-
- void DoScroll();
- virtual void SetTextString( const OUString& rString ) override;
- void SetNumLines( long nLines );
- long GetNumLines() { return mnLines; }
- long GetLastNumExpandedLines() { return mnLastExpandedLines; }
-protected:
- void SetScrollBarRange();
- void InitEditEngine();
-
- virtual void Paint( vcl::RenderContext& rRenderContext, const Rectangle& rRect ) override;
- DECL_LINK_TYPED( NotifyHdl, EENotify&, void );
- DECL_LINK_TYPED( ModifyHdl, LinkParamNone*, void );
-private:
- ScInputBarGroup& mrGroupBar;
- long mnLines;
- long mnLastExpandedLines;
- long mnBorderHeight;
- bool mbInvalidate;
-};
-
class ScInputBarGroup : public ScTextWndBase
{
@@ -220,15 +207,17 @@ public:
void DecrementVerticalSize();
long GetNumLines() { return maTextWnd->GetNumLines(); }
long GetVertOffset() { return mnVertOffset; }
+
private:
void TriggerToolboxLayout();
- VclPtr<ScMultiTextWnd> maTextWnd;
- VclPtr<ImageButton> maButton;
- VclPtr<ScrollBar> maScrollbar;
+
+ VclPtr<ScTextWnd> maTextWnd;
+ VclPtr<ImageButton> maButton;
+ VclPtr<ScrollBar> maScrollbar;
long mnVertOffset;
+
DECL_LINK_TYPED( ClickHdl, Button*, void );
DECL_LINK_TYPED( Impl_ScrollHdl, ScrollBar*, void );
-
};
class ScInputWindow : public ToolBox // Parent toolbox