branchobj.cpp
author insilmaril
Mon, 08 Jun 2009 11:36:56 +0000
changeset 776 25e634a7e1dc
parent 775 6e4b586aa88a
child 779 1fb50e79661c
permissions -rw-r--r--
Images basically work (again)
insilmaril@0
     1
#include "branchobj.h"
insilmaril@616
     2
insilmaril@749
     3
#include "branchitem.h"
insilmaril@643
     4
#include "geometry.h"
insilmaril@0
     5
#include "mapeditor.h"
insilmaril@0
     6
#include "mainwindow.h"
insilmaril@616
     7
#include "misc.h"
insilmaril@616
     8
insilmaril@767
     9
extern FlagRow *standardFlagsMaster;
insilmaril@767
    10
extern FlagRow *systemFlagsMaster;
insilmaril@0
    11
insilmaril@0
    12
/////////////////////////////////////////////////////////////////
insilmaril@0
    13
// BranchObj
insilmaril@0
    14
/////////////////////////////////////////////////////////////////
insilmaril@0
    15
insilmaril@746
    16
BranchObj::BranchObj () :OrnamentedObj()	// FIXME-3 needed at all?
insilmaril@0
    17
{
insilmaril@0
    18
//    cout << "Const BranchObj ()\n";
insilmaril@0
    19
    setParObj (this);	
insilmaril@0
    20
    init();
insilmaril@0
    21
}
insilmaril@0
    22
insilmaril@755
    23
BranchObj::BranchObj (QGraphicsScene* s):OrnamentedObj (s)// FIXME-3 needed at all?
insilmaril@0
    24
{
insilmaril@755
    25
//    cout << "Const BranchObj (s)  \n";
insilmaril@83
    26
	parObj=NULL;
insilmaril@408
    27
    scene=s;
insilmaril@755
    28
	init();
insilmaril@0
    29
}
insilmaril@0
    30
insilmaril@755
    31
BranchObj::BranchObj (QGraphicsScene* s, LinkableMapObj* p):OrnamentedObj (s)// FIXME-3 needed at all?
insilmaril@0
    32
{
insilmaril@408
    33
//    cout << "Const BranchObj (s,p)\n";
insilmaril@408
    34
    scene=s;
insilmaril@0
    35
    setParObj (p);	
insilmaril@773
    36
	if (treeItem->depth()==1)	// FIXME-3 needed to recursively calc depth?
insilmaril@0
    37
		// Calc angle to mapCenter if I am a mainbranch
insilmaril@0
    38
		// needed for reordering the mainbranches clockwise 
insilmaril@0
    39
		// around mapcenter 
insilmaril@408
    40
		angle=getAngle (QPointF (x() - parObj->getChildPos().x() , 
insilmaril@408
    41
								(y() - parObj->getChildPos().y() ) ) );
insilmaril@0
    42
    init();
insilmaril@0
    43
}
insilmaril@0
    44
insilmaril@0
    45
BranchObj::~BranchObj ()
insilmaril@0
    46
{
insilmaril@757
    47
//	cout << "Destr BranchObj of "<<this<<" ("<<treeItem->getHeading().toStdString()<<")"<<endl;
insilmaril@757
    48
insilmaril@722
    49
	// If I'm animated, I need to un-animate myself first
insilmaril@722
    50
	if (anim.isAnimated() )
insilmaril@722
    51
	{
insilmaril@722
    52
		anim.setAnimated (false);
insilmaril@773
    53
		VymModel *model=treeItem->getModel();
insilmaril@722
    54
		model->stopAnimation (this);
insilmaril@722
    55
	}
insilmaril@722
    56
insilmaril@0
    57
	// Check, if this branch was the last child to be deleted
insilmaril@749
    58
	// If so, unset the scrolled flags in parent // FIXME-2 better do this in model?
insilmaril@0
    59
insilmaril@749
    60
	/*
insilmaril@425
    61
	BranchObj *po=(BranchObj*)parObj;
insilmaril@83
    62
	BranchObj *bo;
insilmaril@0
    63
	if (po)
insilmaril@0
    64
	{
insilmaril@425
    65
		bo=((BranchObj*)parObj)->getLastBranch();
insilmaril@425
    66
		if (bo) po->unScroll();
insilmaril@0
    67
	}
insilmaril@749
    68
	*/
insilmaril@83
    69
	clear();
insilmaril@0
    70
}
insilmaril@0
    71
insilmaril@0
    72
bool BranchObj::operator< ( const BranchObj & other )
insilmaril@0
    73
{
insilmaril@0
    74
    return  angle < other.angle;
insilmaril@0
    75
}
insilmaril@0
    76
insilmaril@0
    77
bool BranchObj::operator== ( const BranchObj & other )
insilmaril@0
    78
{
insilmaril@0
    79
    return angle == other.angle;
insilmaril@0
    80
}
insilmaril@0
    81
insilmaril@0
    82
void BranchObj::init () 
insilmaril@0
    83
{
insilmaril@83
    84
	if (parObj)
insilmaril@83
    85
	{
insilmaril@83
    86
		absPos=getRandPos();
insilmaril@83
    87
		absPos+=parObj->getChildPos();
insilmaril@83
    88
	}
insilmaril@0
    89
insilmaril@169
    90
	includeImagesVer=false;
insilmaril@169
    91
	includeImagesHor=false;
insilmaril@0
    92
}
insilmaril@0
    93
insilmaril@0
    94
void BranchObj::copy (BranchObj* other)
insilmaril@0
    95
{
insilmaril@0
    96
    OrnamentedObj::copy(other);
insilmaril@0
    97
insilmaril@404
    98
	for (int i=0; i<other->floatimage.size(); ++i)
insilmaril@404
    99
		addFloatImage  (other->floatimage.at(i));
insilmaril@749
   100
	
insilmaril@0
   101
	setVisibility (other->visible);
insilmaril@0
   102
insilmaril@0
   103
	angle=other->angle;
insilmaril@0
   104
insilmaril@0
   105
    positionBBox();
insilmaril@0
   106
}
insilmaril@0
   107
insilmaril@0
   108
void BranchObj::clear() 
insilmaril@0
   109
{
insilmaril@755
   110
	//setVisibility (true); //FIXME-4 needed?
insilmaril@425
   111
insilmaril@404
   112
	while (!floatimage.isEmpty())
insilmaril@404
   113
		delete floatimage.takeFirst();
insilmaril@404
   114
insilmaril@95
   115
	while (!xlink.isEmpty())
insilmaril@406
   116
		delete xlink.takeFirst();
insilmaril@0
   117
}
insilmaril@0
   118
insilmaril@411
   119
bool isAbove (BranchObj* a, BranchObj *b)
insilmaril@411
   120
{
insilmaril@411
   121
	if (a->angle < b->angle)
insilmaril@411
   122
		return true;
insilmaril@411
   123
	else	
insilmaril@411
   124
		return false;
insilmaril@411
   125
}
insilmaril@411
   126
