我认为我的问题非常简单,我可能忽略了一些非常明显的事情,但是我已经有一段时间没能解决这个问题了。
在我当前的 QT 项目中,我有 2 个文件,其中一个是窗口,另一个是小部件。我的窗口调用我的“自定义”小部件并创建它的一个实例并将其注入框架。将小部件放置到窗口中是由一个可以多次单击的按钮控制的,因为我最终希望一次在屏幕上显示多个小部件实例。
这就是问题所在:每当我的小部件的新实例被放置在框架中时,它们似乎只是在镜像彼此的值,这意味着当我在小部件的第一个实例中执行操作时,它会发生在小部件的每个实例中(但是,它有时似乎不会立即更新,但我知道它会发生)。我希望它们是单独的实例,它们将来会相互交互。
这是我处理注入小部件的方式:
void Window::on_btnNewCell_clicked()
{
ui->verLay->addWidget(new Neuron());
}
这是我的小部件代码的主要部分:
#include "neuron.h"
#include "ui_neuron.h"
#include "qtimer.h"
// Define Neuron Properties
int volt = -70;
int rest = -70;
int max = 40;
// Logic Contol
int excAmt = 10;
int inhAmt = -10;
bool refract = false;
bool timerActive;
bool st = true;
Neuron::Neuron(QWidget *parent):QWidget(parent), ui(new Ui::Neuron)
{
ui->setupUi(this);
//Homeostatic Voltage Changing Timer
tiHom = new QTimer(this);
connect(tiHom, SIGNAL(timeout()), this, SLOT(changeVoltage()),Qt::DirectConnection );
//Duration of mouse depression timer
tiPrs = new QTimer(this);
connect(tiPrs, SIGNAL(timeout()), this, SLOT(chgVltg()),Qt::DirectConnection );
timerActive = false;
}
Neuron::~Neuron()
{
delete ui;
}
// CUSTOM METHODS
void Neuron::changeVoltage(int c)
{
volt = (volt + c);
if (volt >= max) // begin action potential
{
volt = rest;
timerActive = false;
tiHom->stop();
ui->chkFired->setChecked(true);
}
if (volt <= rest) // to not drop below -40
{
if (timerActive == true)
{
timerActive = false;
tiHom->stop();
}
volt = rest;
}
else if (volt >= rest) // to drop it to -40
{
if (timerActive == false)
{
timerActive = true;
tiHom->start(100);
}
}
ui->lblVolt->setText(QString::number(volt));
}
void Neuron::changeVoltage()
{
changeVoltage(-1);
}
void Neuron::chgVltg()
{
if (st == true)
{
changeVoltage(excAmt);
}
else
changeVoltage(inhAmt);
}
void Neuron::updateGlow(int i, bool b)
{
QPixmap pic;
if (b == true) {
if (st == true) pic.load(":/Images/Excitatory/" +QString::number(i) +".png");
else pic.load(":/Images/Inhibitory/" +QString::number(i) +".png");
ui->lblE->setPixmap(pic);
ui->lblE->setEnabled(true);
tiPrs->start(100);
}
else
{
ui->lblE->setEnabled(false);
tiPrs->stop();
}
}
//many additional redundant methods for a lack of an efficient way of implementing them