1 Star 0 Fork 0

SachieW/netanim

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
packetsscene.cpp 12.22 KB
一键复制 编辑 原始数据 按行查看 历史
Makhtar Diouf 提交于 2015-02-06 19:17 . Qt 5 support
/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
/*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 2 as
* published by the Free Software Foundation;
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*
* Author: John Abraham <[email protected]>
* Contributions: Makhtar Diouf <[email protected]>
*/
#include <QRegExp>
#include "packetsscene.h"
#include "logqt.h"
#include "animpacket.h"
#include "graphpacket.h"
#include "animatormode.h"
#include "packetsmode.h"
#define PACKETS_SCENE_LEFT -100
#define PACKETS_SCENE_TOP -100
#define RULER_X (PACKETS_SCENE_LEFT * 2/3)
#define PI 3.14159265
namespace netanim {
NS_LOG_COMPONENT_DEFINE ("PacketsScene");
PacketsScene * pPacketsScene = 0;
PacketsScene::PacketsScene ():
QGraphicsScene (-100, -100, 1024, 1024),
m_interNodeSpacing (100),
m_fromTime (0),
m_toTime (0),
m_textBubble (0),
m_showGrid (false),
//m_showTable (true),
m_showGraph (true),
m_filter (AnimPacket::ALL),
m_filterRegex (".*"),
m_packetPathItem (0)
{
m_textBubble = new TextBubble ("Info:", "No data available\nDid you load the XML file?");
m_infoWidget = addWidget (m_textBubble);
m_infoWidget->setVisible (true);
m_infoWidget->setPos (sceneRect ().width ()/2, sceneRect ().height ()/2);
m_rulerLine = new QGraphicsLineItem;
addItem (m_rulerLine);
m_packetPathItem = new QGraphicsPathItem;
addItem (m_packetPathItem);
}
PacketsScene *
PacketsScene::getInstance ()
{
if (!pPacketsScene)
{
pPacketsScene = new PacketsScene;
}
return pPacketsScene;
}
void
PacketsScene::resetLines ()
{
m_lineIndex.clear ();
for (std::map <uint32_t, QGraphicsLineItem *>::const_iterator i = m_nodeLines.begin ();
i != m_nodeLines.end ();
++i)
{
QGraphicsLineItem * lineItem = i->second;
removeItem (lineItem);
delete lineItem;
}
m_nodeLines.clear ();
for (std::vector <QGraphicsSimpleTextItem *>::const_iterator i = m_nodeIdTexts.begin ();
i != m_nodeIdTexts.end ();
++i)
{
QGraphicsSimpleTextItem * textItem = *i;
removeItem (textItem);
delete textItem;
}
m_nodeIdTexts.clear ();
for (std::vector <QGraphicsLineItem *>::const_iterator i = m_packetLines.begin ();
i != m_packetLines.end ();
++i)
{
QGraphicsLineItem * packetLine = *i;
//removeItem (packetLine);
delete packetLine;
}
m_packetLines.clear ();
for (std::vector <QGraphicsSimpleTextItem *>::const_iterator i = m_rulerTexts.begin ();
i != m_rulerTexts.end ();
++i)
{
QGraphicsSimpleTextItem * txt = *i;
removeItem (txt);
delete txt;
}
m_rulerTexts.clear ();
for (std::vector <QGraphicsLineItem *>::const_iterator i = m_horizontalRulerLines.begin ();
i != m_horizontalRulerLines.end ();
++i)
{
QGraphicsLineItem * line = *i;
removeItem (line);
delete line;
}
m_horizontalRulerLines.clear ();
for (std::vector <QGraphicsSimpleTextItem *>::const_iterator i = m_packetInfoTexts.begin ();
i != m_packetInfoTexts.end ();
++i)
{
QGraphicsSimpleTextItem * text = *i;
removeItem (text);
delete text;
}
m_packetInfoTexts.clear ();
invalidate ();
setSceneRect (-100, -100, 1024, 1024);
}
bool
PacketsScene::setUpNodeLines ()
{
bool foundNodes = false;
QRectF r = sceneRect ();
qreal height = r.bottom () - r.top ();
m_borderHeight = 0.01 * height;
m_lineLength = r.bottom () - m_borderHeight;
r.setWidth (100 * m_interNodeSpacing);
setSceneRect (r);
uint32_t nodeCount = AnimNodeMgr::getInstance ()->getCount ();
if (!nodeCount)
return foundNodes;
for (int lineIndex = 0; lineIndex < m_allowedNodes.count () ; ++lineIndex)
{
foundNodes = true;
QGraphicsLineItem * lineItem = addLine (m_interNodeSpacing * lineIndex, m_borderHeight, m_interNodeSpacing * lineIndex, m_lineLength);
m_nodeLines[m_allowedNodes[lineIndex]] = lineItem;
QGraphicsSimpleTextItem * nodeIdText = new QGraphicsSimpleTextItem (QString::number (m_allowedNodes[lineIndex]));
addItem (nodeIdText);
m_nodeIdTexts.push_back (nodeIdText);
nodeIdText->setPos (m_interNodeSpacing * lineIndex, -m_borderHeight);
m_lineIndex[m_allowedNodes[lineIndex]] = lineIndex;
}
m_rulerLine->setLine (RULER_X, m_borderHeight, RULER_X, m_lineLength);
return foundNodes;
}
qreal
PacketsScene::timeToY (qreal t)
{
qreal y = m_borderHeight + ((t-m_fromTime) * ((m_lineLength-m_borderHeight)/(m_toTime-m_fromTime)));
//NS_LOG_DEBUG ("y:" << y << " t-m_fromTime" << (t-m_fromTime));
//NS_LOG_DEBUG ("LineLength:" << m_lineLength << " (m_toTime-m_fromTime)" << (m_toTime-m_fromTime));
return y;
}
void
PacketsScene::addPacket (qreal tx, qreal rx, uint32_t fromNodeId, uint32_t toNodeId, QString metaInfo, bool drawPacket)
{
QString shortMeta = "";
if (m_filter != AnimPacket::ALL)
{
bool result;
shortMeta = AnimPacket::getMeta (metaInfo, m_filter, result, false);
if (!result)
return;
}
else
{
shortMeta = AnimPacket::getMeta (metaInfo, false);
}
QRegExp rex (m_filterRegex);
if (rex.indexIn (metaInfo) == -1)
{
return;
}
qreal txY = 0;
qreal rxY = 0;
if (drawPacket && m_showGraph)
{
qreal fromNodeX = m_interNodeSpacing * m_lineIndex[fromNodeId];
qreal toNodeX = m_interNodeSpacing * m_lineIndex[toNodeId];
txY = timeToY (tx);
rxY = timeToY (rx);
GraphPacket * graphPacket = new GraphPacket (QPointF (fromNodeX, txY), QPointF (toNodeX, rxY));
//addItem (graphPacket);
m_packetPath.moveTo (graphPacket->line ().p1 ());
m_packetPath.lineTo (graphPacket->line ().p2 ());
qreal angle = 45;
qreal mag = 9;
QPointF endPoint (graphPacket->line ().p2 ());
if (1)
{
if (graphPacket->line ().angle () > 270)
{
m_packetPath.moveTo (endPoint);
angle += graphPacket->line ().angle ();
//NS_LOG_DEBUG ("Angle:" << graphPacket->line ().angle () << " Final Angle:" << angle);
m_packetPath.lineTo (endPoint.x () - mag * cos (angle * PI/180), endPoint.y () - mag * sin (angle * PI/180));
m_packetPath.moveTo (endPoint);
m_packetPath.lineTo (endPoint.x () - mag * cos (angle * PI/180), endPoint.y () + mag * sin (angle * PI/180));
}
else if (graphPacket->line ().angle () > 180)
{
m_packetPath.moveTo (endPoint);
angle += 180 - graphPacket->line ().angle ();
//NS_LOG_DEBUG ("Angle:" << graphPacket->line ().angle () << " Final Angle:" << angle);
m_packetPath.lineTo (endPoint.x () + mag * cos (angle * PI/180), endPoint.y () - mag * sin (angle * PI/180));
m_packetPath.moveTo (endPoint);
m_packetPath.lineTo (endPoint.x () + mag * cos (angle * PI/180), endPoint.y () + mag * sin (angle * PI/180));
}
}
m_packetPathItem->setPath (m_packetPath);
m_packetLines.push_back (graphPacket);
QGraphicsSimpleTextItem * info = new QGraphicsSimpleTextItem (shortMeta);
addItem (info);
m_packetInfoTexts.push_back (info);
info->setFlag (QGraphicsItem::ItemIgnoresTransformations);
info->setPos (QPointF (fromNodeX, txY));
qreal textAngle = graphPacket->line().angle ();
if(textAngle < 90)
{
textAngle = 360-textAngle;
}
else if (textAngle > 270)
{
textAngle = 360-textAngle;
}
else
{
textAngle = 180-textAngle;
info->setPos (QPointF (toNodeX, rxY));
}
info->setTransform (QTransform ().rotate (textAngle));
}
Table * table = PacketsMode::getInstance ()->getTable ();
QStringList sl;
sl << QString::number (fromNodeId)
<< QString::number (toNodeId)
<< QString::number (tx)
<< shortMeta;
table->addRow (sl);
if (m_showGrid && drawPacket && m_showGraph)
{
QGraphicsSimpleTextItem * txText = new QGraphicsSimpleTextItem (QString::number (tx));
txText->setFlag (QGraphicsItem::ItemIgnoresTransformations);
addItem (txText);
txText->setPos (RULER_X, txY);
QPen pen (QColor (200, 100, 155, 100));
QGraphicsLineItem * horizontalTxLine = new QGraphicsLineItem (RULER_X, txY, m_interNodeSpacing * m_lineIndex.size (), txY);
QGraphicsLineItem * horizontalRxLine = new QGraphicsLineItem (RULER_X, rxY, m_interNodeSpacing * m_lineIndex.size (), rxY);
horizontalTxLine->setPen (pen);
horizontalRxLine->setPen (pen);
addItem (horizontalTxLine);
addItem (horizontalRxLine);
QGraphicsSimpleTextItem * rxText = new QGraphicsSimpleTextItem (QString::number (rx));
addItem (rxText);
rxText->setFlag (QGraphicsItem::ItemIgnoresTransformations);
rxText->setPos (RULER_X, rxY);
//graphPacket->setPos (QPointF (fromNodeX, txY));
m_rulerTexts.push_back (txText);
m_rulerTexts.push_back (rxText);
m_horizontalRulerLines.push_back (horizontalTxLine);
m_horizontalRulerLines.push_back (horizontalRxLine);
}
}
void
PacketsScene::showGraph (bool show)
{
m_showGraph = show;
}
void
PacketsScene::setRegexFilter (QString reg)
{
m_filterRegex = reg;
}
void
PacketsScene::setFilter (int ft)
{
m_filter = ft;
}
void
PacketsScene::redraw (qreal fromTime, qreal toTime, QVector<uint32_t> allowedNodes, bool showGrid)
{
m_showGrid = showGrid;
resetLines ();
if (fromTime >= toTime)
{
NS_LOG_DEBUG ("From Time should be lesser than To Time");
return;
}
m_fromTime = fromTime;
m_toTime = toTime;
m_allowedNodes = allowedNodes;
addPackets ();
}
bool
PacketsScene::isAllowedNode (uint32_t nodeId)
{
for (int i = 0; i < m_allowedNodes.count (); ++i)
{
if (m_allowedNodes[i] == nodeId)
return true;
}
return false;
}
void
PacketsScene::addPackets ()
{
bool foundNodes = setUpNodeLines ();
if (!foundNodes)
return;
Table * table = PacketsMode::getInstance ()->getTable ();
table->removeAllRows ();
uint32_t count = 0;
uint32_t maxPackets = 10000;
if (m_packetPathItem)
{
removeItem (m_packetPathItem);
}
m_packetPathItem = new QGraphicsPathItem;
addItem (m_packetPathItem);
m_packetPath = QPainterPath ();
TimeValue <AnimEvent*> *events = AnimatorMode::getInstance ()->getEvents ();
for (TimeValue<AnimEvent *>::TimeValue_t::const_iterator i = events->Begin ();
i != events->End ();
++i)
{
AnimEvent * ev = i->second;
if (ev->m_type == AnimEvent::PACKET_FBTX_EVENT)
{
AnimPacketEvent * packetEvent = static_cast<AnimPacketEvent *> (ev);
if (!isAllowedNode (packetEvent->m_fromId))
continue;
if (!isAllowedNode (packetEvent->m_toId))
continue;
if (packetEvent->m_fbRx > m_toTime)
continue;
if (packetEvent->m_fbTx < m_fromTime)
continue;
if ((count == maxPackets) && m_showGraph)
AnimatorMode::getInstance ()->showPopup ("Currently only the first " + QString::number (maxPackets) + " packets will be shown. Table will be fully populated");
addPacket (packetEvent->m_fbTx, packetEvent->m_fbRx, packetEvent->m_fromId, packetEvent->m_toId, packetEvent->m_metaInfo, count < maxPackets );
AnimatorMode::getInstance ()->keepAppResponsive ();
++count;
}
}
table->adjust ();
m_infoWidget->setVisible (false);
}
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/wangzewenxi/netanim.git
[email protected]:wangzewenxi/netanim.git
wangzewenxi
netanim
netanim
master

搜索帮助