insilmaril@408
   127
void BranchObj::setParObjTmp(LinkableMapObj* lmo, QPointF m, int off)
insilmaril@0
   128
{
insilmaril@0
   129
	// Temporary link to lmo
insilmaril@0
   130
	// m is position of mouse pointer 
insilmaril@0
   131
	// offset 0: default 1: below lmo   -1 above lmo  (if possible)
insilmaril@0
   132
insilmaril@775
   133
	BranchItem *pi=(BranchItem*)(lmo->getTreeItem()->parent());
insilmaril@775
   134
	int pi_depth=pi->depth();
insilmaril@0
   135
	BranchObj* o=(BranchObj*)(lmo);
insilmaril@0
   136
	if (!parObjTmpBuf) 
insilmaril@0
   137
		parObjTmpBuf=parObj;
insilmaril@0
   138
insilmaril@0
   139
	// ignore mapcenter and mainbranch
insilmaril@775
   140
	if (pi_depth<2) off=0;
insilmaril@0
   141
	if (off==0)
insilmaril@0
   142
		link2ParPos=false;
insilmaril@0
   143
	else
insilmaril@0
   144
		link2ParPos=true;
insilmaril@93
   145
	parObj=o;
insilmaril@0
   146
insilmaril@755
   147
	// FIXME-2 depth=parObj->getDepth()+1;
insilmaril@0
   148
insilmaril@0
   149
	// setLinkStyle calls updateLink, only set it once
insilmaril@0
   150
	if (style!=getDefLinkStyle() ) setLinkStyle (getDefLinkStyle());
insilmaril@0
   151
insilmaril@0
   152
	// Move temporary to new position at destination
insilmaril@0
   153
	// Usually the positioning would be done by reposition(),
insilmaril@0
   154
	// but then also the destination branch would "Jump" around...
insilmaril@0
   155
	// Better just do it approximately
insilmaril@773
   156
	if (treeItem->depth()==1)	// FIXME-3 needed to recursively calc depth?
insilmaril@0
   157
	{	// new parent is the mapcenter itself
insilmaril@0
   158
insilmaril@408
   159
		QPointF p= normalise ( QPointF (m.x() - o->getChildPos().x(),
insilmaril@0
   160
									  m.y() - o->getChildPos().y() ));
insilmaril@0
   161
		if (p.x()<0) p.setX( p.x()-bbox.width() );
insilmaril@0
   162
		move2RelPos (p);
insilmaril@0
   163
	} else
insilmaril@0
   164
	{	
insilmaril@408
   165
		qreal y;
insilmaril@0
   166
		if (off==0)
insilmaril@0
   167
		{
insilmaril@0
   168
			// new parent is just a branch, link to it
insilmaril@721
   169
			QRectF t=o->getBBoxSizeWithChildren();
insilmaril@750
   170
			if (o->getTreeItem()->getLastBranch())
insilmaril@0
   171
				y=t.y() + t.height() ;
insilmaril@0
   172
			else
insilmaril@0
   173
				y=t.y();
insilmaril@0
   174
insilmaril@0
   175
		} else
insilmaril@0
   176
		{
insilmaril@0
   177
			if (off<0)
insilmaril@0
   178
				// we want to link above lmo
insilmaril@0
   179
				y=o->y() - height() + 5;
insilmaril@0
   180
			else	
insilmaril@0
   181
				// we want to link below lmo
insilmaril@0
   182
				// Bottom of sel should be 5 pixels above
insilmaril@0
   183
				// the bottom of the branch _below_ the target:
insilmaril@0
   184
				// Don't try to find that branch, guess 12 pixels
insilmaril@0
   185
				y=o->getChildPos().y()  -height() + 12; 
insilmaril@0
   186
		}	
insilmaril@462
   187
		if (o->getOrientation()==LinkableMapObj::LeftOfCenter)
insilmaril@0
   188
			move ( o->getChildPos().x() - linkwidth, y );
insilmaril@0
   189
		else	
insilmaril@0
   190
			move (o->getChildPos().x() + linkwidth, y );
insilmaril@0
   191
	}	
insilmaril@0
   192
insilmaril@0
   193
	// updateLink is called implicitly in move
insilmaril@417
   194
	requestReposition();	
insilmaril@0
   195
}
insilmaril@0
   196
insilmaril@0
   197
void BranchObj::unsetParObjTmp()
insilmaril@0
   198
{
insilmaril@0
   199
	if (parObjTmpBuf) 
insilmaril@0
   200
	{
insilmaril@0
   201
		link2ParPos=false;
insilmaril@0
   202
		parObj=parObjTmpBuf;
insilmaril@0
   203
		parObjTmpBuf=NULL;
insilmaril@755
   204
		//FIXME-2 depth=parObj->getDepth()+1;
insilmaril@0
   205
		setLinkStyle (getDefLinkStyle() );
insilmaril@93
   206
		updateLink();
insilmaril@0
   207
	}		
insilmaril@0
   208
}
insilmaril@0
   209
insilmaril@0
   210
void BranchObj::setVisibility(bool v, int toDepth)
insilmaril@0
   211
{
insilmaril@749
   212
	BranchItem *bi=(BranchItem*)treeItem;
insilmaril@755
   213
    if (bi->depth() <= toDepth)
insilmaril@0
   214
    {
insilmaril@0
   215
		frame->setVisibility(v);
insilmaril@0
   216
		heading->setVisibility(v);
insilmaril@0
   217
		systemFlags->setVisibility(v);
insilmaril@0
   218
		standardFlags->setVisibility(v);
insilmaril@0
   219
		LinkableMapObj::setVisibility (v);
insilmaril@730
   220
		int i;
insilmaril@730
   221
		for (i=0; i<floatimage.size(); ++i)
insilmaril@730
   222
			floatimage.at(i)->setVisibility (v);
insilmaril@730
   223
		for (i=0; i<xlink.size(); ++i)	
insilmaril@730
   224
			xlink.at(i)->setVisibility ();	
insilmaril@730
   225
insilmaril@721
   226
		// Only change children, if I am not scrolled
insilmaril@749
   227
		if (! bi->isScrolled() && (bi->depth() < toDepth))
insilmaril@0
   228
		{
insilmaril@721
   229
			// Now go recursivly through all children
insilmaril@750
   230
			for (i=0; i<treeItem->branchCount(); ++i)
insilmaril@753
   231
				treeItem->getBranchObjNum(i)->setVisibility (v,toDepth);	
insilmaril@0
   232
		}
insilmaril@0
   233
    } // depth <= toDepth	
insilmaril@0
   234
	requestReposition();
insilmaril@0
   235
}	
insilmaril@0
   236
insilmaril@0
   237
