Author: alg Date: Fri Aug 30 09:10:27 2013 New Revision: 1518918 URL: http://svn.apache.org/r1518918 Log: i123003 Corrected Handle/Overlay visualization when TextEdit is active
Modified: openoffice/branches/AOO401/main/ (props changed) openoffice/branches/AOO401/main/svx/source/svdraw/svdmrkv.cxx Propchange: openoffice/branches/AOO401/main/ ------------------------------------------------------------------------------ --- svn:mergeinfo (added) +++ svn:mergeinfo Fri Aug 30 09:10:27 2013 @@ -0,0 +1,7 @@ +/incubator/ooo/branches/AOO34/main:1346776-1346777,1347535,1348052,1348914,1350569,1352456,1358991,1359004,1359010,1359024,1359546-1359547,1359553,1359555-1359556,1360552,1368968,1369110,1371068 +/incubator/ooo/branches/alg/linecap/main:1226811-1232461 +/incubator/ooo/branches/alg/svgreplacement/main:1205420-1220782 +/incubator/ooo/branches/writer001/main:1356067-1386577 +/openoffice/branches/alg/clibboard/main:1428975-1437368 +/openoffice/branches/sidebar/main:1415095-1466374 +/openoffice/trunk/main:1506958,1509224,1509576,1510489,1510954,1512298,1512966,1513112,1515312,1515732,1515749,1515762,1516435,1516741,1516789,1516794,1517535,1518091,1518253,1518697 Modified: openoffice/branches/AOO401/main/svx/source/svdraw/svdmrkv.cxx URL: http://svn.apache.org/viewvc/openoffice/branches/AOO401/main/svx/source/svdraw/svdmrkv.cxx?rev=1518918&r1=1518917&r2=1518918&view=diff ============================================================================== --- openoffice/branches/AOO401/main/svx/source/svdraw/svdmrkv.cxx (original) +++ openoffice/branches/AOO401/main/svx/source/svdraw/svdmrkv.cxx Fri Aug 30 09:10:27 2013 @@ -718,34 +718,41 @@ void SdrMarkView::SetMarkHandles() } } - // #122142# for captions in TextEdit, force to FrameHdls to get the special text selection - if(!bFrmHdl && pMarkedObj && bSingleTextObjMark && dynamic_cast< SdrCaptionObj* >(pMarkedObj)) + // check if text edit or ole is active and handles need to be suppressed. This may be the case + // when a single object is selected + // Using a strict return statement is okay here; no handles means *no* handles. + if(pMarkedObj) { - bFrmHdl = true; - } - - if (bFrmHdl) - { - Rectangle aRect(GetMarkedObjRect()); + // formally #i33755#: If TextEdit is active the EditEngine will directly paint + // to the window, so suppress Overlay and handles completely; a text frame for + // the active text edit will be painted by the repaitnt mechanism in + // SdrObjEditView::ImpPaintOutlinerView in this case. This needs to be reworked + // in the future + // Also formally #122142#: Pretty much the same for SdrCaptionObj's in calc. + if(((SdrView*)this)->IsTextEdit()) + { + const SdrTextObj* pSdrTextObj = dynamic_cast< const SdrTextObj* >(pMarkedObj); - // #i33755# - const sal_Bool bHideHandlesWhenInTextEdit( - ((SdrView*)this)->IsTextEdit() - && pMarkedObj - && pMarkedObj->ISA(SdrTextObj) - && ((SdrTextObj*)pMarkedObj)->IsInEditMode()); - - // #i118524# if inplace activated OLE is selected, - // suppress handles - bool bHideHandlesWhenOleActive(false); + if(pSdrTextObj && pSdrTextObj->IsInEditMode()) + { + return; + } + } + + // formally #i118524#: if inplace activated OLE is selected, suppress handles const SdrOle2Obj* pSdrOle2Obj = dynamic_cast< const SdrOle2Obj* >(pMarkedObj); if(pSdrOle2Obj && (pSdrOle2Obj->isInplaceActive() || pSdrOle2Obj->isUiActive())) { - bHideHandlesWhenOleActive = true; + return; } + } + + if (bFrmHdl) + { + Rectangle aRect(GetMarkedObjRect()); - if(!aRect.IsEmpty() && !bHideHandlesWhenInTextEdit && !bHideHandlesWhenOleActive) + if(!aRect.IsEmpty()) { // sonst nix gefunden if( bSingleTextObjMark ) {