From 21da0f6723f3887d200917b4720dd22261e4420a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Karel=20Ko=C4=8D=C3=AD?= Date: Sun, 17 Dec 2017 13:44:26 +0100 Subject: Implement alu for coreview --- qtmips_gui/coreview/alu.cpp | 62 +++++++++++++++++++++++++++++++++++++++++++++ qtmips_gui/coreview/alu.h | 37 +++++++++++++++++++++++++++ 2 files changed, 99 insertions(+) create mode 100644 qtmips_gui/coreview/alu.cpp create mode 100644 qtmips_gui/coreview/alu.h (limited to 'qtmips_gui/coreview') diff --git a/qtmips_gui/coreview/alu.cpp b/qtmips_gui/coreview/alu.cpp new file mode 100644 index 0000000..76cf8ad --- /dev/null +++ b/qtmips_gui/coreview/alu.cpp @@ -0,0 +1,62 @@ +#include "alu.h" + +////////////////////// +#define WIDTH 40 +#define HEIGHT 120 +#define DENT 10 +#define PENW 1 +////////////////////// + +coreview::Alu::Alu() : QGraphicsObject(nullptr), name(this) { + name.setText("ALU"); + name.setPos(3, 25); + + con_in_a = new Connector(); + con_in_b = new Connector(); + con_out = new Connector(); + con_ctl = new Connector(); + + setPos(x(), y()); // set connector's position +} + +QRectF coreview::Alu::boundingRect() const { + return QRectF(-PENW / 2, -PENW / 2, WIDTH + PENW, HEIGHT + PENW); +} + +void coreview::Alu::paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget) { + const QPointF poly[] = { + QPointF(0, 0), + QPointF(WIDTH, WIDTH), + QPointF(WIDTH, HEIGHT - WIDTH), + QPointF(0, HEIGHT), + QPointF(0, (HEIGHT/2) + DENT), + QPointF(DENT, HEIGHT / 2), + QPointF(0, (HEIGHT / 2) - DENT) + }; + painter->drawPolygon(poly, sizeof(poly) / sizeof(QPointF)); +} + +void coreview::Alu::setPos(qreal x, qreal y) { + QGraphicsObject::setPos(x, y); + qreal off = ((HEIGHT/2) - DENT) / 2; + con_in_a->setPos(0, off); + con_in_b->setPos(0, HEIGHT - off); + con_out->setPos(WIDTH, HEIGHT/2); + con_ctl->setPos(WIDTH/2, HEIGHT - (WIDTH/2)); +} + +const coreview::Connector *coreview::Alu::connector_in_a() const { + return con_in_a; +} + +const coreview::Connector *coreview::Alu::connector_in_b() const { + return con_in_b; +} + +const coreview::Connector *coreview::Alu::connector_out() const { + return con_out; +} + +const coreview::Connector *coreview::Alu::connector_ctl() const { + return con_ctl; +} diff --git a/qtmips_gui/coreview/alu.h b/qtmips_gui/coreview/alu.h new file mode 100644 index 0000000..4c9a73b --- /dev/null +++ b/qtmips_gui/coreview/alu.h @@ -0,0 +1,37 @@ +#ifndef COREVIEW_ALU_H +#define COREVIEW_ALU_H + +#include +#include +#include "../coreview.h" +#include "connection.h" + +namespace coreview { + +class Alu : public QGraphicsObject { +public: + Alu(); + + QRectF boundingRect() const; + void paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget); + + void setPos(qreal x, qreal y); + const Connector *connector_in_a() const; + const Connector *connector_in_b() const; + const Connector *connector_out() const; + const Connector *connector_ctl() const; + +private: + QGraphicsSimpleTextItem name; + Connector *con_in_a, *con_in_b, *con_out, *con_ctl; +}; + +} + +#else + +namespace coreview { + class Alu; +} + +#endif // COREVIEW_ALU_H -- cgit v1.2.3