void BranchObj::setVisibility(bool v)
insilmaril@0
   238
{
insilmaril@0
   239
    setVisibility (v,MAX_DEPTH);
insilmaril@0
   240
}
insilmaril@0
   241
insilmaril@0
   242
insilmaril@0
   243
void BranchObj::setLinkColor ()
insilmaril@0
   244
{
insilmaril@0
   245
	// Overloaded from LinkableMapObj
insilmaril@0
   246
	// BranchObj can use color of heading
insilmaril@0
   247
insilmaril@773
   248
	VymModel *model=treeItem->getModel();
insilmaril@721
   249
	if (model)
insilmaril@611
   250
	{
insilmaril@721
   251
		if (model->getMapLinkColorHint()==HeadingColor)
insilmaril@164
   252
			LinkableMapObj::setLinkColor (heading->getColor() );
insilmaril@164
   253
		else	
insilmaril@164
   254
			LinkableMapObj::setLinkColor ();
insilmaril@611
   255
	}		
insilmaril@0
   256
}
insilmaril@0
   257
insilmaril@753
   258
void BranchObj::updateContentSize()
insilmaril@753
   259
{
insilmaril@753
   260
	calcBBoxSize();
insilmaril@753
   261
	positionBBox();
insilmaril@753
   262
	requestReposition();
insilmaril@100
   263
}
insilmaril@0
   264
insilmaril@333
   265
void BranchObj::positionContents()
insilmaril@333
   266
{
insilmaril@404
   267
    for (int i=0; i<floatimage.size(); ++i )
insilmaril@404
   268
		floatimage.at(i)->reposition();
insilmaril@333
   269
	OrnamentedObj::positionContents();
insilmaril@333
   270
}
insilmaril@0
   271
insilmaril@0
   272
void BranchObj::move (double x, double y)
insilmaril@0
   273
{
insilmaril@0
   274
	OrnamentedObj::move (x,y);
insilmaril@776
   275
	FloatImageObj *fio;
insilmaril@776
   276
    for (int i=0; i<treeItem->imageCount(); ++i )
insilmaril@776
   277
	{
insilmaril@776
   278
		fio=treeItem->getImageObjNum(i);
insilmaril@776
   279
		if (fio) fio->reposition();
insilmaril@776
   280
	}
insilmaril@0
   281
    positionBBox();
insilmaril@0
   282
}
insilmaril@0
   283
insilmaril@408
   284
void BranchObj::move (QPointF p)
insilmaril@0
   285
{
insilmaril@0
   286
	move (p.x(), p.y());
insilmaril@0
   287
}
insilmaril@0
   288
insilmaril@0
   289
void BranchObj::moveBy (double x, double y)
insilmaril@0
   290
{
insilmaril@0
   291
	OrnamentedObj::moveBy (x,y);
insilmaril@750
   292
	for (int i=0; i<treeItem->branchCount(); ++i)
insilmaril@753
   293
		treeItem->getBranchObjNum(i)->moveBy (x,y);
insilmaril@333
   294
    positionBBox();
insilmaril@0
   295
}
insilmaril@83
   296
	
insilmaril@408
   297
void BranchObj::moveBy (QPointF p)
insilmaril@0
   298
{
insilmaril@0
   299
	moveBy (p.x(), p.y());
insilmaril@0
   300
}
insilmaril@0
   301
insilmaril@0
   302
insilmaril@0
   303
void BranchObj::positionBBox()
insilmaril@0
   304
{
insilmaril@408
   305
	QPointF ap=getAbsPos();
insilmaril@223
   306
	bbox.moveTopLeft (ap);
insilmaril@169
   307
	positionContents();
insilmaril@0
   308
insilmaril@0
   309
	// set the frame
insilmaril@408
   310
	frame->setRect(QRectF(bbox.x(),bbox.y(),bbox.width(),bbox.height() ) );
insilmaril@83
   311
insilmaril@83
   312
	// Update links to other branches
insilmaril@406
   313
	for (int i=0; i<xlink.size(); ++i)
insilmaril@406
   314
		xlink.at(i)->updateXLink();
insilmaril@0
   315
}
insilmaril@0
   316
insilmaril@0
   317
void BranchObj::calcBBoxSize()
insilmaril@0
   318
{
insilmaril@408
   319
    QSizeF heading_r=heading->getSize();
insilmaril@408
   320
    qreal heading_w=(qreal) heading_r.width() ;
insilmaril@408
   321
    qreal heading_h=(qreal) heading_r.height() ;
insilmaril@767
   322
    QSizeF sysflags_r=systemFlags->getSize();
insilmaril@767
   323
	qreal sysflags_h=sysflags_r.height();
insilmaril@767
   324
	qreal sysflags_w=sysflags_r.width();
insilmaril@767
   325
    QSizeF stanflags_r=standardFlags->getSize();
insilmaril@767
   326
	qreal stanflags_h=stanflags_r.height();
insilmaril@767
   327
	qreal stanflags_w=stanflags_r.width();
insilmaril@408
   328
    qreal w;
insilmaril@408
   329
    qreal h;
insilmaril@0
   330
insilmaril@0
   331
	// set width to sum of all widths
insilmaril@0
   332
	w=heading_w + sysflags_w + stanflags_w;
insilmaril@0
   333
	// set height to maximum needed height
insilmaril@0
   334
	h=max (sysflags_h,stanflags_h);
insilmaril@0
   335
	h=max (h,heading_h);
insilmaril@0
   336
insilmaril@223
   337
	// Save the dimension of flags and heading
insilmaril@408
   338
	ornamentsBBox.setSize ( QSizeF(w,h));
insilmaril@223
   339
insilmaril@223
   340
	// clickBox includes Flags and Heading
insilmaril@223
   341
    clickBox.setSize (ornamentsBBox.size() );
insilmaril@169
   342
insilmaril@169
   343
	// Floatimages 
insilmaril@408
   344
	QPointF rp;
insilmaril@169
   345
insilmaril@169
   346
	topPad=botPad=leftPad=rightPad=0;
insilmaril@169
   347
	if (includeImagesVer || includeImagesHor)
insilmaril@169
   348
	{
insilmaril@749
   349
		if (treeItem->imageCount()>0)
insilmaril@169
   350
		{
insilmaril@404
   351
			for (int i=0; i<floatimage.size(); ++i )
insilmaril@169
   352
			{
insilmaril@404
   353
				rp=floatimage.at(i)->getRelPos();
insilmaril@169
   354
				if (includeImagesVer)
insilmaril@169
   355
				{
insilmaril@169
   356
					if (rp.y() < 0) 
insilmaril@223
   357
						topPad=max (topPad,-rp.y()-h);
insilmaril@404
   358
					if (rp.y()+floatimage.at(i)->height() > 0)
insilmaril@404
   359
						botPad=max (botPad,rp.y()+floatimage.at(i)->height());
insilmaril@169
   360
				}		
insilmaril@213
   361
				if (includeImagesHor)
insilmaril@213
   362
				{
insilmaril@462
   363
					if (orientation==LinkableMapObj::RightOfCenter)
insilmaril@223
   364
					{
insilmaril@223
   365
						if (-rp.x()-w > 0) 
insilmaril@223
   366
							leftPad=max (leftPad,-rp.x()-w);
insilmaril@404
   367
						if (rp.x()+floatimage.at(i)->width() > 0)
insilmaril@404
   368
							rightPad=max (rightPad,rp.x()+floatimage.at(i)->width());
insilmaril@223
   369
					} else
insilmaril@223
   370
					{
insilmaril@223
   371
						if (rp.x()< 0) 
insilmaril@223
   372
							leftPad=max (leftPad,-rp.x());
insilmaril@404
   373
						if (rp.x()+floatimage.at(i)->width() > w)
insilmaril@404
   374
							rightPad=max (rightPad,rp.x()+floatimage.at(i)->width()-w);
insilmaril@223
   375
					}
insilmaril@213
   376
				}		
insilmaril@169
   377
			}	
insilmaril@169
   378
		}	
insilmaril@169
   379
		h+=topPad+botPad;
insilmaril@213
   380
		w+=leftPad+rightPad;
insilmaril@169
   381
	}
insilmaril@169
   382
insilmaril@169
   383
	// Frame thickness
insilmaril@462
   384
    w+=frame->getPadding();
insilmaril@462
   385
    h+=frame->getPadding();
insilmaril@169
   386
	
insilmaril@169
   387
	// Finally set size
insilmaril@408
   388
    bbox.setSize (QSizeF (w,h));
insilmaril@0
   389
}
insilmaril@0
   390
