aboutsummaryrefslogtreecommitdiffhomepage
path: root/debugger
diff options
context:
space:
mode:
authorGravatar chudy@google.com <chudy@google.com@2bbb7eff-a529-9590-31e7-b0007b416f81>2012-07-12 14:15:54 +0000
committerGravatar chudy@google.com <chudy@google.com@2bbb7eff-a529-9590-31e7-b0007b416f81>2012-07-12 14:15:54 +0000
commite565de4fad5598890124daadf385930043269415 (patch)
tree9aa76559c3686acb04680d7a0404036af088ab6f /debugger
parent6fc5699e777c27c4eea9587a131aecf6e92a677a (diff)
Seperated Space for displaying breakpoint and deletion icons
Review URL: https://codereview.appspot.com/6356094 git-svn-id: http://skia.googlecode.com/svn/trunk@4563 2bbb7eff-a529-9590-31e7-b0007b416f81
Diffstat (limited to 'debugger')
-rw-r--r--debugger/QT/SkDebuggerGUI.cpp37
-rw-r--r--debugger/QT/SkListWidget.cpp60
2 files changed, 47 insertions, 50 deletions
diff --git a/debugger/QT/SkDebuggerGUI.cpp b/debugger/QT/SkDebuggerGUI.cpp
index 33a7190099..96e155167e 100644
--- a/debugger/QT/SkDebuggerGUI.cpp
+++ b/debugger/QT/SkDebuggerGUI.cpp
@@ -118,16 +118,10 @@ void SkDebuggerGUI::actionDelete() {
QListWidgetItem* item = fListWidget.currentItem();
if (item->data(Qt::UserRole + 2) == true) {
item->setData(Qt::UserRole + 2, false);
- item->setData(Qt::DecorationRole, QPixmap(":/images/Icons/delete.png"));
+ item->setData(Qt::UserRole + 3, QPixmap(":/images/Icons/delete.png"));
} else {
item->setData(Qt::UserRole + 2, true);
- if (item->checkState() == Qt::Unchecked) {
- item->setData(Qt::DecorationRole,
- QPixmap(":/images/Icons/blank.png"));
- } else {
- item->setData(Qt::DecorationRole,
- QPixmap(":/images/Icons/breakpoint_16x16.png"));
- }
+ item->setData(Qt::UserRole + 3, QPixmap(":/images/Icons/blank.png"));
}
int currentRow = fListWidget.currentRow();
// NOTE(chudy): Forces a redraw up to current selected command.
@@ -262,31 +256,12 @@ void SkDebuggerGUI::toggleBreakpoint() {
QListWidgetItem* item = fListWidget.currentItem();
if (item->checkState() == Qt::Unchecked) {
item->setCheckState(Qt::Checked);
-
- /* NOTE(chudy): If the command is toggled as hidden that takes
- * precendence over the breakpoint icon.
- */
- if (item->data(Qt::UserRole + 2) == false) {
- item->setData(Qt::DecorationRole,
- QPixmap(":/images/Icons/delete.png"));
- } else {
- item->setData(Qt::DecorationRole,
- QPixmap(":/images/Icons/breakpoint_16x16.png"));
- }
+ item->setData(Qt::DecorationRole,
+ QPixmap(":/images/Icons/breakpoint_16x16.png"));
} else {
-
- /* NOTE(chudy): When untoggling as a breakpoint if the command
- * is hidden then the portraying icon should remain the delete icon.
- */
item->setCheckState(Qt::Unchecked);
-
- if (item->data(Qt::UserRole + 2) == false) {
- item->setData(Qt::DecorationRole,
- QPixmap(":/images/Icons/delete.png"));
- } else {
- item->setData(Qt::DecorationRole,
- QPixmap(":/images/Icons/blank.png"));
- }
+ item->setData(Qt::DecorationRole,
+ QPixmap(":/images/Icons/blank.png"));
}
}
diff --git a/debugger/QT/SkListWidget.cpp b/debugger/QT/SkListWidget.cpp
index 348321c8cc..f0459dd093 100644
--- a/debugger/QT/SkListWidget.cpp
+++ b/debugger/QT/SkListWidget.cpp
@@ -13,12 +13,12 @@ SkListWidget::SkListWidget(QObject *parent) {}
SkListWidget::~SkListWidget() {}
-void SkListWidget::paint (QPainter *painter, const QStyleOptionViewItem &option, const QModelIndex &index) const {
- /*
- * NOTE(chudy): We adjust the initial position of the list item so that
+void SkListWidget::paint (QPainter *painter,
+ const QStyleOptionViewItem &option,
+ const QModelIndex &index) const {
+ /* We adjust the initial position of the list item so that
* we don't have overlapping top and bottom borders of concurrent
- * widget items.
- */
+ * widget items. */
QRect r = option.rect;
r.adjust(-1,-1,1,0);
@@ -26,7 +26,7 @@ void SkListWidget::paint (QPainter *painter, const QStyleOptionViewItem &option,
QPen fontPen(QColor::fromRgb(51,51,51), 1, Qt::SolidLine);
QPen fontMarkedPen(Qt::white, 1, Qt::SolidLine);
- // NOTE(chudy): If selected.
+ // If selected
if(option.state & QStyle::State_Selected){
QLinearGradient gradientSelected(r.left(),r.top(),r.left(),r.height()+r.top());
gradientSelected.setColorAt(0.0, QColor::fromRgb(119,213,247));
@@ -44,8 +44,8 @@ void SkListWidget::paint (QPainter *painter, const QStyleOptionViewItem &option,
painter->setPen(fontMarkedPen);
} else {
- // NOTE(chudy): Alternating background.
- painter->setBrush( (index.row() % 2) ? Qt::white : QColor(252,252,252) );
+ // Alternating background
+ painter->setBrush((index.row() % 2) ? Qt::white : QColor(252,252,252));
painter->drawRect(r);
painter->setPen(linePen);
@@ -57,24 +57,46 @@ void SkListWidget::paint (QPainter *painter, const QStyleOptionViewItem &option,
painter->setPen(fontPen);
}
- QIcon ic = QIcon(qvariant_cast<QPixmap>(index.data(Qt::DecorationRole)));
- QString title = index.data(Qt::DisplayRole).toString();
- QString description = index.data(Qt::UserRole + 1).toString();
- QString hidden = index.data(Qt::UserRole + 2).toString();
-
+ QIcon breakpointIcon =
+ QIcon(qvariant_cast<QPixmap>(index.data(Qt::DecorationRole)));
+ QIcon deleteIcon =
+ QIcon(qvariant_cast<QPixmap>(index.data(Qt::UserRole + 3)));
+
+ QString drawCommandText = index.data(Qt::DisplayRole).toString();
+ QString drawCommandNumber = index.data(Qt::UserRole + 1).toString();
+ QString isDeleted = index.data(Qt::UserRole + 2).toString();
+
+ /* option.rect is a struct that Qt uses as a target to draw into. Following
+ * the format (x1,y1,x2,y2) x1 and y1 represent where the painter can start
+ * drawing. x2 and y2 represent where the drawing area has to terminate
+ * counting from the bottom right corner of each list item styled with this
+ * widget. A (x1,y1,0,0) rect would mean that the item being drawn would
+ * be pushed down into that bottom corner. Negative values in the x2,y2
+ * spot act as a margin for the bottom and right sides. Positive values in
+ * x1,y1 act as a margin for the top and left. The target area will not
+ * affect size of text but will scale icons. */
int imageSpace = 35;
+
+ // Breakpoint Icon
r = option.rect.adjusted(5, 10, -10, -10);
- ic.paint(painter, r, Qt::AlignVCenter|Qt::AlignLeft);
+ breakpointIcon.paint(painter, r, Qt::AlignVCenter|Qt::AlignLeft);
+
+ // Delete Icon
+ r = option.rect.adjusted(19, 10, -10, -10);
+ deleteIcon.paint(painter, r, Qt::AlignVCenter|Qt::AlignLeft);
- // NOTE(chudy): Draw command.
+ // Draw Command
r = option.rect.adjusted(imageSpace, 0, -10, -7);
- painter->drawText(r.left(), r.top(), r.width(), r.height(), Qt::AlignBottom|Qt::AlignRight, title, &r);
+ painter->drawText(r.left(), r.top(), r.width(), r.height(),
+ Qt::AlignBottom|Qt::AlignRight, drawCommandText, &r);
- // NOTE(chudy): Number of draw command.
+ // Draw Command Number
r = option.rect.adjusted(imageSpace, 0, -10, -7);
- painter->drawText(r.left(), r.top(), r.width(), r.height(), Qt::AlignBottom|Qt::AlignLeft, description, &r);
+ painter->drawText(r.left(), r.top(), r.width(), r.height(),
+ Qt::AlignBottom|Qt::AlignLeft, drawCommandNumber, &r);
}
-QSize SkListWidget::sizeHint ( const QStyleOptionViewItem & option, const QModelIndex & index ) const{
+QSize SkListWidget::sizeHint ( const QStyleOptionViewItem & option,
+ const QModelIndex & index ) const{
return QSize(200, 30);
}