xref: /aoo41x/main/svx/source/svdraw/svdibrow.cxx (revision cdf0e10c)
1 /*************************************************************************
2  *
3  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4  *
5  * Copyright 2000, 2010 Oracle and/or its affiliates.
6  *
7  * OpenOffice.org - a multi-platform office productivity suite
8  *
9  * This file is part of OpenOffice.org.
10  *
11  * OpenOffice.org is free software: you can redistribute it and/or modify
12  * it under the terms of the GNU Lesser General Public License version 3
13  * only, as published by the Free Software Foundation.
14  *
15  * OpenOffice.org is distributed in the hope that it will be useful,
16  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18  * GNU Lesser General Public License version 3 for more details
19  * (a copy is included in the LICENSE file that accompanied this code).
20  *
21  * You should have received a copy of the GNU Lesser General Public License
22  * version 3 along with OpenOffice.org.  If not, see
23  * <http://www.openoffice.org/license.html>
24  * for a copy of the LGPLv3 License.
25  *
26  ************************************************************************/
27 
28 // MARKER(update_precomp.py): autogen include statement, do not remove
29 #include "precompiled_svx.hxx"
30 #include <editeng/eeitem.hxx>
31 
32 #include "svdibrow.hxx"
33 
34 #ifndef _STDLIB_H
35 #include <stdlib.h>
36 #define _STDLIB_H
37 #endif
38 
39 #include "svx/svditext.hxx"
40 #include <editeng/flditem.hxx>
41 #include <editeng/editdata.hxx>
42 #include <svx/svdpool.hxx>
43 #include <svx/svdattr.hxx>
44 #include <svx/svdattrx.hxx>
45 #include <svx/svdview.hxx>
46 #include <svx/xenum.hxx>
47 #include <svx/xlineit0.hxx>
48 #include <svx/xlnstwit.hxx>
49 #include <svx/xlnedwit.hxx>
50 #include <svx/xfillit0.hxx>
51 #include <svx/xflbmtit.hxx>
52 #include <svx/xtextit0.hxx>
53 #include <svx/xflbstit.hxx>
54 #include <svx/xflbtoxy.hxx>
55 #include <svx/xftshit.hxx>
56 #include <editeng/colritem.hxx>
57 
58 
59 #include "editeng/fontitem.hxx"
60 #include <editeng/fhgtitem.hxx>
61 
62 #include <editeng/charscaleitem.hxx>
63 #include <svl/whiter.hxx>
64 #include <svl/flagitem.hxx>
65 #include <svl/ptitem.hxx>
66 #include <svl/rectitem.hxx>
67 
68 #include <svl/rngitem.hxx>
69 #include <svx/sdrpaintwindow.hxx>
70 
71 ////////////////////////////////////////////////////////////////////////////////////////////////////
72 
73 #define ITEMBROWSER_WHICHCOL_ID 1
74 #define ITEMBROWSER_STATECOL_ID 2
75 #define ITEMBROWSER_TYPECOL_ID  3
76 #define ITEMBROWSER_NAMECOL_ID  4
77 #define ITEMBROWSER_VALUECOL_ID 5
78 
79 enum ItemType {
80 	ITEM_DONTKNOW, ITEM_BYTE, ITEM_INT16, ITEM_UINT16, ITEM_INT32, ITEM_UINT32,
81 	ITEM_ENUM, ITEM_BOOL, ITEM_FLAG, ITEM_STRING, ITEM_POINT, ITEM_RECT, ITEM_RANGE, ITEM_LRANGE,
82 	ITEM_FRACTION,
83 	ITEM_XCOLOR,
84 	ITEM_COLOR,
85 	ITEM_FONT, ITEM_FONTHEIGHT, ITEM_FONTWIDTH, ITEM_FIELD
86 };
87 
88 class ImpItemListRow
89 {
90 public:
91 	XubString					aName;
92 	XubString					aValue;
93 	SfxItemState				eState;
94 	sal_uInt16						nWhichId;
95 
96 	TypeId						pType;
97 	ItemType					eItemType;
98 
99 	sal_Int32						nVal;
100 	sal_Int32						nMin;
101 	sal_Int32						nMax;
102 
103 	sal_Bool						bComment;
104 	sal_Bool						bIsNum;
105 	sal_Bool						bCanNum;
106 
107 public:
108 	ImpItemListRow()
109 	:	eState(SFX_ITEM_UNKNOWN),
110 		nWhichId(0),
111 		pType(NULL),
112 		eItemType(ITEM_DONTKNOW),
113 		nVal(0),
114 		nMin(0),
115 		nMax(0),
116 		bComment(sal_False),
117 		bIsNum(sal_False),
118 		bCanNum(sal_False)
119 	{}
120 
121 	XubString GetItemTypeStr() const;
122 	sal_Bool operator==(const ImpItemListRow& rEntry) const;
123 	sal_Bool operator!=(const ImpItemListRow& rEntry) const { return !operator==(rEntry); }
124 };
125 
126 XubString ImpItemListRow::GetItemTypeStr() const
127 {
128 	XubString aStr;
129 
130 	switch(eItemType)
131 	{
132 		case ITEM_BYTE		: aStr.AppendAscii("Byte");		break;
133 		case ITEM_INT16		: aStr.AppendAscii("Int16");	break;
134 		case ITEM_UINT16	: aStr.AppendAscii("UInt16");	break;
135 		case ITEM_INT32		: aStr.AppendAscii("Int32");	break;
136 		case ITEM_UINT32	: aStr.AppendAscii("UInt32");	break;
137 		case ITEM_ENUM		: aStr.AppendAscii("Enum");		break;
138 		case ITEM_BOOL		: aStr.AppendAscii("Bool");		break;
139 		case ITEM_FLAG		: aStr.AppendAscii("Flag");		break;
140 		case ITEM_STRING	: aStr.AppendAscii("String");	break;
141 		case ITEM_POINT		: aStr.AppendAscii("Point");	break;
142 		case ITEM_RECT		: aStr.AppendAscii("Rectangle");break;
143 		case ITEM_RANGE		: aStr.AppendAscii("Range");	break;
144 		case ITEM_LRANGE	: aStr.AppendAscii("LRange");	break;
145 		case ITEM_FRACTION	: aStr.AppendAscii("Fraction");	break;
146 		case ITEM_XCOLOR	: aStr.AppendAscii("XColor");	break;
147 		case ITEM_COLOR		: aStr.AppendAscii("Color");	break;
148 		case ITEM_FONT		: aStr.AppendAscii("Font");		break;
149 		case ITEM_FONTHEIGHT:aStr.AppendAscii("FontHeight");break;
150 		case ITEM_FONTWIDTH	:aStr.AppendAscii("FontWidth");	break;
151 		case ITEM_FIELD		:aStr.AppendAscii("Field");		break;
152 		default: break;
153 	}
154 
155 	return aStr;
156 }
157 
158 sal_Bool ImpItemListRow::operator==(const ImpItemListRow& rEntry) const
159 {
160 	return (aName.Equals(rEntry.aName)
161 		&& aValue.Equals(rEntry.aValue)
162 		&& eState==rEntry.eState
163 		&& nWhichId==rEntry.nWhichId
164 		&& bComment==rEntry.bComment
165 		&& bIsNum==rEntry.bIsNum
166 		&& bCanNum==rEntry.bCanNum
167 		&& pType==rEntry.pType
168 		&& eItemType==rEntry.eItemType
169 		&& nVal==rEntry.nVal
170 		&& nMin==rEntry.nMin
171 		&& nMax==rEntry.nMax);
172 }
173 
174 ////////////////////////////////////////////////////////////////////////////////////////////////////
175 
176 class ImpItemEdit: public Edit
177 {
178 	_SdrItemBrowserControl*		pBrowse;
179 
180 public:
181 	ImpItemEdit(Window* pParent, _SdrItemBrowserControl* pBrowse_, WinBits nBits=0)
182 	:	Edit(pParent, nBits),
183 		pBrowse(pBrowse_)
184 	{}
185 
186 	virtual ~ImpItemEdit();
187 	virtual void KeyInput(const KeyEvent& rEvt);
188 };
189 
190 __EXPORT ImpItemEdit::~ImpItemEdit()
191 {
192 }
193 
194 void __EXPORT ImpItemEdit::KeyInput(const KeyEvent& rKEvt)
195 {
196 	_SdrItemBrowserControl* pBrowseMerk = pBrowse;
197 
198 	sal_uInt16 nKeyCode(rKEvt.GetKeyCode().GetCode() + rKEvt.GetKeyCode().GetModifier());
199 
200 	if(nKeyCode == KEY_RETURN)
201 	{
202 		pBrowseMerk->EndChangeEntry();
203 		pBrowseMerk->GrabFocus();
204 	}
205 	else if(nKeyCode == KEY_ESCAPE)
206 	{
207 		pBrowseMerk->BrkChangeEntry();
208 		pBrowseMerk->GrabFocus();
209 	}
210 	else if(nKeyCode == KEY_UP || nKeyCode == KEY_DOWN)
211 	{
212 		pBrowseMerk->EndChangeEntry();
213 		pBrowseMerk->GrabFocus();
214 		pBrowseMerk->KeyInput(rKEvt);
215 	}
216 	else
217 		Edit::KeyInput(rKEvt);
218 }
219 
220 ////////////////////////////////////////////////////////////////////////////////////////////////////
221 
222 #define MYBROWSEMODE (BROWSER_THUMBDRAGGING|BROWSER_KEEPHIGHLIGHT|BROWSER_NO_HSCROLL|BROWSER_HIDECURSOR)
223 
224 _SdrItemBrowserControl::_SdrItemBrowserControl(Window* pParent, WinBits nBits):
225 	BrowseBox(pParent,nBits,MYBROWSEMODE),
226 	aList(1024,16,16)
227 {
228 	ImpCtor();
229 }
230 
231 __EXPORT _SdrItemBrowserControl::~_SdrItemBrowserControl()
232 {
233 	if(pEditControl)
234 		delete pEditControl;
235 
236 	if(pAktChangeEntry)
237 		delete pAktChangeEntry;
238 
239 	Clear();
240 }
241 
242 void _SdrItemBrowserControl::ImpCtor()
243 {
244 	pEditControl = NULL;
245 	pAktChangeEntry = NULL;
246 	nLastWhichOfs = 0;
247 	nLastWhich = 0;
248 	nLastWhichOben = 0;  // not implemented yet
249 	nLastWhichUnten = 0; // not implemented yet
250 	bWhichesButNames = sal_False;
251 	bDontHideIneffectiveItems = sal_False;
252 	bDontSortItems = sal_False;
253 	bShowWhichIds = sal_False;
254 	bShowRealValues = sal_False;
255 	bShowWhichIds = sal_True;   // not implemented yet
256 	bShowRealValues = sal_True; // not implemented yet
257 
258 	rtl_TextEncoding aTextEncoding = gsl_getSystemTextEncoding();
259 
260 	InsertDataColumn(
261 		ITEMBROWSER_WHICHCOL_ID,
262 		String("Which", aTextEncoding),
263 		GetTextWidth(String(" Which ", aTextEncoding)) + 2);
264 	InsertDataColumn(
265 		ITEMBROWSER_STATECOL_ID,
266 		String("State", aTextEncoding),
267 		Max(GetTextWidth(String(" State ", aTextEncoding)) + 2 ,
268 			GetTextWidth(String("DontCare", aTextEncoding)) + 2));
269 	InsertDataColumn(
270 		ITEMBROWSER_TYPECOL_ID ,
271 		String("Type", aTextEncoding),
272 		GetTextWidth(String(" Type_ ", aTextEncoding)) + 2);
273 	InsertDataColumn(
274 		ITEMBROWSER_NAMECOL_ID ,
275 		String("Name", aTextEncoding),
276 		150);
277 	InsertDataColumn(
278 		ITEMBROWSER_VALUECOL_ID,
279 		String("Value", aTextEncoding),
280 		GetTextWidth(String("12345678901234567890", aTextEncoding)));
281 	SetDataRowHeight(
282 		GetTextHeight());
283 
284 	long nWdt=GetColumnWidth(ITEMBROWSER_WHICHCOL_ID)+
285 			  GetColumnWidth(ITEMBROWSER_STATECOL_ID)+
286 			  GetColumnWidth(ITEMBROWSER_TYPECOL_ID )+
287 			  GetColumnWidth(ITEMBROWSER_NAMECOL_ID )+
288 			  GetColumnWidth(ITEMBROWSER_VALUECOL_ID);
289 
290 	long nHgt=GetTitleHeight()+16*GetDataRowHeight();
291 
292 	SetOutputSizePixel(Size(nWdt,nHgt));
293 }
294 
295 void _SdrItemBrowserControl::Clear()
296 {
297 	sal_uIntPtr nAnz=aList.Count();
298 	for (sal_uIntPtr nNum=0; nNum<nAnz; nNum++) {
299 		delete ImpGetEntry(nNum);
300 	}
301 	aList.Clear();
302 	BrowseBox::Clear();
303 }
304 
305 long __EXPORT _SdrItemBrowserControl::GetRowCount() const
306 {
307 	return aList.Count();
308 }
309 
310 sal_Bool __EXPORT _SdrItemBrowserControl::SeekRow(long nRow)
311 {
312 	nAktPaintRow=nRow;
313 	return sal_True;
314 }
315 
316 String _SdrItemBrowserControl::GetCellText(long _nRow, sal_uInt16 _nColId) const
317 {
318 	String sRet;
319 	if ( _nRow >= 0 && _nRow < (sal_Int32)aList.Count() )
320 	{
321 		ImpItemListRow* pEntry = ImpGetEntry(_nRow);
322 		if ( pEntry )
323 		{
324 			if ( pEntry->bComment )
325 			{
326 				if (_nColId == ITEMBROWSER_NAMECOL_ID)
327 					sRet = pEntry->aName;
328 			}
329 			else
330 			{
331 				rtl_TextEncoding aTextEncoding = gsl_getSystemTextEncoding();
332 
333 				sRet = XubString("???", aTextEncoding);
334 				switch (_nColId)
335 				{
336 					case ITEMBROWSER_WHICHCOL_ID:
337 						sRet = UniString::CreateFromInt32(pEntry->nWhichId); break;
338 					case ITEMBROWSER_STATECOL_ID:
339 					{
340 						switch (pEntry->eState)
341 						{
342 							case SFX_ITEM_UNKNOWN : sRet=String("Uknown", aTextEncoding);   break;
343 							case SFX_ITEM_DISABLED: sRet=String("Disabled", aTextEncoding); break;
344 							case SFX_ITEM_DONTCARE: sRet=String("DontCare", aTextEncoding); break;
345 							case SFX_ITEM_SET     : sRet=String("Set", aTextEncoding);      break;
346 							case SFX_ITEM_DEFAULT : sRet=String("Default", aTextEncoding);  break;
347 						} // switch
348 					} break;
349 					case ITEMBROWSER_TYPECOL_ID: sRet = pEntry->GetItemTypeStr(); break;
350 					case ITEMBROWSER_NAMECOL_ID: sRet = pEntry->aName; break;
351 					case ITEMBROWSER_VALUECOL_ID: sRet = pEntry->aValue; break;
352 				} // switch
353 			}
354 		}
355 	}
356 	return sRet;
357 }
358 
359 void __EXPORT _SdrItemBrowserControl::PaintField(OutputDevice& rDev, const Rectangle& rRect, sal_uInt16 nColumnId) const
360 {
361 	if (nAktPaintRow<0 || (sal_uIntPtr)nAktPaintRow>=aList.Count()) {
362 		return;
363 	}
364 	Rectangle aR(rRect);
365 	aR.Bottom()++;
366 	ImpItemListRow* pEntry=ImpGetEntry(nAktPaintRow);
367 	if (pEntry->bComment)
368 	{
369 		if (nColumnId==ITEMBROWSER_NAMECOL_ID)
370 		{
371 			rDev.SetLineColor();
372 			rDev.SetFillColor( Color( COL_LIGHTGRAY ) );
373 			aR.Left()=0;
374 			aR.Right()=rDev.GetOutputSize().Width();
375 			rDev.DrawRect(aR);
376 			rDev.DrawText(rRect.TopLeft(),pEntry->aName);
377 		}
378 	} else {
379 		rDev.SetClipRegion(aR);
380 		rDev.DrawText(aR.TopLeft(),GetCellText(nAktPaintRow,nColumnId));
381 		rDev.SetClipRegion();
382 	}
383 }
384 
385 sal_uIntPtr _SdrItemBrowserControl::GetCurrentPos() const
386 {
387 	sal_uIntPtr nRet=CONTAINER_ENTRY_NOTFOUND;
388 	if (GetSelectRowCount()==1) {
389 		long nPos=((BrowseBox*)this)->FirstSelectedRow();
390 		if (nPos>=0 && (sal_uIntPtr)nPos<aList.Count()) {
391 			nRet=(sal_uIntPtr)nPos;
392 		}
393 	}
394 	return nRet;
395 }
396 
397 sal_uInt16 _SdrItemBrowserControl::GetCurrentWhich() const
398 {
399 	sal_uInt16 nRet=0;
400 	sal_uIntPtr nPos=GetCurrentPos();
401 	if (nPos!=CONTAINER_ENTRY_NOTFOUND) {
402 		nRet=ImpGetEntry(nPos)->nWhichId;
403 	}
404 	return nRet;
405 }
406 
407 void __EXPORT _SdrItemBrowserControl::DoubleClick(const BrowserMouseEvent&)
408 {
409 	sal_uIntPtr nPos=GetCurrentPos();
410 	if (nPos!=CONTAINER_ENTRY_NOTFOUND) {
411 		BegChangeEntry(nPos);
412 	}
413 }
414 
415 void __EXPORT _SdrItemBrowserControl::KeyInput(const KeyEvent& rKEvt)
416 {
417 	sal_uInt16 nKeyCode=rKEvt.GetKeyCode().GetCode()+rKEvt.GetKeyCode().GetModifier();
418 	FASTBOOL bAusgewertet=sal_False;
419 	sal_uIntPtr nPos=GetCurrentPos();
420 	if (nPos!=CONTAINER_ENTRY_NOTFOUND) {
421 		if (nKeyCode==KEY_RETURN) {
422 			if (BegChangeEntry(nPos)) bAusgewertet=sal_True;
423 		} else if (nKeyCode==KEY_ESCAPE) {
424 			// ...
425 		} else if (rKEvt.GetKeyCode().GetModifier()==KEY_SHIFT+KEY_MOD1+KEY_MOD2) { // Strg
426 			if (nKeyCode==KEY_SHIFT+KEY_MOD1+KEY_MOD2+KEY_W) {
427 				bWhichesButNames=!bWhichesButNames;
428 				SetDirty();
429 			}
430 			if (nKeyCode==KEY_SHIFT+KEY_MOD1+KEY_MOD2+KEY_I) {
431 				bDontHideIneffectiveItems=!bDontHideIneffectiveItems;
432 				SetDirty();
433 			}
434 			if (nKeyCode==KEY_SHIFT+KEY_MOD1+KEY_MOD2+KEY_S) {
435 				bDontSortItems=!bDontSortItems;
436 				SetDirty();
437 			}
438 		}
439 	}
440 	if (!bAusgewertet) BrowseBox::KeyInput(rKEvt);
441 }
442 
443 void _SdrItemBrowserControl::SetDirty()
444 {
445 	aSetDirtyHdl.Call(this);
446 }
447 
448 Rectangle _SdrItemBrowserControl::GetFieldCharacterBounds(sal_Int32 /*_nRow*/,sal_Int32 /*_nColumnPos*/,sal_Int32 /*nIndex*/)
449 {
450     // no accessibility implementation required
451     return Rectangle();
452 }
453 
454 sal_Int32 _SdrItemBrowserControl::GetFieldIndexAtPoint(sal_Int32 /*_nRow*/,sal_Int32 /*_nColumnPos*/,const Point& /*_rPoint*/)
455 {
456     // no accessibility implementation required
457     return -1;
458 }
459 
460 void __EXPORT _SdrItemBrowserControl::Select()
461 {
462 	EndChangeEntry();
463 	BrowseBox::Select();
464 	ImpSaveWhich();
465 }
466 
467 void _SdrItemBrowserControl::ImpSaveWhich()
468 {
469 	sal_uInt16 nWh=GetCurrentWhich();
470 	if (nWh!=0) {
471 		long nPos=GetCurrentPos();
472 		long nTop=GetTopRow();
473 		long nBtm=GetTopRow()+GetVisibleRows()+1;
474 		nLastWhich=nWh;
475 		nLastWhichOfs=nPos-nTop;
476 		if (nTop<0) nTop=0;
477 		if (nBtm>=(long)aList.Count()) nBtm=aList.Count()-1;
478 		nLastWhichOben=ImpGetEntry(nTop)->nWhichId;
479 		nLastWhichUnten=ImpGetEntry(nBtm)->nWhichId;
480 	}
481 }
482 
483 void _SdrItemBrowserControl::ImpRestoreWhich()
484 {
485 	if (nLastWhich!=0) {
486 		FASTBOOL bFnd=sal_False;
487 		sal_uInt16 nBestMinWh=0,nBestMaxWh=0xFFFF;       // not implemented yet
488 		sal_uIntPtr nBestMinPos=0,nBestMaxPos=0xFFFFFFFF;  // not implemented yet
489 		sal_uIntPtr nAnz=aList.Count();
490 		sal_uIntPtr nNum;
491 		for (nNum=0; nNum<nAnz && !bFnd; nNum++) {
492 			ImpItemListRow* pEntry=ImpGetEntry(nNum);
493 			if (!pEntry->bComment) {
494 				sal_uInt16 nWh=pEntry->nWhichId;
495 				if (nWh==nLastWhich) bFnd=sal_True;
496 				else if (nWh<nLastWhich && nWh>nBestMinWh) nBestMinPos=nNum;
497 				else if (nWh>nLastWhich && nWh<nBestMaxWh) nBestMaxPos=nNum;
498 			}
499 		}
500 		if (bFnd) {
501 			long nPos=nNum-1;
502 			long nWhichOfs=nPos-GetTopRow();
503 			if (nWhichOfs!=nLastWhichOfs) {
504 				ScrollRows(nWhichOfs-nLastWhichOfs);
505 			}
506 			GoToRow(nPos);
507 		}
508 	}
509 }
510 
511 FASTBOOL _SdrItemBrowserControl::BegChangeEntry(sal_uIntPtr nPos)
512 {
513 	BrkChangeEntry();
514 	FASTBOOL bRet=sal_False;
515 	ImpItemListRow* pEntry=ImpGetEntry(nPos);
516 	if (pEntry!=NULL && !pEntry->bComment) {
517 		SetMode(MYBROWSEMODE & ~BROWSER_KEEPHIGHLIGHT);
518 		pEditControl=new ImpItemEdit(&GetDataWindow(),this,0/*|WB_BORDER|WB_3DLOOK*/);
519 		Rectangle aRect(GetFieldRectPixel(nPos,ITEMBROWSER_VALUECOL_ID,sal_False));
520 		aRect.Left()+=2; // Kleiner Offset fuer's Edit, damit's pixelgenau stimmt
521 		aRect.Right()--;
522 		pEditControl->SetPosSizePixel(aRect.TopLeft(),aRect.GetSize());
523 		pEditControl->SetText(pEntry->aValue);
524 		pEditControl->SetBackground( Wallpaper(Color(COL_LIGHTGRAY)));
525 		Font aFont(pEditControl->GetFont());
526 		aFont.SetFillColor(Color(COL_LIGHTGRAY));
527 		pEditControl->SetFont(aFont);
528 		pEditControl->Show();
529 		pEditControl->GrabFocus();
530 		pEditControl->SetSelection(Selection(SELECTION_MIN,SELECTION_MAX));
531 		Window* pParent=GetParent();
532 		aWNamMerk=pParent->GetText();
533 		XubString aNeuNam(aWNamMerk);
534 		aNeuNam += sal_Unicode(' ');
535 		aNeuNam += pEntry->GetItemTypeStr();
536 		if (pEntry->bCanNum) {
537 			aNeuNam.AppendAscii(": ");
538 			aNeuNam += UniString::CreateFromInt32(pEntry->nMin);
539 			aNeuNam.AppendAscii("..");
540 			aNeuNam += UniString::CreateFromInt32(pEntry->nMax);
541 		}
542 		aNeuNam.AppendAscii(" - Type 'del' to reset to default.");
543 		pParent->SetText(aNeuNam);
544 		pAktChangeEntry=new ImpItemListRow(*pEntry);
545 		bRet=sal_True;
546 	}
547 	return bRet;
548 }
549 
550 FASTBOOL _SdrItemBrowserControl::EndChangeEntry()
551 {
552 	FASTBOOL bRet=sal_False;
553 	if (pEditControl!=NULL) {
554 		aEntryChangedHdl.Call(this);
555 		delete pEditControl;
556 		pEditControl=NULL;
557 		delete pAktChangeEntry;
558 		pAktChangeEntry=NULL;
559 		Window* pParent=GetParent();
560 		pParent->SetText(aWNamMerk);
561 		SetMode(MYBROWSEMODE);
562 		bRet=sal_True;
563 	}
564 	return bRet;
565 }
566 
567 void _SdrItemBrowserControl::BrkChangeEntry()
568 {
569 	if (pEditControl!=NULL) {
570 		delete pEditControl;
571 		pEditControl=NULL;
572 		delete pAktChangeEntry;
573 		pAktChangeEntry=NULL;
574 		Window* pParent=GetParent();
575 		pParent->SetText(aWNamMerk);
576 		SetMode(MYBROWSEMODE);
577 	}
578 }
579 
580 void _SdrItemBrowserControl::ImpSetEntry(const ImpItemListRow& rEntry, sal_uIntPtr nEntryNum)
581 {
582 	ImpItemListRow* pAktEntry=ImpGetEntry(nEntryNum);
583 	if (pAktEntry==NULL) {
584 		aList.Insert(new ImpItemListRow(rEntry),CONTAINER_APPEND);
585 		RowInserted(nEntryNum);
586 	} else if (*pAktEntry!=rEntry) {
587 		FASTBOOL bStateDiff=rEntry.eState!=pAktEntry->eState;
588 		FASTBOOL bValueDiff=!rEntry.aValue.Equals(pAktEntry->aValue);
589 		FASTBOOL bAllDiff=sal_True;
590 		if (bStateDiff || bValueDiff) {
591 			// Checken, ob nur State und/oder Value geaendert
592 			ImpItemListRow aTest(rEntry);
593 			aTest.eState=pAktEntry->eState;
594 			aTest.aValue=pAktEntry->aValue;
595 			if (aTest==*pAktEntry) bAllDiff=sal_False;
596 		}
597 		*pAktEntry=rEntry;
598 		if (bAllDiff) {
599 			RowModified(nEntryNum);
600 		} else {
601 			if (bStateDiff) RowModified(nEntryNum,ITEMBROWSER_STATECOL_ID);
602 			if (bValueDiff) RowModified(nEntryNum,ITEMBROWSER_VALUECOL_ID);
603 		}
604 	}
605 }
606 
607 FASTBOOL ImpGetItem(const SfxItemSet& rSet, sal_uInt16 nWhich, const SfxPoolItem*& rpItem)
608 {
609 	SfxItemState eState=rSet.GetItemState(nWhich,sal_True,&rpItem);
610 	if (eState==SFX_ITEM_DEFAULT) {
611 		rpItem=&rSet.Get(nWhich);
612 	}
613 	return (eState==SFX_ITEM_DEFAULT || eState==SFX_ITEM_SET) && rpItem!=NULL;
614 }
615 
616 FASTBOOL IsItemIneffective(sal_uInt16 nWhich, const SfxItemSet* pSet, sal_uInt16& rIndent)
617 {
618 	rIndent=0;
619 	if (pSet==NULL) return sal_False;
620 	const SfxPoolItem* pItem=NULL;
621 	FASTBOOL bRet=sal_False;
622 	switch (nWhich) {
623 		case XATTR_LINEDASH         :
624 		case XATTR_LINEWIDTH        :
625 		case XATTR_LINECOLOR        :
626 		case XATTR_LINESTART        :
627 		case XATTR_LINEEND          :
628 		case XATTR_LINESTARTWIDTH   :
629 		case XATTR_LINEENDWIDTH     :
630 		case XATTR_LINESTARTCENTER  :
631 		case XATTR_LINEENDCENTER    :
632 		case XATTR_LINETRANSPARENCE : {
633 			rIndent=1;
634 			if (ImpGetItem(*pSet,XATTR_LINESTYLE,pItem)) {
635 				XLineStyle eLineStyle=((const XLineStyleItem*)pItem)->GetValue();
636 				if (eLineStyle==XLINE_NONE) return sal_True;
637 				if (eLineStyle!=XLINE_DASH && nWhich==XATTR_LINEDASH) return sal_True;
638 			}
639 			if (nWhich==XATTR_LINESTART || nWhich==XATTR_LINESTARTCENTER) {
640 				rIndent=2;
641 				if (ImpGetItem(*pSet,XATTR_LINESTARTWIDTH,pItem)) {
642 					sal_Int32 nWdt=((const XLineStartWidthItem*)pItem)->GetValue();
643 					if (nWdt==0) return sal_True;
644 				}
645 			}
646 			if (nWhich==XATTR_LINEEND || nWhich==XATTR_LINEENDCENTER) {
647 				rIndent=2;
648 				if (ImpGetItem(*pSet,XATTR_LINEENDWIDTH,pItem)) {
649 					sal_Int32 nWdt=((const XLineEndWidthItem*)pItem)->GetValue();
650 					if (nWdt==0) return sal_True;
651 				}
652 			}
653 		} break;
654 		case XATTR_FILLCOLOR           : /*nur bei Style=Color*/
655 		case XATTR_FILLGRADIENT        : /*nur bei Style=Gradient*/
656 		case XATTR_FILLHATCH           : /*nur bei Style=Hatch*/
657 		case XATTR_FILLTRANSPARENCE    : /*nur bei Style=Color*/
658 		case XATTR_GRADIENTSTEPCOUNT   : /*nur bei Style=Gradient*/
659 		case XATTR_FILLBACKGROUND	   : /*nur bei Style=Hatch*/
660 		{
661 			rIndent=1;
662 			if (ImpGetItem(*pSet,XATTR_FILLSTYLE,pItem)) {
663 				XFillStyle eFillStyle=((const XFillStyleItem*)pItem)->GetValue();
664 				if (eFillStyle==XFILL_NONE) return sal_True;
665 				// Transparenz z.Zt. nur fuer SolidFill
666 				if (eFillStyle!=XFILL_SOLID && (nWhich==XATTR_FILLCOLOR || nWhich==XATTR_FILLTRANSPARENCE)) return sal_True;
667 				if (eFillStyle!=XFILL_GRADIENT && (nWhich==XATTR_FILLGRADIENT || nWhich==XATTR_GRADIENTSTEPCOUNT)) return sal_True;
668 				if (eFillStyle!=XFILL_HATCH && (nWhich==XATTR_FILLHATCH || nWhich==XATTR_FILLBACKGROUND)) return sal_True;
669 			}
670 		} break;
671 		case XATTR_FILLBITMAP          :
672 		case XATTR_FILLBMP_TILE        :
673 		case XATTR_FILLBMP_POS         : /* z.Zt. nur wenn TILE=sal_True */
674 		case XATTR_FILLBMP_SIZEX       : /* nur wenn nicht Stretch */
675 		case XATTR_FILLBMP_SIZEY       : /* nur wenn nicht Stretch */
676 		case XATTR_FILLBMP_SIZELOG     : /* nur wenn SIZELOG=sal_False zum ruecksetzen auf sal_True (alt) -> doch noch in Gebrauch */
677 		case XATTR_FILLBMP_TILEOFFSETX : /* nur wenn TILE=sal_True */
678 		case XATTR_FILLBMP_TILEOFFSETY : /* nur wenn TILE=sal_True */
679 		case XATTR_FILLBMP_STRETCH     : /* nur wenn TILE=sal_False */
680 		case XATTR_FILLBMP_POSOFFSETX  : /* nur wenn TILE=sal_True*/
681 		case XATTR_FILLBMP_POSOFFSETY  : { /* nur wenn TILE=sal_True*/
682 			rIndent=1;
683 			if (ImpGetItem(*pSet,XATTR_FILLSTYLE,pItem)) {
684 				XFillStyle eFillStyle=((const XFillStyleItem*)pItem)->GetValue();
685 				if (eFillStyle!=XFILL_BITMAP) return sal_True;
686 			}
687 			if (nWhich==XATTR_FILLBITMAP || nWhich==XATTR_FILLBMP_TILE) {
688 				return sal_False; // immer anwaehlbar
689 			}
690 			FASTBOOL bTileTRUE=sal_False;
691 			FASTBOOL bTileFALSE=sal_False;
692 			FASTBOOL bStretchTRUE=sal_False;
693 			FASTBOOL bStretchFALSE=sal_False;
694 			if (ImpGetItem(*pSet,XATTR_FILLBMP_TILE,pItem)) {
695 				bTileTRUE=((const XFillBmpTileItem*)pItem)->GetValue();
696 				bTileFALSE=!bTileTRUE;
697 			}
698 			if (ImpGetItem(*pSet,XATTR_FILLBMP_STRETCH,pItem)) {
699 				bStretchTRUE=((const XFillBmpStretchItem*)pItem)->GetValue();
700 				bStretchFALSE=!bStretchTRUE;
701 			}
702 			// Stretch nicht anwaehlbar, wenn Tile=TRUE
703 			if (nWhich==XATTR_FILLBMP_STRETCH) return bTileTRUE;
704 			// und uebrig bleiben 7+1 Item (Unterattribute)
705 			rIndent=2;
706 			// Pos (enum) nicht anwaehlbar, wenn Tile=FALSE
707 			if (nWhich==XATTR_FILLBMP_POS) return bTileFALSE;
708 			// SizeXY nicht anwaehlbar bei Stretch=TRUE
709 			if (nWhich==XATTR_FILLBMP_SIZEX || nWhich==XATTR_FILLBMP_SIZEY) {
710 				return bTileFALSE && bStretchTRUE;
711 			}
712 			// 2 Items speziell fuer Tile
713 			if (nWhich==XATTR_FILLBMP_POSOFFSETX  || nWhich==XATTR_FILLBMP_POSOFFSETY) {
714 				return bTileFALSE;
715 			}
716 			// Noch 2 Items speziell fuer Tile die sich jedoch gegenseitig ausschliessen
717 			if (nWhich==XATTR_FILLBMP_TILEOFFSETX || nWhich==XATTR_FILLBMP_TILEOFFSETY) {
718 				if (bTileFALSE) return sal_True;
719 				sal_uInt16 nX=0,nY=0;
720 				FASTBOOL bX=sal_False,bY=sal_False;
721 				if (ImpGetItem(*pSet,XATTR_FILLBMP_TILEOFFSETX,pItem)) {
722 					nX=((const XFillBmpTileOffsetXItem*)pItem)->GetValue();
723 					bX=sal_True;
724 				}
725 				if (ImpGetItem(*pSet,XATTR_FILLBMP_TILEOFFSETY,pItem)) {
726 					nY=((const XFillBmpTileOffsetYItem*)pItem)->GetValue();
727 					bY=sal_True;
728 				}
729 				if (nWhich==XATTR_FILLBMP_TILEOFFSETX) {
730 					if (nX!=0 || !bX) return sal_False;
731 					if (nY!=0) return sal_True;
732 				} else {
733 					if (nY!=0 || !bY) return sal_False;
734 					if (nX!=0) return sal_True;
735 				}
736 			}
737 			// SizeLog nicht anwaehlbar bei Stretch=TRUE
738 			// und sonst auch nur wenn es auf SizeLog=sal_False gesetzt ist.
739 			// -> wohl doch noch in Gebrauch
740 			// (sal_True ist der statische PoolDefault)
741 			if (nWhich==XATTR_FILLBMP_SIZELOG) {
742 				if (bTileFALSE && bStretchTRUE) return sal_True;
743 			}
744 		} break;
745 
746 		case XATTR_FORMTXTADJUST    :
747 		case XATTR_FORMTXTDISTANCE  :
748 		case XATTR_FORMTXTSTART     :
749 		case XATTR_FORMTXTMIRROR    :
750 		case XATTR_FORMTXTOUTLINE   :
751 		case XATTR_FORMTXTSHADOW    :
752 		case XATTR_FORMTXTSHDWCOLOR :
753 		case XATTR_FORMTXTSHDWXVAL  :
754 		case XATTR_FORMTXTSHDWYVAL  :
755 		case XATTR_FORMTXTSTDFORM   :
756 		case XATTR_FORMTXTHIDEFORM  :
757 		case XATTR_FORMTXTSHDWTRANSP: {
758 			rIndent=1;
759 			if (ImpGetItem(*pSet,XATTR_FORMTXTSTYLE,pItem)) {
760 				XFormTextStyle eStyle=((const XFormTextStyleItem*)pItem)->GetValue();
761 				if (eStyle==XFT_NONE) return sal_True;
762 			}
763 			if ((nWhich>=XATTR_FORMTXTSHDWCOLOR && nWhich<=XATTR_FORMTXTSHDWYVAL) || nWhich>=XATTR_FORMTXTSHDWTRANSP) {
764 				rIndent=2;
765 				if (ImpGetItem(*pSet,XATTR_FORMTXTSHADOW,pItem)) {
766 					XFormTextShadow eShadow=((const XFormTextShadowItem*)pItem)->GetValue();
767 					if (eShadow==XFTSHADOW_NONE) return sal_True;
768 				}
769 			}
770 		} break;
771 
772 		case SDRATTR_SHADOWCOLOR       :
773 		case SDRATTR_SHADOWXDIST       :
774 		case SDRATTR_SHADOWYDIST       :
775 		case SDRATTR_SHADOWTRANSPARENCE:
776 		case SDRATTR_SHADOW3D          :
777 		case SDRATTR_SHADOWPERSP       : {
778 			rIndent=1;
779 			if (ImpGetItem(*pSet,SDRATTR_SHADOW,pItem)) {
780 				FASTBOOL bShadow=((const SdrShadowItem*)pItem)->GetValue();
781 				if (!bShadow) return sal_True;
782 			}
783 		} break;
784 
785 		case SDRATTR_CAPTIONANGLE: {
786 			rIndent=1;
787 			if (ImpGetItem(*pSet,SDRATTR_CAPTIONFIXEDANGLE,pItem)) {
788 				FASTBOOL bFixed=((const SdrCaptionFixedAngleItem*)pItem)->GetValue();
789 				if (!bFixed) return sal_True;
790 			}
791 		} break;
792 		case SDRATTR_CAPTIONESCREL:
793 		case SDRATTR_CAPTIONESCABS: {
794 			rIndent=1;
795 			if (ImpGetItem(*pSet,SDRATTR_CAPTIONESCISREL,pItem)) {
796 				FASTBOOL bRel=((const SdrCaptionEscIsRelItem*)pItem)->GetValue();
797 				if (bRel && nWhich==SDRATTR_CAPTIONESCABS) return sal_True;
798 				if (!bRel && nWhich==SDRATTR_CAPTIONESCREL) return sal_True;
799 			}
800 		} break;
801 		case SDRATTR_CAPTIONLINELEN: {
802 			rIndent=1;
803 			if (ImpGetItem(*pSet,SDRATTR_CAPTIONFITLINELEN,pItem)) {
804 				FASTBOOL bFit=((const SdrCaptionFitLineLenItem*)pItem)->GetValue();
805 				if (bFit) return sal_True;
806 			}
807 		} break;
808 
809 		case SDRATTR_TEXT_MINFRAMEHEIGHT:
810 		case SDRATTR_TEXT_MAXFRAMEHEIGHT: {
811 			rIndent=1;
812 			if (ImpGetItem(*pSet,SDRATTR_TEXT_AUTOGROWHEIGHT,pItem)) {
813 				FASTBOOL bAutoGrow=((const SdrTextAutoGrowHeightItem*)pItem)->GetValue();
814 				if (!bAutoGrow) return sal_True;
815 			}
816 		} break;
817 		case SDRATTR_TEXT_MINFRAMEWIDTH:
818 		case SDRATTR_TEXT_MAXFRAMEWIDTH: {
819 			rIndent=1;
820 			if (ImpGetItem(*pSet,SDRATTR_TEXT_AUTOGROWWIDTH,pItem)) {
821 				FASTBOOL bAutoGrow=((const SdrTextAutoGrowWidthItem*)pItem)->GetValue();
822 				if (!bAutoGrow) return sal_True;
823 			}
824 		} break;
825 		case SDRATTR_TEXT_VERTADJUST:
826 		case SDRATTR_TEXT_HORZADJUST: {
827 			if (ImpGetItem(*pSet,SDRATTR_TEXT_FITTOSIZE,pItem)) {
828 				SdrFitToSizeType eFit=((const SdrTextFitToSizeTypeItem*)pItem)->GetValue();
829 				if (eFit!=SDRTEXTFIT_NONE) return sal_True;
830 			}
831 		} break;
832 
833 		case SDRATTR_TEXT_ANIDIRECTION  :
834 		case SDRATTR_TEXT_ANISTARTINSIDE:
835 		case SDRATTR_TEXT_ANISTOPINSIDE :
836 		case SDRATTR_TEXT_ANICOUNT      :
837 		case SDRATTR_TEXT_ANIDELAY      :
838 		case SDRATTR_TEXT_ANIAMOUNT     : {
839 			rIndent=1;
840 			if (ImpGetItem(*pSet,SDRATTR_TEXT_ANIKIND,pItem)) {
841 				SdrTextAniKind eAniKind=((const SdrTextAniKindItem*)pItem)->GetValue();
842 				if (eAniKind==SDRTEXTANI_NONE) return sal_True;
843 				if (eAniKind==SDRTEXTANI_BLINK && (nWhich==SDRATTR_TEXT_ANIDIRECTION || nWhich==SDRATTR_TEXT_ANIAMOUNT)) return sal_True;
844 				if (eAniKind==SDRTEXTANI_SLIDE && (nWhich==SDRATTR_TEXT_ANISTARTINSIDE || nWhich==SDRATTR_TEXT_ANISTOPINSIDE)) return sal_True;
845 			}
846 		} break;
847 
848 		case SDRATTR_EDGELINEDELTAANZ: return sal_True;
849 		case SDRATTR_EDGELINE1DELTA:
850 		case SDRATTR_EDGELINE2DELTA:
851 		case SDRATTR_EDGELINE3DELTA: {
852 			if (ImpGetItem(*pSet,SDRATTR_EDGEKIND,pItem)) {
853 				SdrEdgeKind eKind=((const SdrEdgeKindItem*)pItem)->GetValue();
854 				if (eKind==SDREDGE_THREELINES) {
855 					if (nWhich>SDRATTR_EDGELINE2DELTA) return sal_True;
856 					else return sal_False;
857 				}
858 				if (eKind!=SDREDGE_ORTHOLINES && eKind!=SDREDGE_BEZIER) return sal_True;
859 			}
860 			if (ImpGetItem(*pSet,SDRATTR_EDGELINEDELTAANZ,pItem)) {
861 				sal_uInt16 nAnz=((const SdrEdgeLineDeltaAnzItem*)pItem)->GetValue();
862 				if (nAnz==0) return sal_True;
863 				if (nAnz==1 && nWhich>SDRATTR_EDGELINE1DELTA) return sal_True;
864 				if (nAnz==2 && nWhich>SDRATTR_EDGELINE2DELTA) return sal_True;
865 				if (nAnz==3 && nWhich>SDRATTR_EDGELINE3DELTA) return sal_True;
866 			}
867 		} break;
868 
869 		case SDRATTR_CIRCSTARTANGLE:
870 		case SDRATTR_CIRCENDANGLE  : {
871 			rIndent=1;
872 			if (ImpGetItem(*pSet,SDRATTR_CIRCKIND,pItem)) {
873 				SdrCircKind eKind=((const SdrCircKindItem*)pItem)->GetValue();
874 				if (eKind==SDRCIRC_FULL) return sal_True;
875 			}
876 		} break;
877 	} // switch
878 	return bRet;
879 }
880 
881 sal_uInt16 ImpSortWhich(sal_uInt16 nWhich)
882 {
883 	switch (nWhich) {
884 		// Line
885 		case XATTR_LINESTART            : nWhich=XATTR_LINETRANSPARENCE     ; break;
886 		case XATTR_LINEEND              : nWhich=XATTR_LINESTARTWIDTH       ; break;
887 		case XATTR_LINESTARTWIDTH       : nWhich=XATTR_LINESTART            ; break;
888 		case XATTR_LINEENDWIDTH         : nWhich=XATTR_LINESTARTCENTER      ; break;
889 		case XATTR_LINESTARTCENTER      : nWhich=XATTR_LINEENDWIDTH         ; break;
890 		case XATTR_LINEENDCENTER        : nWhich=XATTR_LINEEND              ; break;
891 		case XATTR_LINETRANSPARENCE     : nWhich=XATTR_LINEENDCENTER        ; break;
892 
893 		// Fill
894 		case XATTR_FILLBMP_POS          : nWhich=XATTR_FILLBMP_STRETCH      ; break;
895 		case XATTR_FILLBMP_SIZEX        : nWhich=XATTR_FILLBMP_POS          ; break;
896 		case XATTR_FILLBMP_SIZEY        : nWhich=XATTR_FILLBMP_SIZEX        ; break;
897 		case XATTR_FILLBMP_SIZELOG      : nWhich=XATTR_FILLBMP_SIZEY        ; break;
898 		case XATTR_FILLBMP_TILEOFFSETX  : nWhich=XATTR_FILLBMP_SIZELOG      ; break;
899 		case XATTR_FILLBMP_TILEOFFSETY  : nWhich=XATTR_FILLBMP_TILEOFFSETX  ; break;
900 		case XATTR_FILLBMP_STRETCH      : nWhich=XATTR_FILLBMP_TILEOFFSETY  ; break;
901 
902 		// Fontwork
903 		case XATTR_FORMTXTSHADOW        : nWhich=XATTR_FORMTXTSTDFORM       ; break;
904 		case XATTR_FORMTXTSHDWCOLOR     : nWhich=XATTR_FORMTXTHIDEFORM      ; break;
905 		case XATTR_FORMTXTSHDWXVAL      : nWhich=XATTR_FORMTXTSHADOW        ; break;
906 		case XATTR_FORMTXTSHDWYVAL      : nWhich=XATTR_FORMTXTSHDWCOLOR     ; break;
907 		case XATTR_FORMTXTSTDFORM       : nWhich=XATTR_FORMTXTSHDWXVAL      ; break;
908 		case XATTR_FORMTXTHIDEFORM      : nWhich=XATTR_FORMTXTSHDWYVAL      ; break;
909 
910 		// Misc
911 		case SDRATTR_TEXT_MINFRAMEHEIGHT: nWhich=SDRATTR_TEXT_FITTOSIZE     ; break;
912 		case SDRATTR_TEXT_AUTOGROWHEIGHT: nWhich=SDRATTR_TEXT_LEFTDIST      ; break;
913 		case SDRATTR_TEXT_FITTOSIZE     : nWhich=SDRATTR_TEXT_RIGHTDIST     ; break;
914 		case SDRATTR_TEXT_LEFTDIST      : nWhich=SDRATTR_TEXT_UPPERDIST     ; break;
915 		case SDRATTR_TEXT_RIGHTDIST     : nWhich=SDRATTR_TEXT_LOWERDIST     ; break;
916 		case SDRATTR_TEXT_UPPERDIST     : nWhich=SDRATTR_TEXT_AUTOGROWWIDTH ; break;
917 		case SDRATTR_TEXT_LOWERDIST     : nWhich=SDRATTR_TEXT_MINFRAMEWIDTH ; break;
918 		case SDRATTR_TEXT_VERTADJUST    : nWhich=SDRATTR_TEXT_MAXFRAMEWIDTH ; break;
919 		case SDRATTR_TEXT_MAXFRAMEHEIGHT: nWhich=SDRATTR_TEXT_AUTOGROWHEIGHT; break;
920 		case SDRATTR_TEXT_MINFRAMEWIDTH : nWhich=SDRATTR_TEXT_MINFRAMEHEIGHT; break;
921 		case SDRATTR_TEXT_MAXFRAMEWIDTH : nWhich=SDRATTR_TEXT_MAXFRAMEHEIGHT; break;
922 		case SDRATTR_TEXT_AUTOGROWWIDTH : nWhich=SDRATTR_TEXT_HORZADJUST    ; break;
923 		case SDRATTR_TEXT_HORZADJUST    : nWhich=SDRATTR_TEXT_VERTADJUST    ; break;
924 	} // switch
925 	return nWhich;
926 }
927 
928 #define INSERTCOMMENT(nStartId,nEndId,aStr) \
929     { if (nWhich0<nStartId && nWhich>=nStartId && nWhich<=nEndId) aCommentStr=aStr; }
930 
931 void _SdrItemBrowserControl::SetAttributes(const SfxItemSet* pSet, const SfxItemSet* p2ndSet)
932 {
933 	SetMode(MYBROWSEMODE & ~BROWSER_KEEPHIGHLIGHT);
934 	if (pSet!=NULL) {
935 		rtl_TextEncoding aTextEncoding = gsl_getSystemTextEncoding();
936 		sal_uInt16 nEntryNum=0;
937 		SfxWhichIter aIter(*pSet);
938 		const SfxItemPool* pPool=pSet->GetPool();
939 		sal_uInt16 nWhich0=0;
940 		sal_uInt16 nWhich=aIter.FirstWhich();
941 		while (nWhich!=0) {
942 			// Nun erstmal etwas umsortieren
943 			// Geht nur, solange keine InvalidItems, d.h. keine Luecken
944 			// an dieser Stelle im Set sind
945 			if (!bDontSortItems) nWhich=ImpSortWhich(nWhich);
946 			SfxItemState eState=pSet->GetItemState(nWhich);
947 			if (p2ndSet!=NULL) {
948 				SfxItemState e2ndState=p2ndSet->GetItemState(nWhich);
949 				if (eState==SFX_ITEM_DEFAULT) eState=SFX_ITEM_DISABLED;
950 				else if (e2ndState==SFX_ITEM_DEFAULT) eState=SFX_ITEM_DEFAULT;
951 			}
952 			if (eState!=SFX_ITEM_DISABLED) {
953 				const SfxPoolItem& rItem=pSet->Get(nWhich);
954 				sal_uInt16 nIndent=0;
955 				if (!HAS_BASE(SfxVoidItem,&rItem) && !HAS_BASE(SfxSetItem,&rItem) && (!IsItemIneffective(nWhich,pSet,nIndent) || bDontHideIneffectiveItems)) {
956 					XubString aCommentStr;
957 
958 					INSERTCOMMENT(XATTR_LINE_FIRST,XATTR_LINE_LAST,String("L I N I E", aTextEncoding));
959                     INSERTCOMMENT(XATTR_FILL_FIRST,XATTR_FILL_LAST,String("F L � C H E", aTextEncoding));
960 					INSERTCOMMENT(XATTR_TEXT_FIRST,XATTR_TEXT_LAST,String("F O N T W O R K", aTextEncoding));
961 					INSERTCOMMENT(SDRATTR_SHADOW_FIRST,SDRATTR_SHADOW_LAST,String("S C H A T T E N", aTextEncoding));
962 					INSERTCOMMENT(SDRATTR_CAPTION_FIRST,SDRATTR_CAPTION_LAST,String("L E G E N D E", aTextEncoding));
963 					INSERTCOMMENT(SDRATTR_MISC_FIRST,SDRATTR_MISC_LAST,String("V E R S C H I E D E N E S", aTextEncoding));
964 					INSERTCOMMENT(SDRATTR_EDGE_FIRST,SDRATTR_EDGE_LAST,String("V E R B I N D E R", aTextEncoding));
965 					INSERTCOMMENT(SDRATTR_MEASURE_FIRST,SDRATTR_MEASURE_LAST,String("B E M A S S U N G", aTextEncoding));
966 					INSERTCOMMENT(SDRATTR_CIRC_FIRST,SDRATTR_CIRC_LAST,String("K R E I S", aTextEncoding));
967 					INSERTCOMMENT(SDRATTR_NOTPERSIST_FIRST,SDRATTR_NOTPERSIST_LAST,String("N O T P E R S I S T", aTextEncoding));
968 					INSERTCOMMENT(SDRATTR_MOVEX,SDRATTR_VERTSHEARONE,String("Transformationen auf alle Objekte einzeln", aTextEncoding));
969 					INSERTCOMMENT(SDRATTR_RESIZEXALL,SDRATTR_VERTSHEARALL,String("Transformationen auf alle Objekte gemeinsam", aTextEncoding));
970 					INSERTCOMMENT(SDRATTR_TRANSFORMREF1X,SDRATTR_TRANSFORMREF2Y,String("View-Referenzpunkte", aTextEncoding));
971 					INSERTCOMMENT(SDRATTR_GRAF_FIRST,SDRATTR_GRAF_LAST,String("G R A F I K", aTextEncoding));
972 					INSERTCOMMENT(EE_ITEMS_START,EE_ITEMS_END,String("E D I T  E N G I N E", aTextEncoding));
973 					INSERTCOMMENT(EE_ITEMS_END+1,EE_ITEMS_END+1,String("... by Joe Merten, JME Engineering Berlin ...", aTextEncoding));
974 
975 					if(aCommentStr.Len())
976 					{
977 						ImpItemListRow aEntry;
978 						aEntry.bComment=sal_True;
979 						aEntry.aName=aCommentStr;
980 						ImpSetEntry(aEntry,nEntryNum);
981 						nEntryNum++;
982 					}
983 					nWhich0=nWhich;
984 					ImpItemListRow aEntry;
985 					SdrItemPool::TakeItemName(nWhich, aEntry.aName);
986 					nIndent*=2;
987 
988 					while(nIndent > 0)
989 					{
990 						aEntry.aName.Insert(sal_Unicode(' '), 0);
991 						nIndent--;
992 					}
993 
994 					aEntry.eState=eState;
995 					aEntry.nWhichId=nWhich;
996 					if (!IsInvalidItem(&rItem)) {
997 						aEntry.pType=rItem.Type();
998 						aEntry.nMax=0x7FFFFFFF;
999 						aEntry.nMin=-aEntry.nMax;
1000 						aEntry.nVal=-4711;
1001 						if      (HAS_BASE(SfxByteItem     ,&rItem)) aEntry.eItemType=ITEM_BYTE;
1002 						else if (HAS_BASE(SfxInt16Item    ,&rItem)) aEntry.eItemType=ITEM_INT16;
1003 						else if (HAS_BASE(SfxUInt16Item   ,&rItem)) aEntry.eItemType=ITEM_UINT16;
1004 						else if (HAS_BASE(SfxInt32Item    ,&rItem)) aEntry.eItemType=ITEM_INT32;
1005 						else if (HAS_BASE(SfxUInt32Item   ,&rItem)) aEntry.eItemType=ITEM_UINT32;
1006 						else if (HAS_BASE(SfxEnumItemInterface,&rItem)) aEntry.eItemType=ITEM_ENUM;
1007 						else if (HAS_BASE(SfxBoolItem     ,&rItem)) aEntry.eItemType=ITEM_BOOL;
1008 						else if (HAS_BASE(SfxFlagItem     ,&rItem)) aEntry.eItemType=ITEM_FLAG;
1009 						else if (HAS_BASE(XColorItem      ,&rItem)) aEntry.eItemType=ITEM_XCOLOR;
1010 						else if (HAS_BASE(SfxStringItem   ,&rItem)) aEntry.eItemType=ITEM_STRING;
1011 						else if (HAS_BASE(SfxPointItem    ,&rItem)) aEntry.eItemType=ITEM_POINT;
1012 						else if (HAS_BASE(SfxRectangleItem,&rItem)) aEntry.eItemType=ITEM_RECT;
1013 						else if (HAS_BASE(SfxRangeItem    ,&rItem)) aEntry.eItemType=ITEM_RANGE;
1014 						else if (HAS_BASE(SdrFractionItem ,&rItem)) aEntry.eItemType=ITEM_FRACTION;
1015 						else if (HAS_BASE(SvxColorItem    ,&rItem)) aEntry.eItemType=ITEM_COLOR;
1016 						else if (HAS_BASE(SvxFontItem     ,&rItem)) aEntry.eItemType=ITEM_FONT;
1017 						else if (HAS_BASE(SvxFontHeightItem,&rItem))aEntry.eItemType=ITEM_FONTHEIGHT;
1018 						else if (HAS_BASE(SvxCharScaleWidthItem,&rItem)) aEntry.eItemType=ITEM_FONTWIDTH;
1019 						else if (HAS_BASE(SvxFieldItem    ,&rItem)) aEntry.eItemType=ITEM_FIELD;
1020 						switch (aEntry.eItemType) {
1021 							case ITEM_BYTE      : aEntry.bIsNum=sal_True;  aEntry.nVal=((SfxByteItem  &)rItem).GetValue(); aEntry.nMin=0;      aEntry.nMax=255;   break;
1022 							case ITEM_INT16     : aEntry.bIsNum=sal_True;  aEntry.nVal=((SfxInt16Item &)rItem).GetValue(); aEntry.nMin=-32767; aEntry.nMax=32767; break;
1023 							case ITEM_UINT16    : aEntry.bIsNum=sal_True;  aEntry.nVal=((SfxUInt16Item&)rItem).GetValue(); aEntry.nMin=0;      aEntry.nMax=65535; break;
1024 							case ITEM_INT32     : aEntry.bIsNum=sal_True;  aEntry.nVal=((SfxInt32Item &)rItem).GetValue();                                        break;
1025 							case ITEM_UINT32    : aEntry.bIsNum=sal_True;  aEntry.nVal=((SfxUInt32Item&)rItem).GetValue(); aEntry.nMin=0; /*aEntry.nMax=0xFF...*/;break;
1026 							case ITEM_ENUM      : aEntry.bCanNum=sal_True; aEntry.nVal=((SfxEnumItemInterface&)rItem).GetEnumValue(); aEntry.nMin=0; aEntry.nMax=((SfxEnumItemInterface&)rItem).GetValueCount()-1; break;
1027 							case ITEM_BOOL      : aEntry.bCanNum=sal_True; aEntry.nVal=((SfxBoolItem  &)rItem).GetValue(); aEntry.nMin=0; aEntry.nMax=1;          break;
1028 							case ITEM_FLAG      : aEntry.bCanNum=sal_True; aEntry.nVal=((SfxFlagItem  &)rItem).GetValue(); aEntry.nMin=0; aEntry.nMax=0xFFFF;     break;
1029 							case ITEM_FONTHEIGHT: aEntry.bCanNum=sal_True; aEntry.nVal=((SvxFontHeightItem&)rItem).GetHeight(); aEntry.nMin=0;                    break;
1030 							case ITEM_FONTWIDTH : aEntry.bCanNum=sal_True; aEntry.nVal=((SvxCharScaleWidthItem&)rItem).GetValue();    aEntry.nMin=0; aEntry.nMax=0xFFFF;break;
1031 							default: break;
1032 						} // switch
1033 						if (aEntry.bIsNum) aEntry.bCanNum=sal_True;
1034 						FASTBOOL bGetPres=sal_True;
1035 						if (bGetPres) {
1036 							rItem.GetPresentation(SFX_ITEM_PRESENTATION_NAMELESS,
1037 												  pPool->GetMetric(nWhich),
1038 												  SFX_MAPUNIT_MM,aEntry.aValue);
1039 							if (aEntry.bCanNum) {
1040 								aEntry.aValue.InsertAscii(": ",0);
1041 								aEntry.aValue.Insert(UniString::CreateFromInt32(aEntry.nVal),0);
1042 							}
1043 						} else {
1044 							if (aEntry.eItemType==ITEM_BOOL) aEntry.aValue.AppendAscii(aEntry.nVal!=0 ? "True" : "False");
1045 							else if (aEntry.bCanNum) aEntry.aValue = UniString::CreateFromInt32(aEntry.nVal);
1046 							else if (aEntry.eItemType==ITEM_STRING) aEntry.aValue=((SfxStringItem&)rItem).GetValue();
1047 							else if (aEntry.eItemType==ITEM_ENUM && nWhich!=EE_CHAR_WEIGHT) aEntry.aValue=((SfxEnumItemInterface&)rItem).GetValueTextByPos((sal_Bool)aEntry.nVal);
1048 							else aEntry.aValue = String("GPF", aTextEncoding);
1049 						}
1050 					} else {
1051 						aEntry.aValue = String("InvalidItem", aTextEncoding);
1052 					}
1053 					ImpSetEntry(aEntry,nEntryNum);
1054 					nEntryNum++;
1055 				}
1056 			}
1057 			nWhich=aIter.NextWhich();
1058 		} // while
1059 
1060 		if (aList.Count()>nEntryNum) { // evtl. noch zuviele Eintraege
1061 			sal_uIntPtr nTooMuch=aList.Count()-nEntryNum;
1062 			for (sal_uIntPtr nNum=0; nNum<nTooMuch; nNum++) {
1063 				delete ImpGetEntry(nEntryNum);
1064 				aList.Remove(nEntryNum);
1065 			}
1066 			RowRemoved(nEntryNum,nTooMuch);
1067 		}
1068 	} else {
1069 		Clear(); // wenn pSet==NULL
1070 	}
1071 	ImpRestoreWhich();
1072 	SetMode(MYBROWSEMODE);
1073 }
1074 
1075 ////////////////////////////////////////////////////////////////////////////////////////////////////
1076 
1077 _SdrItemBrowserWindow::_SdrItemBrowserWindow(Window* pParent, WinBits nBits):
1078 	FloatingWindow(pParent,nBits),
1079 	aBrowse(this)
1080 {
1081 	SetOutputSizePixel(aBrowse.GetSizePixel());
1082 	SetText(String("Joe's ItemBrowser", gsl_getSystemTextEncoding()));
1083 	aBrowse.Show();
1084 }
1085 
1086 __EXPORT _SdrItemBrowserWindow::~_SdrItemBrowserWindow()
1087 {
1088 }
1089 
1090 void __EXPORT _SdrItemBrowserWindow::Resize()
1091 {
1092 	aBrowse.SetSizePixel(GetOutputSizePixel());
1093 }
1094 
1095 void __EXPORT _SdrItemBrowserWindow::GetFocus()
1096 {
1097 	aBrowse.GrabFocus();
1098 }
1099 
1100 ////////////////////////////////////////////////////////////////////////////////////////////////////
1101 
1102 SdrItemBrowser::SdrItemBrowser(SdrView& rView):
1103 	_SdrItemBrowserWindow(ImpGetViewWin(rView)),
1104 	pView(&rView),
1105 	bDirty(sal_False)
1106 {
1107 	aIdleTimer.SetTimeoutHdl(LINK(this,SdrItemBrowser,IdleHdl));
1108 	GetBrowserControl().SetEntryChangedHdl(LINK(this,SdrItemBrowser,ChangedHdl));
1109 	GetBrowserControl().SetSetDirtyHdl(LINK(this,SdrItemBrowser,SetDirtyHdl));
1110 	SetDirty();
1111 }
1112 
1113 Window* SdrItemBrowser::ImpGetViewWin(SdrView& rView)
1114 {
1115 	const sal_uInt32 nWinCount(rView.PaintWindowCount());
1116 
1117 	for(sal_uInt32 a(0L); a < nWinCount; a++)
1118 	{
1119 		SdrPaintWindow* pCandidate = rView.GetPaintWindow(a);
1120 
1121 		if(OUTDEV_WINDOW == pCandidate->GetOutputDevice().GetOutDevType())
1122 		{
1123 			return (Window*)(&pCandidate->GetOutputDevice());
1124 		}
1125 	}
1126 
1127 	return 0L;
1128 }
1129 
1130 void SdrItemBrowser::ForceParent()
1131 {
1132 	Window* pWin=ImpGetViewWin(*pView);
1133 	if (pWin!=NULL) SetParent(pWin);
1134 }
1135 
1136 void SdrItemBrowser::SetDirty()
1137 {
1138 	if (!bDirty) {
1139 		bDirty=sal_True;
1140 		aIdleTimer.SetTimeout(1);
1141 		aIdleTimer.Start();
1142 	}
1143 }
1144 
1145 void SdrItemBrowser::Undirty()
1146 {
1147 	aIdleTimer.Stop();
1148 	bDirty = sal_False;
1149 
1150 //	SfxItemSet aSet(pView->GetAttributes());
1151 	SfxItemSet aSet(pView->GetModel()->GetItemPool());
1152 	pView->GetAttributes(aSet);
1153 
1154 	if(pView->AreObjectsMarked())
1155 	{
1156 		// SfxItemSet a2ndSet(pView->GetAttributes(sal_True));
1157 		SfxItemSet a2ndSet(pView->GetModel()->GetItemPool());
1158 		pView->GetAttributes(a2ndSet, sal_True);
1159 
1160 		SetAttributes(&aSet,&a2ndSet);
1161 	}
1162 	else
1163 	{
1164 		SetAttributes(&aSet);
1165 	}
1166 }
1167 
1168 IMPL_LINK(SdrItemBrowser,IdleHdl,Timer*,EMPTYARG)
1169 {
1170 	Undirty();
1171 	return 0;
1172 }
1173 
1174 IMPL_LINK(SdrItemBrowser,ChangedHdl,_SdrItemBrowserControl*,pBrowse)
1175 {
1176 	const ImpItemListRow* pEntry=pBrowse->GetAktChangeEntry();
1177 	if (pEntry!=NULL)
1178 	{
1179 //		SfxItemSet aSet(pView->GetAttributes());
1180 		SfxItemSet aSet(pView->GetModel()->GetItemPool());
1181 		pView->GetAttributes(aSet);
1182 
1183 		SfxItemSet aNewSet(*aSet.GetPool(),pEntry->nWhichId,pEntry->nWhichId);
1184 		XubString aNewText(pBrowse->GetNewEntryValue());
1185 		sal_Bool bDel( aNewText.EqualsAscii("del")
1186 			|| aNewText.EqualsAscii("Del")
1187 			|| aNewText.EqualsAscii("DEL")
1188 			|| aNewText.EqualsAscii("default")
1189 			|| aNewText.EqualsAscii("Default")
1190 			|| aNewText.EqualsAscii("DEFAULT"));
1191 
1192 		if (!bDel) {
1193 			SfxPoolItem* pNewItem=aSet.Get(pEntry->nWhichId).Clone();
1194 			long nLongVal=0;
1195 			nLongVal = aNewText.ToInt32();
1196 			if (pEntry->bCanNum) {
1197 				if (nLongVal>pEntry->nMax) nLongVal=pEntry->nMax;
1198 				if (nLongVal<pEntry->nMin) nLongVal=pEntry->nMin;
1199 			}
1200 			FASTBOOL bPair=sal_False;
1201 			FASTBOOL bPairX=sal_True;
1202 			FASTBOOL bPairY=sal_False;
1203 			sal_uInt16 nSepLen=1;
1204 			long nLongX = aNewText.ToInt32();
1205 			long nLongY=0;
1206 			xub_StrLen nPos = aNewText.Search(sal_Unicode('/'));
1207 			if (nPos==STRING_NOTFOUND) nPos=aNewText.Search(sal_Unicode(':'));
1208 			if (nPos==STRING_NOTFOUND) nPos=aNewText.Search(sal_Unicode(' '));
1209 			if (nPos==STRING_NOTFOUND) { nPos=aNewText.SearchAscii(".."); if (nPos!=STRING_NOTFOUND) nSepLen=2; }
1210 			if (nPos!=STRING_NOTFOUND) {
1211 				bPair=sal_True;
1212 				bPairX=nPos>0;
1213 				XubString s(aNewText);
1214 				s.Erase(0,nPos+nSepLen);
1215 				bPairY = (sal_Bool)aNewText.Len();
1216 				nLongY = s.ToInt32();
1217 			}
1218 			switch (pEntry->eItemType) {
1219 				case ITEM_BYTE  : ((SfxByteItem  *)pNewItem)->SetValue((sal_uInt8  )nLongVal); break;
1220 				case ITEM_INT16 : ((SfxInt16Item *)pNewItem)->SetValue((sal_Int16 )nLongVal); break;
1221 				case ITEM_UINT16: ((SfxUInt16Item*)pNewItem)->SetValue((sal_uInt16)nLongVal); break;
1222 				case ITEM_INT32: {
1223 					if(HAS_BASE(SdrAngleItem, pNewItem))
1224 					{
1225 						aNewText.SearchAndReplace(sal_Unicode(','), sal_Unicode('.'));
1226 						double nVal = aNewText.ToFloat();
1227 						nLongVal = (long)(nVal * 100 + 0.5);
1228 					}
1229 					((SfxInt32Item *)pNewItem)->SetValue((sal_Int32)nLongVal);
1230 				} break;
1231 				case ITEM_UINT32: ((SfxUInt32Item*)pNewItem)->SetValue(aNewText.ToInt32()); break;
1232 				case ITEM_ENUM  : ((SfxEnumItemInterface*)pNewItem)->SetEnumValue((sal_uInt16)nLongVal); break;
1233 				case ITEM_BOOL: {
1234 					aNewText.ToUpperAscii();
1235 					if (aNewText.EqualsAscii("TRUE")) nLongVal=1;
1236 					if (aNewText.EqualsAscii("JA")) nLongVal=1;
1237 					if (aNewText.EqualsAscii("AN")) nLongVal=1;
1238 					if (aNewText.EqualsAscii("EIN")) nLongVal=1;
1239 					if (aNewText.EqualsAscii("ON")) nLongVal=1;
1240 					if (aNewText.EqualsAscii("YES")) nLongVal=1;
1241 					((SfxBoolItem*)pNewItem)->SetValue((sal_Bool)nLongVal);
1242 				} break;
1243 				case ITEM_FLAG  : ((SfxFlagItem  *)pNewItem)->SetValue((sal_uInt16)nLongVal); break;
1244 				case ITEM_STRING: ((SfxStringItem*)pNewItem)->SetValue(aNewText); break;
1245 				case ITEM_POINT : ((SfxPointItem*)pNewItem)->SetValue(Point(nLongX,nLongY)); break;
1246 				case ITEM_RECT  : break;
1247 				case ITEM_RANGE : {
1248 					((SfxRangeItem*)pNewItem)->From()=(sal_uInt16)nLongX;
1249 					((SfxRangeItem*)pNewItem)->From()=(sal_uInt16)nLongY;
1250 				} break;
1251 				case ITEM_LRANGE : {
1252 				} break;
1253 				case ITEM_FRACTION: {
1254 					if (!bPairX) nLongX=1;
1255 					if (!bPairY) nLongY=1;
1256 					((SdrFractionItem*)pNewItem)->SetValue(Fraction(nLongX,nLongY));
1257 				} break;
1258 				case ITEM_XCOLOR: break;
1259 				case ITEM_COLOR: break;
1260 				case ITEM_FONT: {
1261                     ((SvxFontItem*)pNewItem)->SetFamily( FAMILY_DONTKNOW );
1262                     ((SvxFontItem*)pNewItem)->SetFamilyName(aNewText);
1263                     ((SvxFontItem*)pNewItem)->SetStyleName( String() );
1264 				} break;
1265 				case ITEM_FONTHEIGHT: {
1266 					sal_uIntPtr nHgt=0;
1267 					sal_uInt16 nProp=100;
1268 					if (aNewText.Search(sal_Unicode('%'))!=STRING_NOTFOUND) {
1269 						nProp=(sal_uInt16)nLongVal;
1270 					} else {
1271 						nHgt=nLongVal;
1272 					}
1273 					((SvxFontHeightItem*)pNewItem)->SetHeight(nHgt,nProp);
1274 				} break;
1275 				case ITEM_FONTWIDTH: {
1276 					sal_uInt16 nProp=100;
1277 					if (aNewText.Search(sal_Unicode('%'))!=STRING_NOTFOUND) {
1278 						nProp=(sal_uInt16)nLongVal;
1279 					}
1280 					((SvxCharScaleWidthItem*)pNewItem)->SetValue(nProp);
1281 				} break;
1282 				case ITEM_FIELD: break;
1283 				default: break;
1284 			} // switch
1285 			aNewSet.Put(*pNewItem);
1286 			delete pNewItem;
1287 		}
1288 		pView->SetAttributes(aNewSet,bDel);
1289 	}
1290 	return 0;
1291 }
1292 
1293 IMPL_LINK(SdrItemBrowser,SetDirtyHdl,_SdrItemBrowserControl*,EMPTYARG)
1294 {
1295 	SetDirty();
1296 	return 0;
1297 }
1298 
1299 
1300