insilmaril@223
   391
void BranchObj::setDockPos()
insilmaril@223
   392
{
insilmaril@775
   393
	if (treeItem->getType()==TreeItem::MapCenter)
insilmaril@775
   394
	{
insilmaril@775
   395
		// set childPos to middle of MapCenterObj
insilmaril@775
   396
		childPos.setX( clickBox.topLeft().x() + clickBox.width()/2 );
insilmaril@775
   397
		childPos.setY( clickBox.topLeft().y() + clickBox.height()/2 );
insilmaril@775
   398
		parPos=childPos;		
insilmaril@775
   399
		for (int i=0; i<treeItem->branchCount(); ++i)
insilmaril@775
   400
			treeItem->getBranchObjNum(i)->updateLink();
insilmaril@775
   401
insilmaril@775
   402
	} else
insilmaril@775
   403
	{
insilmaril@775
   404
		// Sets childpos and parpos depending on orientation
insilmaril@775
   405
		if (getOrientation()==LinkableMapObj::LeftOfCenter )
insilmaril@775
   406
		{
insilmaril@775
   407
			childPos=QPointF (
insilmaril@775
   408
				ornamentsBBox.bottomLeft().x(), 
insilmaril@775
   409
				bottomlineY);
insilmaril@775
   410
			parPos=QPointF (
insilmaril@775
   411
				ornamentsBBox.bottomRight().x(),
insilmaril@775
   412
				bottomlineY);
insilmaril@775
   413
		} else
insilmaril@775
   414
		{
insilmaril@775
   415
			childPos=QPointF (
insilmaril@775
   416
				ornamentsBBox.bottomRight().x(), 
insilmaril@775
   417
				bottomlineY);
insilmaril@775
   418
			parPos=QPointF (
insilmaril@775
   419
				ornamentsBBox.bottomLeft().x(),
insilmaril@775
   420
				bottomlineY);
insilmaril@775
   421
		}
insilmaril@775
   422
	}
insilmaril@223
   423
}
insilmaril@382
   424
insilmaril@767
   425
void BranchObj::updateData()
insilmaril@0
   426
{
insilmaril@767
   427
	bool changed=false;
insilmaril@753
   428
	if (!treeItem)
insilmaril@254
   429
	{
insilmaril@753
   430
		qWarning ("BranchObj::udpateHeading treeItem==NULL");
insilmaril@753
   431
		return;
insilmaril@753
   432
	}
insilmaril@767
   433
	QString s=treeItem->getHeading();
insilmaril@767
   434
	if (s!=heading->text())
insilmaril@767
   435
	{
insilmaril@767
   436
		heading->setText (s);
insilmaril@767
   437
		changed=true;
insilmaril@767
   438
	}
insilmaril@767
   439
	QStringList TIactiveFlags=treeItem->activeStandardFlagNames();
insilmaril@767
   440
insilmaril@767
   441
	// Add missing standard flags active in TreeItem
insilmaril@767
   442
	for (int i=0;i<=TIactiveFlags.size()-1;i++)
insilmaril@767
   443
	{	
insilmaril@767
   444
		if (!standardFlags->isActive (TIactiveFlags.at(i) ))
insilmaril@767
   445
		{
insilmaril@767
   446
			Flag *f=standardFlagsMaster->getFlag(TIactiveFlags.at(i));
insilmaril@767
   447
			if (f) standardFlags->activate (f);
insilmaril@767
   448
			changed=true;
insilmaril@767
   449
		}
insilmaril@767
   450
	}
insilmaril@767
   451
	// Remove standard flags no longer active in TreeItem
insilmaril@767
   452
	QStringList BOactiveFlags=standardFlags->activeFlagNames();
insilmaril@767
   453
	for (int i=0;i<BOactiveFlags.size();++i)
insilmaril@767
   454
		if (!TIactiveFlags.contains (BOactiveFlags.at(i)))
insilmaril@767
   455
		{
insilmaril@767
   456
			standardFlags->deactivate (BOactiveFlags.at(i));
insilmaril@767
   457
			changed=true;
insilmaril@767
   458
		}	
insilmaril@767
   459
insilmaril@767
   460
	// Add missing system flags active in TreeItem
insilmaril@767
   461
	TIactiveFlags=treeItem->activeSystemFlagNames();
insilmaril@767
   462
	for (int i=0;i<TIactiveFlags.size();++i)
insilmaril@767
   463
	{	
insilmaril@767
   464
		if (!systemFlags->isActive (TIactiveFlags.at(i) ))
insilmaril@767
   465
		{
insilmaril@767
   466
			Flag *f=systemFlagsMaster->getFlag(TIactiveFlags.at(i));
insilmaril@767
   467
			if (f) systemFlags->activate (f);
insilmaril@767
   468
			changed=true;
insilmaril@767
   469
		}
insilmaril@767
   470
	}
insilmaril@767
   471
	// Remove system flags no longer active in TreeItem
insilmaril@767
   472
	BOactiveFlags=systemFlags->activeFlagNames();
insilmaril@767
   473
	for (int i=0;i<BOactiveFlags.size();++i)
insilmaril@767
   474
	{
insilmaril@767
   475
		if (!TIactiveFlags.contains (BOactiveFlags.at(i)))
insilmaril@767
   476
		{
insilmaril@767
   477
			systemFlags->deactivate (BOactiveFlags.at(i));
insilmaril@767
   478
			changed=true;
insilmaril@767
   479
		}	
insilmaril@767
   480
	}
insilmaril@767
   481
insilmaril@767
   482
	if (changed)
insilmaril@767
   483
		updateContentSize();
insilmaril@254
   484
}
insilmaril@254
   485
