fixed display bug

git-svn-id: http://svn.code.sf.net/p/retroshare/code/trunk@7322 b45a01b8-16f6-495d-af2f-9b41ad6348cc
This commit is contained in:
csoler 2014-05-03 13:32:31 +00:00
parent 7a9e2e865d
commit 31ee64a4f8
2 changed files with 61 additions and 139 deletions

View file

@ -32,7 +32,7 @@ GroupListView::GroupListView(QWidget *)
scene->setSceneRect(0, 0, width(), height()); scene->setSceneRect(0, 0, width(), height());
setCacheMode(CacheBackground); setCacheMode(CacheBackground);
setViewportUpdateMode(BoundingRectViewportUpdate); setViewportUpdateMode(FullViewportUpdate);
setRenderHint(QPainter::Antialiasing); setRenderHint(QPainter::Antialiasing);
setTransformationAnchor(AnchorUnderMouse); setTransformationAnchor(AnchorUnderMouse);
setResizeAnchor(AnchorViewCenter); setResizeAnchor(AnchorViewCenter);
@ -47,53 +47,6 @@ void GroupListView::resizeEvent(QResizeEvent *e)
scene()->setSceneRect(0, 0, e->size().width(), e->size().height()); scene()->setSceneRect(0, 0, e->size().width(), e->size().height());
} }
void GroupListView::clearGraph()
{
// QGraphicsScene *scene = new QGraphicsScene(this);
// scene->setItemIndexMethod(QGraphicsScene::NoIndex);
// setScene(scene);
// scene->addItem(centerNode);
// centerNode->setPos(0, 0);
// if (oldscene != NULL)
// {
// delete oldscene;
// }
scene()->clear();
scene()->setSceneRect(-200, -200, 1000, 1000);
// _edges.clear();
// _nodes.clear();
_friction_factor = 1.0f ;
}
// GroupListView::NodeId GroupListView::addNode(const std::string& node_short_string,const std::string& node_complete_string,NodeType type,AuthType auth,const RsPeerId& ssl_id,const RsPgpId& gpg_id)
// {
// Node *node = new Node(node_short_string,type,auth,this,ssl_id,gpg_id);
// node->setToolTip(QString::fromUtf8(node_complete_string.c_str())) ;
// _nodes.push_back(node) ;
// scene()->addItem(node);
//
// std::map<std::string,QPointF>::const_iterator it(_node_cached_positions.find(gpg_id.toStdString())) ;
// if(_node_cached_positions.end() != it)
// node->setPos(it->second) ;
// else
// {
// qreal x1,y1,x2,y2 ;
// sceneRect().getCoords(&x1,&y1,&x2,&y2) ;
//
// float f1 = (type == GroupListView::ELASTIC_NODE_TYPE_OWN)?0.5:(rand()/(float)RAND_MAX) ;
// float f2 = (type == GroupListView::ELASTIC_NODE_TYPE_OWN)?0.5:(rand()/(float)RAND_MAX) ;
//
// node->setPos(x1+f1*(x2-x1),y1+f2*(y2-y1));
// }
// #ifdef DEBUG_ELASTIC
// std::cerr << "Added node " << _nodes.size()-1 << std::endl ;
// #endif
// return _nodes.size()-1 ;
// }
void GroupListView::itemMoved() void GroupListView::itemMoved()
{ {
if (!timerId) if (!timerId)
@ -108,32 +61,14 @@ void GroupListView::itemMoved()
void GroupListView::keyPressEvent(QKeyEvent *event) void GroupListView::keyPressEvent(QKeyEvent *event)
{ {
switch (event->key()) { switch (event->key())
// case Qt::Key_Up: {
// centerNode->moveBy(0, -20); case Qt::Key_Plus: scaleView(qreal(1.2));
// break;
// case Qt::Key_Down:
// centerNode->moveBy(0, 20);
// break;
// case Qt::Key_Left:
// centerNode->moveBy(-20, 0);
// break;
// case Qt::Key_Right:
// centerNode->moveBy(20, 0);
// break;
case Qt::Key_Plus:
scaleView(qreal(1.2));
break; break;
case Qt::Key_Minus: case Qt::Key_Minus:scaleView(1 / qreal(1.2));
scaleView(1 / qreal(1.2));
break; break;
case Qt::Key_Space: case Qt::Key_Space:
case Qt::Key_Enter: case Qt::Key_Enter:requestIdList() ;
requestIdList() ;
// foreach (QGraphicsItem *item, scene()->items()) {
// if (qgraphicsitem_cast<Node *>(item))
// item->setPos(-150 + qrand() % 300, -150 + qrand() % 300);
// }
break; break;
default: default:
QGraphicsView::keyPressEvent(event); QGraphicsView::keyPressEvent(event);
@ -155,15 +90,7 @@ void GroupListView::timerEvent(QTimerEvent *event)
QRectF R(scene()->sceneRect()) ; QRectF R(scene()->sceneRect()) ;
// if (!itemsMoved) { // do nothing for now.
// killTimer(timerId);
//#ifdef DEBUG_ELASTIC
// std::cerr << "Killing timr" << std::endl ;
//#endif
// timerId = 0;
// }
_friction_factor *= 1.001f ;
// std::cerr << "Friction factor = " << _friction_factor << std::endl;
} }
void GroupListView::setEdgeLength(uint32_t l) void GroupListView::setEdgeLength(uint32_t l)
@ -267,7 +194,6 @@ void GroupListView::forceRedraw()
it->second->update( it->second->boundingRect()) ; it->second->update( it->second->boundingRect()) ;
updateSceneRect(sceneRect()) ; updateSceneRect(sceneRect()) ;
scaleView(1.0);
} }
void GroupListView::wheelEvent(QWheelEvent *event) void GroupListView::wheelEvent(QWheelEvent *event)
{ {
@ -315,20 +241,11 @@ void GroupListView::drawBackground(QPainter *painter, const QRectF &rect)
// Shadow // Shadow
QRectF sceneRect = this->sceneRect(); QRectF sceneRect = this->sceneRect();
// QRectF rightShadow(sceneRect.right(), sceneRect.top() + 5, 5, sceneRect.height());
// QRectF bottomShadow(sceneRect.left() + 5, sceneRect.bottom(), sceneRect.width(), 5);
// if (rightShadow.intersects(rect) || rightShadow.contains(rect))
// painter->fillRect(rightShadow, Qt::darkGray);
// if (bottomShadow.intersects(rect) || bottomShadow.contains(rect))
// painter->fillRect(bottomShadow, Qt::darkGray);
// Fill // Fill
QLinearGradient gradient(sceneRect.topLeft(), sceneRect.bottomRight()); QLinearGradient gradient(sceneRect.topLeft(), sceneRect.bottomRight());
gradient.setColorAt(0, Qt::white); gradient.setColorAt(0, Qt::white);
gradient.setColorAt(1, Qt::lightGray); gradient.setColorAt(1, Qt::lightGray);
painter->fillRect(rect.intersected(sceneRect), gradient); painter->fillRect(rect.intersected(sceneRect), gradient);
//painter->setBrush(Qt::NoBrush);
//painter->drawRect(sceneRect);
// Text // Text
// QRectF textRect(sceneRect.left() + 4, sceneRect.top() + 4, // QRectF textRect(sceneRect.left() + 4, sceneRect.top() + 4,
@ -347,19 +264,31 @@ void GroupListView::drawBackground(QPainter *painter, const QRectF &rect)
// Now draw information about current Identity // Now draw information about current Identity
// //
static const int font_size = 12 ;
if(IdentityItem::_selected_node != NULL) if(IdentityItem::_selected_node != NULL)
{ {
std::cerr << "Drawing selected info" << std::endl; std::cerr << "Drawing selected info" << std::endl;
painter->setPen(Qt::black); painter->setPen(Qt::black);
QFont font = painter->font(); QFont font = painter->font();
font.setBold(true); font.setBold(true);
font.setPointSize(14); font.setPointSize(font_size);
painter->setFont(font); painter->setFont(font);
const RsGxsIdGroup& group_info(IdentityItem::_selected_node->groupInfo()) ; const RsGxsIdGroup& group_info(IdentityItem::_selected_node->groupInfo()) ;
painter->drawText(QPointF(IdentityItem::IMG_SIZE*2.5,50), QString("Id: ")+QString::fromStdString(group_info.mMeta.mGroupId.toStdString() )); std::cerr << "scene rect: " << sceneRect.x() << " " << sceneRect.y() << " " << sceneRect.width() << " " << sceneRect.height() << " " << std::endl;
painter->drawText(QPointF(100,100), QString("Id: ")+QString::fromStdString(group_info.mMeta.mGroupId.toStdString() )); int n=1 ;
static const int line_height = font_size+2 ;
QString typestring = (group_info.mPgpKnown)?(QString("Signed by node ")+QString::fromStdString(rsPeers->getGPGName(group_info.mPgpId))
+ " ("
+QString::fromStdString(group_info.mPgpId.toStdString())
+")"):tr("Anonymous") ;
painter->drawText(sceneRect.translated(IdentityItem::IMG_SIZE*2.5,line_height*n++), QString("Name\t: ")+QString::fromStdString(group_info.mMeta.mGroupName ));
painter->drawText(sceneRect.translated(IdentityItem::IMG_SIZE*2.5,line_height*n++), QString("Id \t: ")+QString::fromStdString(group_info.mMeta.mGroupId.toStdString() ));
painter->drawText(sceneRect.translated(IdentityItem::IMG_SIZE*2.5,line_height*n++), QString("Type\t: ")+typestring );
} }
} }

View file

@ -57,13 +57,6 @@ QRectF IdentityItem::boundingRect() const
return QRectF(-(int)IMG_SIZE/2-10, -(int)IMG_SIZE/2-10, (int)IMG_SIZE+20,(int)IMG_SIZE+35) ; return QRectF(-(int)IMG_SIZE/2-10, -(int)IMG_SIZE/2-10, (int)IMG_SIZE+20,(int)IMG_SIZE+35) ;
} }
//QPainterPath IdentityItem::shape() const
//{
// QPainterPath path;
// path.addRect(-(int)IMG_SIZE, -(int)IMG_SIZE, 2*(int)IMG_SIZE, 2*(int)IMG_SIZE);
// return path;
//}
QImage IdentityItem::makeDefaultIcon(const RsGxsGroupId& id) QImage IdentityItem::makeDefaultIcon(const RsGxsGroupId& id)
{ {
int S = 128 ; int S = 128 ;