1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
|
/* -*- 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 .
*/
#include "commonlingui.hxx"
#include <cuires.hrc>
#include <dialmgr.hxx>
#include <vcl/decoview.hxx>
#include <sal/macros.h>
#include "hangulhanjadlg.hrc"
// SvxClickInfoCtr
SvxClickInfoCtr::SvxClickInfoCtr( Window* pParent, const ResId& rResId ) :
Control( pParent, rResId ),
aFixedInfo( this)
{
aFixedInfo.SetSizePixel(GetOutputSizePixel());
aFixedInfo.Show();
}
void SvxClickInfoCtr::MouseButtonDown( const MouseEvent& )
{
aActivateLink.Call(this);
}
bool SvxClickInfoCtr::PreNotify( NotifyEvent& rNEvt )
{
if(rNEvt.GetType()==EVENT_GETFOCUS || rNEvt.GetType()==EVENT_MOUSEBUTTONDOWN)
{
aActivateLink.Call(this);
}
return Control::PreNotify(rNEvt);
}
void SvxClickInfoCtr::SetText( const OUString& rStr )
{
aFixedInfo.SetText(rStr );
}
OUString SvxClickInfoCtr::GetText() const
{
return aFixedInfo.GetText();
}
SvxClickInfoCtr::~SvxClickInfoCtr()
{
}
// SvxCommonLinguisticControl
SvxCommonLinguisticControl::SvxCommonLinguisticControl( ModalDialog* _pParent )
:Window( _pParent, CUI_RES( RID_SVX_WND_COMMON_LINGU ) )
,aWordText ( this, CUI_RES( FT_WORD ) )
,aAktWord ( this, CUI_RES( FT_AKTWORD ) )
,aNewWord ( this, CUI_RES( FT_NEWWORD ) )
,aNewWordED ( this, CUI_RES( ED_NEWWORD ) )
,aSuggestionFT ( this, CUI_RES( FT_SUGGESTION ) )
,aIgnoreBtn ( this, CUI_RES( BTN_IGNORE ) )
,aIgnoreAllBtn ( this, CUI_RES( BTN_IGNOREALL ) )
,aChangeBtn ( this, CUI_RES( BTN_CHANGE ) )
,aChangeAllBtn ( this, CUI_RES( BTN_CHANGEALL ) )
,aOptionsBtn ( this, CUI_RES( BTN_OPTIONS ) )
,aStatusText ( this, CUI_RES( FT_STATUS ) )
,aHelpBtn ( this, CUI_RES( BTN_SPL_HELP ) )
,aCancelBtn ( this, CUI_RES( BTN_SPL_CANCEL ) )
,aAuditBox ( this, CUI_RES( GB_AUDIT ) )
{
FreeResource();
aAktWord.SetAccessibleName(aWordText.GetText());
SetPosSizePixel( Point( 0, 0 ), _pParent->GetOutputSizePixel() );
Show();
}
PushButton* SvxCommonLinguisticControl::implGetButton( ButtonType _eType ) const
{
const PushButton* pButton = NULL;
switch ( _eType )
{
case eClose: pButton = &aCancelBtn; break;
case eIgnore: pButton = &aIgnoreBtn; break;
case eIgnoreAll: pButton = &aIgnoreAllBtn; break;
case eChange: pButton = &aChangeBtn; break;
case eChangeAll: pButton = &aChangeAllBtn; break;
case eOptions: pButton = &aOptionsBtn; break;
}
return const_cast< PushButton* >( pButton );
}
void SvxCommonLinguisticControl::SetButtonHandler( ButtonType _eType, const Link& _rHandler )
{
Button* pButton = GetButton( _eType );
if ( pButton )
pButton->SetClickHdl( _rHandler );
}
void SvxCommonLinguisticControl::EnableButton( ButtonType _eType, sal_Bool _bEnable )
{
Button* pButton = GetButton( _eType );
if ( pButton )
pButton->Enable( _bEnable );
}
void SvxCommonLinguisticControl::InsertControlGroup( Window& _rFirstGroupWindow, Window& _rLastGroupWindow, ControlGroup _eInsertAfter )
{
Window* pInsertAfter = NULL; // will be the last window of our own "undividable" group, after which we insert the foreign group
switch ( _eInsertAfter )
{
case eLeftRightWords : pInsertAfter = &aNewWordED; break;
case eSuggestionLabel : pInsertAfter = &aSuggestionFT; break;
case eActionButtons : pInsertAfter = &aChangeAllBtn; break;
case eDialogButtons : pInsertAfter = &aCancelBtn; break;
}
// now loop through the remaining windows of the foreign group
Window* pInsertBehind = pInsertAfter;
Window* pInsert = &_rFirstGroupWindow;
// some strange thing below: asking a window for WINDOW_NEXT or WINDOW_PREV does not take into
// account the border window, _but_ SetZOrder _does_!. Thus, when advancing through a chain
// of windows, we need to work with the border windows (WINDOW_BORDER), instead of simply
// asking for WINDOW_NEXT.
Window* pLoopEnd = _rLastGroupWindow.GetWindow( WINDOW_BORDER );
while ( pInsert && ( pInsertBehind != pLoopEnd ) )
{
// we'll destroy the NEXT relation immediately, so remember the next window
DBG_ASSERT( pInsert->GetWindow( WINDOW_BORDER ), "SvxCommonLinguisticControl::InsertControlGroup: border window is expected to be non NULL!" );
Window* pNextInsert = pInsert->GetWindow( WINDOW_BORDER )->GetWindow( WINDOW_NEXT );
// knit
pInsert->SetZOrder( pInsertBehind, WINDOW_ZORDER_BEHIND );
// advance
pInsertBehind = pInsert;
pInsert = pNextInsert;
}
DBG_ASSERT( pInsertBehind == pLoopEnd, "SvxCommonLinguisticControl::InsertControlGroup: controls do not form a group!" );
// if we did not reach pLoopEnd, then we did not reach _rLastGroupWindow in the loop, then
// (FirstWindow, LastWindow) was no valid control group
}
void SvxCommonLinguisticControl::Paint( const Rectangle& rRect )
{
Window::Paint(rRect );
DecorationView aDecoView( this );
Rectangle aRect( aAuditBox.GetPosPixel(), aAuditBox.GetSizePixel() );
aDecoView.DrawButton( aRect, BUTTON_DRAW_NOFILL );
}
void SvxCommonLinguisticControl::Enlarge( sal_Int32 _nX, sal_Int32 _nY )
{
Size aSize;
Point aPos;
// the controls which need to be resized
{
Window* pResize[] =
{
this, &aAuditBox, &aStatusText
};
for ( sal_uInt32 i = 0; i < SAL_N_ELEMENTS( pResize ); ++i )
{
aSize = pResize[i]->GetSizePixel( );
pResize[i]->SetSizePixel( Size( aSize.Width() + _nX, aSize.Height() + _nY ) );
}
}
// the controls which stick to the bottom of the window
{
Window* pMoveDown[] =
{
&aStatusText, &aHelpBtn, &aCancelBtn
};
for ( sal_uInt32 i = 0; i < SAL_N_ELEMENTS( pMoveDown ); ++i )
{
aPos = pMoveDown[i]->GetPosPixel();
aPos.Y() += _nY;
pMoveDown[i]->SetPosPixel( aPos );
}
}
// the controls which stick to the right
{
Window* pMoveRight[] =
{
&aIgnoreBtn, &aIgnoreAllBtn, &aChangeBtn, &aChangeAllBtn, &aOptionsBtn, &aHelpBtn, &aCancelBtn
};
for ( sal_uInt32 i = 0; i < SAL_N_ELEMENTS( pMoveRight ); ++i )
{
aPos = pMoveRight[i]->GetPosPixel();
aPos.X() += _nX;
pMoveRight[i]->SetPosPixel( aPos );
}
}
}
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|