insilmaril@0
   486
insilmaril@95
   487
void BranchObj::addXLink (XLinkObj *xlo)
insilmaril@83
   488
{
insilmaril@95
   489
	xlink.append (xlo);
insilmaril@83
   490
	
insilmaril@83
   491
}
insilmaril@83
   492
insilmaril@95
   493
void BranchObj::removeXLinkRef (XLinkObj *xlo)
insilmaril@83
   494
{
insilmaril@406
   495
	xlink.removeAt (xlink.indexOf(xlo));
insilmaril@83
   496
}
insilmaril@83
   497
insilmaril@95
   498
void BranchObj::deleteXLink(XLinkObj *xlo)
insilmaril@83
   499
{
insilmaril@95
   500
	xlo->deactivate();
insilmaril@95
   501
	if (!xlo->isUsed()) delete (xlo);
insilmaril@83
   502
}
insilmaril@83
   503
insilmaril@95
   504
void BranchObj::deleteXLinkAt (int i)
insilmaril@94
   505
{
insilmaril@95
   506
	XLinkObj *xlo=xlink.at(i);
insilmaril@95
   507
	xlo->deactivate();
insilmaril@95
   508
	if (!xlo->isUsed()) delete(xlo);
insilmaril@94
   509
}
insilmaril@94
   510
insilmaril@97
   511
XLinkObj* BranchObj::XLinkAt (int i)
insilmaril@97
   512
{
insilmaril@97
   513
	return xlink.at(i);
insilmaril@97
   514
}
insilmaril@97
   515
insilmaril@95
   516
BranchObj* BranchObj::XLinkTargetAt (int i)
insilmaril@89
   517
{
insilmaril@406
   518
	if (i>=0 && i<xlink.size())
insilmaril@406
   519
	{
insilmaril@406
   520
		if (xlink.at(i))
insilmaril@406
   521
			return xlink.at(i)->otherBranch (this);
insilmaril@406
   522
	}
insilmaril@406
   523
	return NULL;
insilmaril@89
   524
}
insilmaril@89
   525
insilmaril@169
   526
void BranchObj::setIncludeImagesVer(bool b)
insilmaril@169
   527
{
insilmaril@169
   528
	includeImagesVer=b;
insilmaril@169
   529
	calcBBoxSize();
insilmaril@169
   530
	positionBBox();
insilmaril@169
   531
	requestReposition();
insilmaril@169
   532
}
insilmaril@169
   533
insilmaril@169
   534
bool BranchObj::getIncludeImagesVer()
insilmaril@169
   535
{
insilmaril@169
   536
	return includeImagesVer;
insilmaril@169
   537
}
insilmaril@169
   538
insilmaril@169
   539
void BranchObj::setIncludeImagesHor(bool b)
insilmaril@169
   540
{
insilmaril@169
   541
	includeImagesHor=b;
insilmaril@169
   542
	calcBBoxSize();
insilmaril@169
   543
	positionBBox();
insilmaril@169
   544
	requestReposition();
insilmaril@169
   545
}
insilmaril@169
   546
insilmaril@169
   547
bool BranchObj::getIncludeImagesHor()
insilmaril@169
   548
{
insilmaril@169
   549
	return includeImagesHor;
insilmaril@169
   550
}
insilmaril@169
   551
insilmaril@169
   552
QString BranchObj::getIncludeImageAttr()
insilmaril@169
   553
{
insilmaril@169
   554
	QString a;
insilmaril@169
   555
	if (includeImagesVer)
insilmaril@169
   556
		a=attribut ("incImgV","true");
insilmaril@169
   557
	else
insilmaril@169
   558
		a=attribut ("incImgV","false");
insilmaril@169
   559
	if (includeImagesHor)
insilmaril@213
   560
		a+=attribut ("incImgH","true");
insilmaril@169
   561
	else
insilmaril@213
   562
		a+=attribut ("incImgH","false");
insilmaril@169
   563
	return a;	
insilmaril@169
   564
}
insilmaril@169
   565
insilmaril@395
   566
FloatImageObj* BranchObj::addFloatImage ()
insilmaril@0
   567
{
insilmaril@408
   568
	FloatImageObj *newfi=new FloatImageObj (scene,this);
insilmaril@0
   569
	floatimage.append (newfi);
insilmaril@749
   570
	if ( ((BranchItem*)treeItem)->hasScrolledParent((BranchItem*)treeItem) )
insilmaril@0
   571
		newfi->setVisibility (false);
insilmaril@0
   572
	else	
insilmaril@0
   573
		newfi->setVisibility(visible);
insilmaril@395
   574
		/*
insilmaril@169
   575
	calcBBoxSize();
insilmaril@169
   576
	positionBBox();
insilmaril@395
   577
	*/
insilmaril@0
   578
	requestReposition();
insilmaril@0
   579
	return newfi;
insilmaril@0
   580
}
insilmaril@0
   581
insilmaril@395
   582
FloatImageObj* BranchObj::addFloatImage (FloatImageObj *fio)
insilmaril@0
   583
{
insilmaril@408
   584
	FloatImageObj *newfi=new FloatImageObj (scene,this);
insilmaril@0
   585
	floatimage.append (newfi);
insilmaril@0
   586
	newfi->copy (fio);
insilmaril@749
   587
	if (((BranchItem*)treeItem)->hasScrolledParent((BranchItem*)treeItem) )
insilmaril@0
   588
		newfi->setVisibility (false);
insilmaril@0
   589
	else	
insilmaril@0
   590
		newfi->setVisibility(visible);
insilmaril@395
   591
		/*
insilmaril@169
   592
	calcBBoxSize();
insilmaril@169
   593
	positionBBox();
insilmaril@395
   594
	*/
insilmaril@0
   595
	requestReposition();
insilmaril@0
   596
	return newfi;
insilmaril@0
   597
}
insilmaril@0
   598
insilmaril@0
   599
FloatImageObj* BranchObj::getFirstFloatImage ()
insilmaril@0
   600
{
insilmaril@0
   601
    return floatimage.first();
insilmaril@0
   602
}
insilmaril@0
   603
insilmaril@0
   604
FloatImageObj* BranchObj::getLastFloatImage ()
insilmaril@0
   605
{
insilmaril@0
   606
    return floatimage.last();
insilmaril@0
   607
}
insilmaril@0
   608
insilmaril@0
   609
FloatImageObj* BranchObj::getFloatImageNum (const uint &i)
insilmaril@0
   610
{
insilmaril@0
   611
    return floatimage.at(i);
insilmaril@0
   612
}
insilmaril@0
   613
insilmaril@0
   614
void BranchObj::removeFloatImage (FloatImageObj *fio)
insilmaril@0
   615
{
insilmaril@404
   616
	int i=floatimage.indexOf (fio);
insilmaril@411
   617
	if (i>-1) delete (floatimage.takeAt (i));
insilmaril@169
   618
	calcBBoxSize();
insilmaril@169
   619
	positionBBox();
insilmaril@0
   620
	requestReposition();
insilmaril@0
   621
}
insilmaril@0
   622
insilmaril@0
   623
void BranchObj::savePosInAngle ()
insilmaril@0
   624
{
insilmaril@0
   625
	// Save position in angle
insilmaril@750
   626
	for (int i=0; i<treeItem->branchCount(); ++i)
insilmaril@753
   627
		treeItem->getBranchObjNum(i)->angle=i;
insilmaril@0
   628
}
insilmaril@0
   629
insilmaril@146
   630
void BranchObj::setDefAttr (BranchModification mod)
insilmaril@146
   631
{
insilmaril@146
   632
	int fontsize;
insilmaril@755
   633
	switch (treeItem->depth())
insilmaril@146
   634
	{
insilmaril@146
   635
		case 0: fontsize=16; break;
insilmaril@146
   636
		case 1: fontsize=12; break;
insilmaril@146
   637
		default: fontsize=10; break;
insilmaril@146
   638
	}	
insilmaril@146
   639
insilmaril@146
   640
	setLinkColor ();
insilmaril@146
   641
	setLinkStyle(getDefLinkStyle());
insilmaril@146
   642
	QFont font("Sans Serif,8,-1,5,50,0,0,0,0,0");
insilmaril@146
   643
	font.setPointSize(fontsize);
insilmaril@146
   644
	heading->setFont(font );
insilmaril@146
   645
insilmaril@146
   646
	if (mod==NewBranch)
insilmaril@760
   647
		setColor (treeItem->getHeadingColor() );
insilmaril@146
   648
	calcBBoxSize();
insilmaril@146
   649
}
insilmaril@146
   650
insilmaril@760
   651
void BranchObj::sortChildren() //FIXME-2  
insilmaril@604
   652
{
insilmaril@749
   653
/*
insilmaril@749
   654
	int childCount=branch.count(); 
insilmaril@604
   655
	int curChildIndex;
insilmaril@604
   656
	bool madeChanges=false;
insilmaril@604
   657
	do
insilmaril@604
   658
	{
insilmaril@604
   659
		madeChanges=false;
insilmaril@604
   660
		for(curChildIndex=1;curChildIndex<childCount;curChildIndex++){
insilmaril@753
   661
			BranchObj* curChild=(BranchObj*)treeItem->getBranchObjNum(curChildIndex);
insilmaril@753
   662
			BranchObj* prevChild=(BranchObj*)treeItem->getBranchObjNum(curChildIndex-1);
insilmaril@604
   663
			if(prevChild->heading->text().compare(curChild->heading->text())>0)
insilmaril@604
   664
			{
insilmaril@604
   665
				this->moveBranchUp(curChild);
insilmaril@604
   666
				madeChanges=true;
insilmaril@604
   667
			}
insilmaril@604
   668
		}
insilmaril@604
   669
	}while(madeChanges);
insilmaril@749
   670
*/
insilmaril@604
   671
}
insilmaril@604
   672
insilmaril@721
   673
void BranchObj::alignRelativeTo (QPointF ref,bool alignSelf)
insilmaril@0
   674
{
insilmaril@408
   675
	qreal th = bboxTotal.height();	
insilmaril@773
   676
	int depth=treeItem->depth();	// FIXME-3 needed to recursively calc depth?
insilmaril@223
   677
// TODO testing
insilmaril@223
   678
/*
insilmaril@755
   679
insilmaril@755
   680
	QString h=QString (depth,' ');
insilmaril@753
   681
	h+=treeItem->getHeading();
insilmaril@753
   682
	h+=QString (15,' ');
insilmaril@753
   683
	h.truncate (15);
insilmaril@688
   684
	QPointF pp; if (parObj) pp=parObj->getChildPos();
insilmaril@753
   685
	cout << "BO::alignRelTo ";
insilmaril@753
   686
	cout<<h.toStdString();
insilmaril@755
   687
	cout << "    d="<<depth<<
insilmaril@755
   688
//cout<<  "  ref="<<ref<<
insilmaril@753
   689
      	"  bbox.tL="<<bboxTotal.topLeft()<<
insilmaril@223
   690
		"  absPos="<<absPos<<
insilmaril@721
   691
//		"  relPos="<<relPos<<
insilmaril@721
   692
//		"  parPos="<<pp<<
insilmaril@753
   693
		"  w="<<bbox.width()<<
insilmaril@753
   694
		"  h="<<bbox.height()<<
insilmaril@753
   695
//		"  orient="<<orientation<<
insilmaril@753
   696
//		"  alignSelf="<<alignSelf<<
insilmaril@753
   697
//		"  scrolled="<<((BranchItem*)treeItem)->isScrolled()<<
insilmaril@254
   698
//		"  pad="<<topPad<<","<<botPad<<","<<leftPad<<","<<rightPad<<
insilmaril@382
   699
//		"  hidden="<<hidden<<
insilmaril@753
   700
		"  th="<<th<<
insilmaril@382
   701
		endl;
insilmaril@394
   702
*/
insilmaril@0
   703
insilmaril@382
   704
	setOrientation();
insilmaril@382
   705
	//updateLink();
insilmaril@382
   706
insilmaril@755
   707
	if (depth==1 && parObj)
insilmaril@364
   708
	{
insilmaril@753
   709
		// Position relatively, if needed
insilmaril@753
   710
		//if (useRelPos) move2RelPos (relPos.x(), relPos.y());
insilmaril@382
   711
insilmaril@753
   712
		// Calc angle to mapCenter if I am a mainbranch
insilmaril@753
   713
		// needed for reordering the mainbranches clockwise 
insilmaril@753
   714
		// around mapcenter 
insilmaril@753
   715
		angle=getAngle (QPointF ((int)(x() - parObj->getChildPos().x() ), 
insilmaril@753
   716
								(int)(y() - parObj->getChildPos().y() ) ) );
insilmaril@753
   717
	}							
insilmaril@753
   718
	if (depth>1)
insilmaril@0
   719
    {
insilmaril@0
   720
		// Align myself depending on orientation and parent, but
insilmaril@382
   721
		// only if I am not a mainbranch or mapcenter itself
insilmaril@688
   722
insilmaril@688
   723
		if (anim.isAnimated())
insilmaril@0
   724
		{
insilmaril@688
   725
			move2RelPos(anim);
insilmaril@688
   726
		} else
insilmaril@688
   727
		{
insilmaril@688
   728
			LinkableMapObj::Orientation o;
insilmaril@688
   729
			o=parObj->getOrientation();
insilmaril@721
   730
			if (alignSelf)
insilmaril@721
   731
				switch (orientation) 
insilmaril@721
   732
				{
insilmaril@721
   733
					case LinkableMapObj::LeftOfCenter:
insilmaril@721
   734
						move (ref.x() - bbox.width(), ref.y() + (th-bbox.height())/2 );
insilmaril@721
   735
						//move (ref.x() , ref.y() + (th-bbox.height())/2 );
insilmaril@721
   736
					break;
insilmaril@721
   737
					case LinkableMapObj::RightOfCenter:	
insilmaril@721
   738
						move (ref.x() , ref.y() + (th-bbox.height())/2  );
insilmaril@721
   739
					break;
insilmaril@721
   740
					default:
insilmaril@721
   741
						qWarning ("LMO::alignRelativeTo: oops, no orientation given...");
insilmaril@721
   742
					break;
insilmaril@753
   743
			}
insilmaril@688
   744
		}
insilmaril@0
   745
    }		
insilmaril@0
   746
insilmaril@749
   747
	if ( ((BranchItem*)treeItem)->isScrolled() ) return;
insilmaril@0
   748
insilmaril@721
   749
    // Set reference point for alignment of children
insilmaril@408
   750
    QPointF ref2;
insilmaril@462
   751
    if (orientation==LinkableMapObj::LeftOfCenter)
insilmaril@223
   752
		ref2.setX(bbox.topLeft().x() - linkwidth);
insilmaril@0
   753
    else	
insilmaril@223
   754
		ref2.setX(bbox.topRight().x() + linkwidth);
insilmaril@0
   755
insilmaril@0
   756
	if (depth==1)
insilmaril@0
   757
		ref2.setY(absPos.y()-(bboxTotal.height()-bbox.height())/2);
insilmaril@0
   758
	else	
insilmaril@0
   759
		ref2.setY(ref.y() );	
insilmaril@0
   760
insilmaril@721
   761
    // Align the children depending on reference point 
insilmaril@750
   762
	for (int i=0; i<treeItem->branchCount(); ++i)
insilmaril@0
   763
    {	
insilmaril@753
   764
		if (!treeItem->getBranchNum(i)->isHidden())
insilmaril@254
   765
		{
insilmaril@753
   766
			treeItem->getBranchObjNum(i)->alignRelativeTo (ref2,true);
insilmaril@721
   767
insilmaril@721
   768
			// append next branch below current one
insilmaril@753
   769
			ref2.setY(ref2.y() + treeItem->getBranchObjNum(i)->getBBoxSizeWithChildren().height() );
insilmaril@254
   770
		}
insilmaril@0
   771
    }
insilmaril@0
   772
}
insilmaril@0
   773
insilmaril@0
   774
insilmaril@0
   775
void BranchObj::reposition()
insilmaril@0
   776
{	
insilmaril@164
   777
/* TODO testing only
insilmaril@753
   778
	if (!treeItem->getHeading().isEmpty())
insilmaril@753
   779
		cout << "BO::reposition  "<<qPrintable(treeItem->getHeading())<<endl;
insilmaril@0
   780
	else	
insilmaril@0
   781
		cout << "BO::reposition  ???"<<endl;
insilmaril@753
   782
//	cout << "  orient="<<orientation<<endl;
insilmaril@0
   783
*/		
insilmaril@382
   784
insilmaril@755
   785
	if (treeItem->depth()==0)
insilmaril@0
   786
	{
insilmaril@0
   787
		// only calculate the sizes once. If the deepest LMO 
insilmaril@0
   788
		// changes its height,
insilmaril@0
   789
		// all upper LMOs have to change, too.
insilmaril@721
   790
		calcBBoxSizeWithChildren();
insilmaril@408
   791
		updateLink();	// This update is needed if the scene is resized 
insilmaril@333
   792
						// due to excessive moving of a FIO
insilmaril@333
   793
insilmaril@408
   794
	    alignRelativeTo ( QPointF (absPos.x(),
insilmaril@0
   795
			absPos.y()-(bboxTotal.height()-bbox.height())/2) );
insilmaril@753
   796
		//FIXME-2 qSort (branch.begin(),branch.end(), isAbove);
insilmaril@333
   797
		positionBBox();	// Reposition bbox and contents
insilmaril@0
   798
	} else
insilmaril@0
   799
	{
insilmaril@0
   800
		// This is only important for moving branches:
insilmaril@0
   801
		// For editing a branch it isn't called...
insilmaril@408
   802
	    alignRelativeTo ( QPointF (absPos.x(),
insilmaril@0
   803
							absPos.y()-(bboxTotal.height()-bbox.height())/2) );
insilmaril@0
   804
	}
insilmaril@0
   805
}
insilmaril@0
   806
insilmaril@382
   807
void BranchObj::unsetAllRepositionRequests()
insilmaril@382
   808
{
insilmaril@382
   809
	repositionRequest=false;
insilmaril@750
   810
	for (int i=0; i<treeItem->branchCount(); ++i)
insilmaril@753
   811
		treeItem->getBranchObjNum(i)->unsetAllRepositionRequests();
insilmaril@382
   812
}
insilmaril@382
   813
insilmaril@0
   814
insilmaril@661
   815
QPolygonF BranchObj::shape()
insilmaril@661
   816
{
insilmaril@661
   817
	QPolygonF p;
insilmaril@661
   818
insilmaril@661
   819
	QRectF r=getTotalBBox();
insilmaril@661
   820
	if (orientation==LinkableMapObj::LeftOfCenter)
insilmaril@661
   821
		p   <<r.bottomLeft()
insilmaril@661
   822
			<<r.topLeft()
insilmaril@661
   823
			<<QPointF (bbox.topLeft().x(), r.topLeft().y() )
insilmaril@661
   824
			<<bbox.topRight()
insilmaril@661
   825
			<<bbox.bottomRight()
insilmaril@661
   826
			<<QPointF (bbox.bottomLeft().x(), r.bottomLeft().y() ) ;
insilmaril@661
   827
	else		
insilmaril@661
   828
		p   <<r.bottomRight()
insilmaril@661
   829
			<<r.topRight()
insilmaril@661
   830
			<<QPointF (bbox.topRight().x(), r.topRight().y() )
insilmaril@661
   831
			<<bbox.topLeft()
insilmaril@661
   832
			<<bbox.bottomLeft()
insilmaril@661
   833
			<<QPointF (bbox.bottomRight().x(), r.bottomRight().y() ) ;
insilmaril@661
   834
	return p;
insilmaril@661
   835
}
insilmaril@661
   836
insilmaril@408
   837
QRectF BranchObj::getTotalBBox()
insilmaril@0
   838
{
insilmaril@408
   839
	QRectF r=bbox;
insilmaril@0
   840
insilmaril@749
   841
	if ( ((BranchItem*)treeItem)->isScrolled() ) return r;
insilmaril@0
   842
insilmaril@750
   843
	for (int i=0; i<treeItem->branchCount(); ++i)
insilmaril@753
   844
		if (!treeItem->getBranchNum(i)->isHidden())
insilmaril@753
   845
			r=addBBox(treeItem->getBranchObjNum(i)->getTotalBBox(),r);
insilmaril@0
   846
insilmaril@755
   847
/* FIXME-3 lots of occurences of treeItem->getBranchObjNum(i) in branchobj.cpp
insilmaril@755
   848
            better check if they are not NULL and maybe simplify...
insilmaril@755
   849
			(have been NULL at least in calcBBoxSizeWithChilds...)
insilmaril@755
   850
*/			
insilmaril@755
   851
insilmaril@753
   852
/*
insilmaril@771
   853
	FIXME-3 for (int i=0; i<floatimage.size(); ++i)
insilmaril@404
   854
		if (!floatimage.at(i)->isHidden())
insilmaril@404
   855
			r=addBBox(floatimage.at(i)->getTotalBBox(),r);
insilmaril@753
   856
	*/	
insilmaril@0
   857
	return r;
insilmaril@0
   858
}
insilmaril@0
   859
insilmaril@721
   860
QRectF BranchObj::getBBoxSizeWithChildren()
insilmaril@0
   861
{
insilmaril@0
   862
	return bboxTotal;
insilmaril@0
   863
}
insilmaril@0
   864
insilmaril@721
   865
void BranchObj::calcBBoxSizeWithChildren()
insilmaril@169
   866
{	
insilmaril@169
   867
	// This is initially called only from reposition and
insilmaril@0
   868
	// and only for mapcenter. So it won't be
insilmaril@0
   869
	// called more than once for a single user 
insilmaril@0
   870
	// action
insilmaril@0
   871
	
insilmaril@169
   872
insilmaril@721
   873
	// Calculate size of LMO including all children (to align them later)
insilmaril@0
   874
	bboxTotal.setX(bbox.x() );
insilmaril@0
   875
	bboxTotal.setY(bbox.y() );
insilmaril@0
   876
insilmaril@721
   877
	// if branch is scrolled, ignore children, but still consider floatimages
insilmaril@753
   878
	BranchItem *bi=(BranchItem*)treeItem;
insilmaril@753
   879
	if ( bi->isScrolled() ) 
insilmaril@0
   880
	{
insilmaril@0
   881
		bboxTotal.setWidth (bbox.width());
insilmaril@0
   882
		bboxTotal.setHeight(bbox.height());
insilmaril@0
   883
		return;
insilmaril@0
   884
	}
insilmaril@0
   885
	
insilmaril@753
   886
	if (bi->isHidden())
insilmaril@254
   887
	{
insilmaril@254
   888
		bboxTotal.setWidth (0);
insilmaril@254
   889
		bboxTotal.setHeight(0);
insilmaril@254
   890
		if (parObj)
insilmaril@254
   891
		{
insilmaril@254
   892
			bboxTotal.setX (parObj->x());
insilmaril@254
   893
			bboxTotal.setY (parObj->y());
insilmaril@254
   894
		} else
insilmaril@254
   895
		{
insilmaril@254
   896
			bboxTotal.setX (bbox.x());
insilmaril@254
   897
			bboxTotal.setY (bbox.y());
insilmaril@254
   898
		}
insilmaril@254
   899
		return;
insilmaril@254
   900
	}
insilmaril@254
   901
	
insilmaril@408
   902
	QRectF r(0,0,0,0);
insilmaril@408
   903
	QRectF br;
insilmaril@0
   904
	// Now calculate recursivly
insilmaril@0
   905
	// sum of heights 
insilmaril@0
   906
	// maximum of widths 
insilmaril@0
   907
	// minimum of y
insilmaril@755
   908
	for (int i=0; i<treeItem->branchCount(); i++)
insilmaril@0
   909
	{
insilmaril@753
   910
		if (!bi->getBranchNum(i)->isHidden())
insilmaril@254
   911
		{
insilmaril@753
   912
			bi->getBranchObjNum(i)->calcBBoxSizeWithChildren();
insilmaril@753
   913
			br=bi->getBranchObjNum(i)->getBBoxSizeWithChildren();
insilmaril@254
   914
			r.setWidth( max (br.width(), r.width() ));
insilmaril@254
   915
			r.setHeight(br.height() + r.height() );
insilmaril@254
   916
			if (br.y()<bboxTotal.y()) bboxTotal.setY(br.y());
insilmaril@254
   917
		}
insilmaril@0
   918
	}
insilmaril@0
   919
	// Add myself and also
insilmaril@0
   920
	// add width of link to sum if necessary
insilmaril@753
   921
	if (bi->branchCount()<1)
insilmaril@0
   922
		bboxTotal.setWidth (bbox.width() + r.width() );
insilmaril@0
   923
	else	
insilmaril@0
   924
		bboxTotal.setWidth (bbox.width() + r.width() + linkwidth);
insilmaril@169
   925
	
insilmaril@169
   926
	bboxTotal.setHeight(max (r.height(),  bbox.height()));
insilmaril@0
   927
}
insilmaril@0
   928
insilmaril@0
   929
QString BranchObj::getSelectString()
insilmaril@0
   930
{
insilmaril@773
   931
	VymModel *model=treeItem->getModel();
insilmaril@773
   932
	if (model)
insilmaril@773
   933
		return model->getSelectString (this);
insilmaril@773
   934
	else
insilmaril@773
   935
		return QString();
insilmaril@0
   936
}
insilmaril@0
   937
insilmaril@688
   938
void BranchObj::setAnimation(const AnimPoint &ap)
insilmaril@462
   939
{
insilmaril@688
   940
	anim=ap;
insilmaril@462
   941
}
insilmaril@462
   942
insilmaril@688
   943
bool BranchObj::animate()
insilmaril@688
   944
{
insilmaril@688
   945
	anim.animate ();
insilmaril@721
   946
	if ( anim.isAnimated() )
insilmaril@721
   947
	{
insilmaril@721
   948
		setRelPos (anim);
insilmaril@721
   949
		return true;
insilmaril@721
   950
	}
insilmaril@723
   951
	parObj->reposition();	// we might have been relinked meanwhile
insilmaril@721
   952
	return false;
insilmaril@688
   953
}
insilmaril@688
   954