Qt的update不进入paintevent更新不了

#include"A.cpp"
#include"B.cpp"
mian::Qwidget
{……}

A.cpp中
{……
B.setvalue(para);
……}

B.cpp中

B::B(QWidget *parent) :
QWidget(parent)
{
m_startAngle=0;
// m_currentvalue=0;
UpdateTime=new QTimer(this);
UpdateTime->setInterval(10);
connect(UpdateTime,SIGNAL(timeout()),this,SLOT(UpdateGraph()));
//UpdateTime->start();
}
void PShowDisplay::paintEvent(QPaintEvent *)
{…
PARA//包含这个一直变化的参数希望通过update来更新…}
……
setvalue(para)
{
PARA=para;//参数一直变化
UpdateTime->start();
}

void PShowDisplay::UpdateGraph()
{

this->update();//没有进入paintevent中

}

请问为什么没有更新??有一个例子和我的代码一样, 为啥他额能够更新,我的不能呢??

2个回答

repaint()呢?

试过了,不行图片说明

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
qt绘图时paintEvent执行不及时

我想在qt中绘制一条轨迹,是由好多个点组成的。想在显示时有那种绘制的动画过程,所以每添加一个点调用一次update(),但qt是将所有的update压缩到一起最后用paintevevt显示的,动画效果就消失了。用repaint替换update程序就报错。求各位高人指点应该怎样才能实现这个动画效果啊?

QT5 为什么我调用paintEvent,图片和文字都显示不了了

这是我显示图片的代码 ``` QImage image(pic); pixmap = new QPixmap; pixmap->fromImage(image); setPixmap(*pixmap); ``` 可是我把paintEvent删除之后图片就又显示出来了啊

QT paintEvent(QPaintEvent *)画图问题 急急急

#include "widget.h" Widget::Widget(QWidget *parent) : QWidget(parent) { setFixedSize(600,600); QLabel *label = new QLabel(tr("Images side is 50 !")); label->setFixedHeight(50); QLineEdit *edit = new QLineEdit(tr("50")); //QLineEdit *edit2 = new QLineEdit(); QPushButton *button1 = new QPushButton(tr("Random")); button1->setFixedHeight(50); QPushButton *button2 = new QPushButton(tr("Previous")); button2->setFixedHeight(50); QPushButton *button3 = new QPushButton(tr("Next")); button3->setFixedHeight(50); QGroupBox *box = new QGroupBox; QRadioButton *radio1 = new QRadioButton(tr("3*3")); QRadioButton *radio2 = new QRadioButton(tr("5*5")); QVBoxLayout *vbox = new QVBoxLayout; vbox->addWidget(radio1); vbox->addWidget(radio2); box->setLayout(vbox); QHBoxLayout *layout = new QHBoxLayout; layout->addWidget(label); layout->addWidget(edit); layout->addWidget(button1); //layout->addWidget(edit2); layout->addWidget(button2); layout->addWidget(button3); layout->addWidget(box); layout->setAlignment(Qt::AlignTop); setLayout(layout); L=edit->text().toInt();//**这里** //QString str = QString::number(L); //edit2->setText(str); connect(button1,SIGNAL(clicked()),this,SLOT(change())); } void Widget::change() { //this->repaint(); this->update(); } void Widget::random() { int m = qrand()%100; if(m<=20){ color = false; }else{ color = true; } } void Widget::paintEvent(QPaintEvent *) { int length; int i=0; int j=70;//**这里** //length=edit->text().toInt();//为什么用这两行行代码程序就崩溃了,要怎样才能实现根据edit中输入的数值 //L=edit->text().toInt(); // 来刷新我生成矩形的数目啊 length=L; QPainter painter(this); for(int m=0;m<=length;m++){ for(int n=0;n<=length;n++){ painter.begin(this); random(); if(color){ painter.setBrush(QBrush(Qt::white,Qt::SolidPattern)); }else{ painter.setBrush(QBrush(Qt::black,Qt::SolidPattern)); } painter.setPen(QPen(Qt::gray)); painter.drawRect(i,j,i+10,j+10); painter.end(); i=i+10; } i=0; j=j+10; } }

qt的重绘事件的显示问题

用重绘事件显示一段硬盘信息,希望每次update都只显示当次的信息,结果第二次update后第一次绘画的也会留在上面,以后每次update也就只会显示两个信息,以下是我的重绘事件的全部处理代码 ``` QPainter painter(this); for(int i = 0;i < statListString.count();++i) { painter.drawText(0,90 + 16 * i,statListString.at(i)); } ``` 可以看到每次重绘的开始地点是一样的,但是结果第一次后呢是![图片说明](https://img-ask.csdn.net/upload/201506/25/1435197564_635815.png),第二次后的每次就是![图片说明](https://img-ask.csdn.net/upload/201506/25/1435197592_913850.png),希望有经验的大神指教

求问大神:Qt用label显示图片,如何实现第一次点击后显示矩形,第二次点击后再显示一个矩形,之前的不消失

求问大家,我用label显示图片,重写paintEvent来显示鼠标点击位置的一个矩形,在 mousePressEvent里用update()来实现随鼠标位置更新矩形,但是这样就会使之前的 矩形消失。 怎么样才能实现鼠标每点击一次,在鼠标位置显示一个矩形,且之前的不会消失。 代码如下: **QImageLabel.h** ``` class QImageLabel : public QLabel { Q_OBJECT public: QImageLabel(QWidget *parent = 0); virtual ~QImageLabel(); protected: void paintEvent(QPaintEvent *event); void mousePressEvent(QMouseEvent *event); private: QPoint currentpos; }; ``` **QImageLabel.cpp** ``` #include "QImageLabel.h" #include <QtWidgets> QImageLabel::QImageLabel(QWidget *parent): QLabel(parent) { currentpos.setX(0); currentpos.setY(0); } QImageLabel::~QImageLabel() { } void QImageLabel::paintEvent(QPaintEvent *event) { QLabel::paintEvent(event); //需要调用父类的paintEvent事件,否则Label都无法绘制 QPainter painter(this); painter.setPen(Qt::red); painter.drawRect(currentpos.x() - 30, currentpos.y() - 30, 60, 60); } void QImageLabel::mousePressEvent(QMouseEvent *event) { currentpos = event->pos(); update(); } ```

Qt使用多线程刷新界面,界面一段时间后不响应

我设计了一个串口工作线程和界面刷新主线程。 串口线程如下: #include "thread.h" #include "mainwindow.h" #include <QDebug> #include <QMutexLocker> Thread::Thread() { //初始化 } Thread::~Thread() { mutex.lock(); abort = true; mutex.unlock(); wait(); }//析构 void Thread::run() //这就是线程的具体工作了 { // qint64 f=0; int i; int fd; int nread=1; //int nwrite int count=0;//size of writed buff fd=open("/dev/ttySAC1",O_RDONLY | O_NOCTTY); set_speed(fd,115200); if(set_Parity(fd,8,1,'N')==FALSEE) { printf("Set Parity Error\n"); exit (0); } while(!abort) { qDebug()<<"r:"<<QThread::currentThreadId(); nread=read(fd,buff1,1); qDebug()<<"rea"; if(nread>0) { buff[count]=buff1[0]; count++; // qDebug()<<count; } if(count==16) { dosomething; count=0; emit receiver16(nameflag,time,datas); msleep(85); nameflag=0; } } close(fd); } 界面主线程: #include "mainwindow.h" #include <QPainter> #include <QDebug> #include <QMutexLocker> void MyMainWindow::paintEvent(QPaintEvent *) //paintEvent函数由系统自动调用,用不着我们人为的去调用。 { QPainter paint;//1024*768 paint.begin(this); /*画一大堆东西*/ qDebug()<<"paint"; paint.end(); } MyMainWindow::MyMainWindow(QWidget *parent) :QWidget(parent) { setGeometry(0,0,1024,768); ioread= new Thread; timer = new QTimer; timerPon= new QTimer;//总共4个定时器,但结构都是这样的 ioread->start(QThread::InheritPriority); connect(ioread,SIGNAL(receiver16(int,char *,char *)),this,SLOT(display(int,char *,char *))); connect(timer, SIGNAL(timeout()), this, SLOT(timerFunction())); connect(timerPon, SIGNAL(timeout()), this, SLOT(timerFunctionPon())); //初始化; } void MyMainWindow::display(int nameflag,char *time,char *datas) { qDebug()<<"dis:"<<QThread::currentThreadId(); DoSth……; update(); } void MyMainWindow::timerFunction() { cttimerDoSth; } void MyMainWindow::timerFunctionPon() { PonttimerDoSth; } 运行了一段时间(一般是几个小时后)界面卡住不动了,定时器计时都不显示了,这是怎么回事啊?

用qt写的五子棋界面,请问为什么第一行和第一列 不能落棋子? 大佬 bai'tuo

# ![图片说明](https://img-ask.csdn.net/upload/201903/10/1552210863_538638.jpg) ChessWidget::ChessWidget(QWidget *parent) : QWidget(parent) { ui.setupUi(this); this->setFixedSize(800, 660); this->setAutoFillBackground(true); QPalette palette; palette.setColor(QPalette::Window, QColor("#B1723C")); this->setPalette(palette); for (int i = 0; i < 15; ++i) { for (int j = 0; j < 15; ++j) { chess[i][j] = empyt; } } } ChessWidget::~ChessWidget() { } void ChessWidget::paintEvent(QPaintEvent *) { QPainter painter(this); painter.setRenderHint(QPainter::Antialiasing, true);//反走样 QPen pen; pen.setColor(QColor("#8D5822")); pen.setWidth(7); painter.setPen(pen); QBrush brush; brush.setColor(QColor("#EEC085")); brush.setStyle(Qt::SolidPattern); painter.setBrush(brush); painter.drawRect(10, 10, 620, 620); QPainter painters(this); painters.setRenderHint(QPainter::Antialiasing, true); int i, j; for (i = 0; i <= 15; ++i) { painters.drawLine(20, 20 + i * 40, 620, 20 + i * 40); painters.drawLine(20 + i * 40, 20, 20 + i * 40, 620); } brush.setStyle(Qt::SolidPattern); for (i = 0; i < 15; ++i) { for (j = 0; j < 15; ++j) { if (chess[i][j] == BLACK) { brush.setColor(Qt::black); painters.setBrush(brush); painters.drawEllipse(QPoint((i) * 40 + 20, (j ) * 40 + 20), 20, 20); } else if (chess[i][j] == WHITE) { brush.setColor(Qt::white); painters.setBrush(brush); painters.drawEllipse(QPoint((i) * 40 + 20, (j) * 40 + 20), 20, 20); } } } } void ChessWidget::mousePressEvent(QMouseEvent *e) { int x, y; if (e->x() >= 20 || e->x() <= 620 || e->y() >= 20 || e->y() <= 620) { x = (e->x()-20)/40; y = (e->y()-20)/40; if (chess[x][y]==empyt) { chess[x][y] = player++ % 2 + 1; } } update(); } ``` ``` ``` ``` ``` ```

QWidget重绘事件不响应

从一个非GUI dll里面使用widget指针不论使用 update还是repaint刷屏方式,都不能及时刷新屏幕,如果将Widget控件最小化然后再最大化,就可以看到刷新后的屏幕。这是神马问题啊...请问有遇到这个问题的吗?paintevent我已重新实现,什么原因,求教.

PyQt5中如何在lable中加载的图片上绘制矩形框呢?

我的程序是通过摄像头采集一帧图像,点击开始标记按钮后显示在按钮左侧的lable中(灰色框)。 我希望可以在lable中加载的一帧图像中通过点击鼠标左键开始绘制矩形,按住左键拖动时改变矩形的形状,松开左键后完成绘制。(和lableImg软件类似)。 请问如何实现上述功能呢?我目前找到的方法是使用QPainter来实现,但是在我的代码中该如何实现呢?万分感谢! ![图片说明](https://img-ask.csdn.net/upload/201812/12/1544601796_693173.png) 附上我的完整代码如下: ``` # -*- coding: utf-8 -*- import sys import cv2 from PyQt5 import QtCore, QtGui, QtWidgets from PyQt5.QtWidgets import * from PyQt5.QtCore import * from PyQt5.QtGui import * # ~ class MyLabel(QLabel): # ~ def paintEvent(self, event): # ~ width = self.pos2[0]-self.pos1[0] # ~ height = self.pos2[1] - self.pos1[1] # ~ qp = QPainter() # ~ qp.begin(self) # ~ qp.drawRect(self.pos1[0], self.pos1[1], width, height) # ~ qp.end() # ~ def mousePressEvent(self, event): # ~ self.pos1[0], self.pos1[1] = event.pos().x(), event.pos().y() # ~ print("clicked") # ~ def mouseReleaseEvent(self, event): # ~ self.pos2[0], self.pos2[1] = event.pos().x(), event.pos().y() # ~ print("released") # ~ self.update() class Ui_train_window(QtWidgets.QWidget): def setupUi(self, train_window): train_window.setObjectName("train_window") train_window.resize(690, 600) train_window.setMaximumSize(QtCore.QSize(690, 600)) self.horizontalLayoutWidget = QtWidgets.QWidget(train_window) self.horizontalLayoutWidget.setGeometry(QtCore.QRect(0, 10, 681, 80)) self.horizontalLayoutWidget.setObjectName("horizontalLayoutWidget") self.horizontalLayout = QtWidgets.QHBoxLayout(self.horizontalLayoutWidget) self.horizontalLayout.setContentsMargins(0, 0, 0, 0) self.horizontalLayout.setObjectName("horizontalLayout") self.lab_enter_name = QtWidgets.QLabel(self.horizontalLayoutWidget) self.lab_enter_name.setObjectName("lab_enter_name") self.horizontalLayout.addWidget(self.lab_enter_name) self.le_username = QtWidgets.QLineEdit(self.horizontalLayoutWidget) self.le_username.setObjectName("le_username") self.horizontalLayout.addWidget(self.le_username) self.lab_enter_pw = QtWidgets.QLabel(self.horizontalLayoutWidget) self.lab_enter_pw.setObjectName("lab_enter_pw") self.horizontalLayout.addWidget(self.lab_enter_pw) self.le_userpw = QtWidgets.QLineEdit(self.horizontalLayoutWidget) self.le_userpw.setObjectName("le_userpw") self.le_userpw.setEchoMode(QLineEdit.Password) self.horizontalLayout.addWidget(self.le_userpw) self.label = QtWidgets.QLabel(self.horizontalLayoutWidget) self.label.setObjectName("label") self.horizontalLayout.addWidget(self.label) self.le_ipadr = QtWidgets.QLineEdit(self.horizontalLayoutWidget) self.le_ipadr.setObjectName("le_ipadr") self.horizontalLayout.addWidget(self.le_ipadr) self.btn_openIPcam = QtWidgets.QPushButton(self.horizontalLayoutWidget) self.btn_openIPcam.setMinimumSize(QtCore.QSize(50, 10)) self.btn_openIPcam.setObjectName("btn_openIPcam") self.horizontalLayout.addWidget(self.btn_openIPcam) self.show = QtWidgets.QLabel(train_window) self.show.setGeometry(QtCore.QRect(15, 110, 531, 371)) self.show.setObjectName("show") self.show.setStyleSheet(("border:2px solid lightgray")) self.verticalLayoutWidget = QtWidgets.QWidget(train_window) self.verticalLayoutWidget.setGeometry(QtCore.QRect(560, 100, 111, 381)) self.verticalLayoutWidget.setObjectName("verticalLayoutWidget") self.verticalLayout = QtWidgets.QVBoxLayout(self.verticalLayoutWidget) self.verticalLayout.setContentsMargins(0, 0, 0, 0) self.verticalLayout.setObjectName("verticalLayout") self.btn_start = QtWidgets.QPushButton(self.verticalLayoutWidget) self.btn_start.setObjectName("btn_start") self.verticalLayout.addWidget(self.btn_start) self.combo_label = QtWidgets.QComboBox(self.verticalLayoutWidget) self.combo_label.setObjectName("combo_label") self.combo_label.addItem("") self.combo_label.addItem("") self.combo_label.addItem("") self.combo_label.addItem("") self.combo_label.addItem("") self.combo_label.addItem("") self.verticalLayout.addWidget(self.combo_label) self.btn_save = QtWidgets.QPushButton(self.verticalLayoutWidget) self.btn_save.setObjectName("btn_save") self.verticalLayout.addWidget(self.btn_save) self.btn_finish = QtWidgets.QPushButton(self.verticalLayoutWidget) self.btn_finish.setObjectName("btn_finish") self.verticalLayout.addWidget(self.btn_finish) self.horizontalLayoutWidget_2 = QtWidgets.QWidget(train_window) self.horizontalLayoutWidget_2.setGeometry(QtCore.QRect(0, 500, 681, 71)) self.horizontalLayoutWidget_2.setObjectName("horizontalLayoutWidget_2") self.horizontalLayout_2 = QtWidgets.QHBoxLayout(self.horizontalLayoutWidget_2) self.horizontalLayout_2.setContentsMargins(0, 0, 0, 0) self.horizontalLayout_2.setObjectName("horizontalLayout_2") self.lab_stepnum = QtWidgets.QLabel(self.horizontalLayoutWidget_2) self.lab_stepnum.setObjectName("lab_stepnum") self.horizontalLayout_2.addWidget(self.lab_stepnum) self.le_stepnm = QtWidgets.QLineEdit(self.horizontalLayoutWidget_2) self.le_stepnm.setObjectName("le_stepnm") self.horizontalLayout_2.addWidget(self.le_stepnm) self.lab_batchsize = QtWidgets.QLabel(self.horizontalLayoutWidget_2) self.lab_batchsize.setObjectName("lab_batchsize") self.horizontalLayout_2.addWidget(self.lab_batchsize) self.le_batchsize = QtWidgets.QLineEdit(self.horizontalLayoutWidget_2) self.le_batchsize.setObjectName("le_batchsize") self.horizontalLayout_2.addWidget(self.le_batchsize) self.btn_pretrain = QtWidgets.QPushButton(self.horizontalLayoutWidget_2) self.btn_pretrain.setObjectName("btn_pretrain") self.horizontalLayout_2.addWidget(self.btn_pretrain) self.btn_retrain = QtWidgets.QPushButton(self.horizontalLayoutWidget_2) self.btn_retrain.setObjectName("btn_retrain") self.horizontalLayout_2.addWidget(self.btn_retrain) self.show.raise_() self.horizontalLayoutWidget.raise_() self.verticalLayoutWidget.raise_() self.horizontalLayoutWidget_2.raise_() self.retranslateUi(train_window) self.btn_openIPcam.clicked.connect(self.IPinfo) self.btn_start.clicked.connect(self.labledata) QtCore.QMetaObject.connectSlotsByName(train_window) def retranslateUi(self, train_window): _translate = QtCore.QCoreApplication.translate train_window.setWindowTitle(_translate("train_window", "训练工具")) self.lab_enter_name.setText(_translate("train_window", "输入IP摄像头用户名:")) self.lab_enter_pw.setText(_translate("train_window", "输入IP摄像头密码:")) self.label.setText(_translate("train_window", "IP地址")) self.btn_openIPcam.setText(_translate("train_window", "连接IP摄像头")) self.show.setText(_translate("train_window", "")) self.btn_start.setText(_translate("train_window", "开始标记")) self.combo_label.setItemText(0, _translate("train_window", "a")) self.combo_label.setItemText(1, _translate("train_window", "b")) self.combo_label.setItemText(2, _translate("train_window", "c")) self.combo_label.setItemText(3, _translate("train_window", "d")) self.combo_label.setItemText(4, _translate("train_window", "e")) self.combo_label.setItemText(5, _translate("train_window", "f")) self.btn_save.setText(_translate("train_window", "保存")) self.btn_finish.setText(_translate("train_window", "标记结束")) self.lab_stepnum.setText(_translate("train_window", "迭代次数:")) self.lab_batchsize.setText(_translate("train_window", "batchsize:")) self.btn_pretrain.setText(_translate("train_window", "预训练")) self.btn_retrain.setText(_translate("train_window", "重新训练")) def IPinfo(self): username = self.le_username.text() password = self.le_userpw.text() ipaddress = self.le_ipadr.text() #cam_rtsp_addr = "rtsp://" + username + ":" + password + "@" + ipaddress + "/h264/ch33/main/av_stream" #self.camcapture = cv2.VideoCapture(cam_rtsp_addr) self.camcapture = cv2.VideoCapture(0) self.timer = QtCore.QTimer() self.timer.start() self.timer.setInterval(0.3) self.timer.timeout.connect(self.camshow) def camshow(self): global showImage _ , camimg = self.camcapture.read() camimg = cv2.cvtColor(camimg, cv2.COLOR_BGR2RGB) showImage = QtGui.QImage(camimg.data, camimg.shape[1], camimg.shape[0], QtGui.QImage.Format_RGB888) def labledata(self): self.show.setPixmap(QtGui.QPixmap.fromImage(showImage)) if __name__ == "__main__": app = QtWidgets.QApplication(sys.argv) Window = QtWidgets.QWidget() ui = Ui_train_window() ui.setupUi(Window) Window.show() sys.exit(app.exec_()) ```

求C++大神注释一下这个代码

#include <QPainter> #include <QtGui/QApplication> #include <QMouseEvent> #include<ctime> #include <QtGui> #include "dialog.h" #include "ui_dialog.h" using namespace std; Dialog::Dialog(QWidget *parent) : QDialog(parent), ui(new Ui::Dialog) { source_picture_show=false; ui->setupUi(this); ui->spinBox->setMinimum(2);//设置最小值 ui->spinBox->setValue(4); //ui是界面,spinBox是界面中的一个控件,setValue是设置值。给界面中的spinBox设置一个值为4 n=ui->spinBox->value();//获取spinBox中的值,并将其赋给n //n=4; N=n*n; a = new int* [n+2]; for(int i=0; i <n+2; i++) a[i] = new int[n+2]; wsubsize=100; hsubsize=100; bak.load(":/new/prefix1/background3.png"); Bak=bak; setbak(); ui->verticalWidget->setGeometry(n*wsubsize,10,100,150); //wsize=400; //hsize=400; //move(100,10); //max_n=5; //initpicture(); //update(); } Dialog::~Dialog() { delete ui; } void Dialog::setbak() { Bak=Bak.scaled( n*wsubsize , n*hsubsize,Qt::IgnoreAspectRatio, Qt::SmoothTransformation); QPainter pb(&Bak); for (int i=0;i<=n*wsubsize/127;i++ ) for (int j=0;j<=n*hsubsize/127;j++) pb.drawPixmap( i*127, j*127, bak); } void Dialog::paintEvent(QPaintEvent *) { //move( (QApplication::desktop()->width() - width())/2, (QApplication::desktop()->height() - height())/2); //()<<"start paint"; //setFixedHeight(n*hsubsize); //setFixedWidth(n*wsubsize+100); int i,j,p; QPainter painter(this); if (source_picture_show) painter.drawPixmap( 0, 0, pix); else { painter.drawPixmap( 0, 0, Bak); for (int l=1;l<=pixmaps.size();l++) { i=(l-1)%n+1; j=(l-1)/n+1; p=a[i][j]-1; if (p<pixmaps.size()-1) painter.drawPixmap( (i-1)*wsubsize, (j-1)*hsubsize, pixmaps[p]); } } } void Dialog::mousePressEvent(QMouseEvent *m) { if (source_picture_show) return; else { int x = m->pos().x(); int y = m->pos().y(); hit(x/wsubsize+1 , y/hsubsize+1); } } void Dialog::hit(int i,int j) { if (i<1 || j<1 || i>n || j>n) return; if (a[i-1][j]==N) { a[i-1][j]=a[i][j]; a[i][j]=N; } else if (a[i+1][j]==N) { a[i+1][j]=a[i][j]; a[i][j]=N; } else if (a[i][j-1]==N) { a[i][j-1]=a[i][j]; a[i][j]=N; } else if (a[i][j+1]==N) { a[i][j+1]=a[i][j]; a[i][j]=N; } update(); if (check()) { QMessageBox msgBox(this); msgBox.setText(tr("success!")); msgBox.exec(); //initrandom(); //refresh(); } } void Dialog::randomp() { for(int i=0; i <n+2; i++) for(int j=0; j <n+2; j++) { if (i==0 || j==0 || i==n+1 || j==n+1) a[i][j]=0; else a[i][j]=(j-1)*n+i; } int i,j; int p; for(int l=1;l<100*N;l++) { p=findN(); i=(p-1)%n+1; j=(p-1)/n+1; switch (rand()%4) { case 0: if ((i-1)>0) swap(a[i][j],a[i-1][j]); break; case 1: if ((i+1)<n+1) swap(a[i][j],a[i+1][j]); break; case 2: if ((j-1)>0) swap(a[i][j],a[i][j-1]); break; case 3: if ((j+1)<n+1) swap(a[i][j],a[i][j+1]); break; } } } void Dialog::initpicture() { QString tempfile; //tempfile = QFileDialog::getOpenFileName(this, tr("Open")); tempfile = QFileDialog::getOpenFileName(this, tr("Open Image"), "./pictures", tr("Image Files (*.png *.jpg *.bmp)")); if (!pix.load(tempfile)) { ////()<<"?"; return; } n=ui->spinBox->value(); N=n*n; //()<<"ok4"; a = new int* [n+2]; for(int i=0; i <n+2; i++) a[i] = new int[n+2]; wsize = pix.width(); hsize = pix.height(); if (hsize>700) { pix=pix.scaled( wsize*700/hsize, 700, Qt::IgnoreAspectRatio, Qt::SmoothTransformation); wsize = pix.width(); hsize = pix.height(); } else if (hsize<400) { pix=pix.scaled( wsize*400/hsize, 400, Qt::IgnoreAspectRatio, Qt::SmoothTransformation); wsize = pix.width(); hsize = pix.height(); } wsubsize = wsize/n; hsubsize = hsize/n; pix = pix.copy(0,0, n*wsubsize, n*hsubsize); pixmaps.clear(); //()<<pixmaps.length(); for (int y = 0; y < n; y++) { for (int x = 0; x < n; x++) { QPixmap pieceImage = pix.copy(x*wsubsize, y*hsubsize, wsubsize, hsubsize); pixmaps.append(pieceImage); } } //pixmaps[pixmaps.size()-1]=QPixmap(subsize, subsize); //pixmaps[pixmaps.length()-1].fill(QColor(200, 200, 200)); randomp(); setbak(); setGeometry( (QApplication::desktop()->width() - (n*wsubsize+100))/2, (QApplication::desktop()->height() - n*hsubsize)/2, n*wsubsize+100,n*hsubsize); //ui->pushButton ->setGeometry(n*wsubsize+10,10,80,23); //ui->pushButton_2->setGeometry(n*wsubsize+10,50,80,23); ui->verticalWidget->setGeometry(n*wsubsize,10,100,150); update(); //move( (QApplication::desktop()->width() - width())/2, (QApplication::desktop()->height() - height())/2); //qDebug()<<QApplication::desktop()->width()<<width(); //pix.fill( &pixmaps[pixmaps.length()-1],0,0); } int Dialog::findN() { for (int i=1;i<=n;i++) for (int j=1;j<=n;j++) if (a[i][j]==N) return n*(j-1)+i; //return 0; } bool Dialog::check() { bool good=true; for (int i=1;i<=n;i++) for (int j=1;j<=n;j++) good=good&&(a[i][j]==n*(j-1)+i); return good; } void Dialog::on_pushButton_clicked() { initpicture(); //()<<"ok"; } void Dialog::on_pushButton_2_clicked() { //setGeometry(x(),y(),2*n*subsize+100, n*subsize); if (source_picture_show) { //setFixedWidth(n*wsubsize+100); ui->pushButton_2->setText(tr("show image")); source_picture_show=false; update(); } else { //setFixedWidth(2*n*wsubsize+100); ui->pushButton_2->setText(tr("Back game")); source_picture_show=true; update(); } } void Dialog::on_spinBox_editingFinished() { }

Python可以这样学(第一季:Python内功修炼)

董付国系列教材《Python程序设计基础》、《Python程序设计(第2版)》、《Python可以这样学》配套视频,讲解Python 3.5.x和3.6.x语法、内置对象用法、选择与循环以及函数设计与使用、lambda表达式用法、字符串与正则表达式应用、面向对象编程、文本文件与二进制文件操作、目录操作与系统运维、异常处理结构。

获取Linux下Ftp目录树并逐步绑定到treeview

在linux下抓取目录树,双击后获取该节点子节点(逐步生成)。另外有两个类,一个是windows下的(一次性获取目录树),一个是linux下的(足部获取目录树)

NS网络模拟和协议仿真源代码

NS网络模拟和协议仿真源代码,包含代码说明及协议分析

简单的NS3网络模拟仿真(计算机网络作业)

简单的NS3网络模拟仿真,内附有PPT演示。论文评述。以及简单的安装教程。

手把手实现Java图书管理系统(附源码)

【超实用课程内容】 本课程演示的是一套基于Java的SSM框架实现的图书管理系统,主要针对计算机相关专业的正在做毕设的学生与需要项目实战练习的java人群。详细介绍了图书管理系统的实现,包括:环境搭建、系统业务、技术实现、项目运行、功能演示、系统扩展等,以通俗易懂的方式,手把手的带你从零开始运行本套图书管理系统,该项目附带全部源码可作为毕设使用。 【课程如何观看?】 PC端:https://edu.csdn.net/course/detail/27513 移动端:CSDN 学院APP(注意不是CSDN APP哦) 本课程为录播课,课程2年有效观看时长,大家可以抓紧时间学习后一起讨论哦~ 【学员专享增值服务】 源码开放 课件、课程案例代码完全开放给你,你可以根据所学知识,自行修改、优化

三个项目玩转深度学习(附1G源码)

从事大数据与人工智能开发与实践约十年,钱老师亲自见证了大数据行业的发展与人工智能的从冷到热。事实证明,计算机技术的发展,算力突破,海量数据,机器人技术等,开启了第四次工业革命的序章。深度学习图像分类一直是人工智能的经典任务,是智慧零售、安防、无人驾驶等机器视觉应用领域的核心技术之一,掌握图像分类技术是机器视觉学习的重中之重。针对现有线上学习的特点与实际需求,我们开发了人工智能案例实战系列课程。打造:以项目案例实践为驱动的课程学习方式,覆盖了智能零售,智慧交通等常见领域,通过基础学习、项目案例实践、社群答疑,三维立体的方式,打造最好的学习效果。

150讲轻松搞定Python网络爬虫

【为什么学爬虫?】 &nbsp; &nbsp; &nbsp; &nbsp;1、爬虫入手容易,但是深入较难,如何写出高效率的爬虫,如何写出灵活性高可扩展的爬虫都是一项技术活。另外在爬虫过程中,经常容易遇到被反爬虫,比如字体反爬、IP识别、验证码等,如何层层攻克难点拿到想要的数据,这门课程,你都能学到! &nbsp; &nbsp; &nbsp; &nbsp;2、如果是作为一个其他行业的开发者,比如app开发,web开发,学习爬虫能让你加强对技术的认知,能够开发出更加安全的软件和网站 【课程设计】 一个完整的爬虫程序,无论大小,总体来说可以分成三个步骤,分别是: 网络请求:模拟浏览器的行为从网上抓取数据。 数据解析:将请求下来的数据进行过滤,提取我们想要的数据。 数据存储:将提取到的数据存储到硬盘或者内存中。比如用mysql数据库或者redis等。 那么本课程也是按照这几个步骤循序渐进的进行讲解,带领学生完整的掌握每个步骤的技术。另外,因为爬虫的多样性,在爬取的过程中可能会发生被反爬、效率低下等。因此我们又增加了两个章节用来提高爬虫程序的灵活性,分别是: 爬虫进阶:包括IP代理,多线程爬虫,图形验证码识别、JS加密解密、动态网页爬虫、字体反爬识别等。 Scrapy和分布式爬虫:Scrapy框架、Scrapy-redis组件、分布式爬虫等。 通过爬虫进阶的知识点我们能应付大量的反爬网站,而Scrapy框架作为一个专业的爬虫框架,使用他可以快速提高我们编写爬虫程序的效率和速度。另外如果一台机器不能满足你的需求,我们可以用分布式爬虫让多台机器帮助你快速爬取数据。 &nbsp; 从基础爬虫到商业化应用爬虫,本套课程满足您的所有需求! 【课程服务】 专属付费社群+每周三讨论会+1v1答疑

cuda开发cutilDLL

包括cutil32.dll、cutil32D.dll、cutil32.lib、cutil32D.lib,以及附带的glew32.lib/freeglut.lib

深度学习原理+项目实战+算法详解+主流框架(套餐)

深度学习系列课程从深度学习基础知识点开始讲解一步步进入神经网络的世界再到卷积和递归神经网络,详解各大经典网络架构。实战部分选择当下最火爆深度学习框架PyTorch与Tensorflow/Keras,全程实战演示框架核心使用与建模方法。项目实战部分选择计算机视觉与自然语言处理领域经典项目,从零开始详解算法原理,debug模式逐行代码解读。适合准备就业和转行的同学们加入学习! 建议按照下列课程顺序来进行学习 (1)掌握深度学习必备经典网络架构 (2)深度框架实战方法 (3)计算机视觉与自然语言处理项目实战。(按照课程排列顺序即可)

Tensorflow与python3.7适配版本

tensorflow与python3.7匹配的最新库,更新了python3.7以后可以自行下载,或者去国外python的扩展包下载界面自行下载。

4小时玩转微信小程序——基础入门与微信支付实战

这是一个门针对零基础学员学习微信小程序开发的视频教学课程。课程采用腾讯官方文档作为教程的唯一技术资料来源。杜绝网络上质量良莠不齐的资料给学员学习带来的障碍。 视频课程按照开发工具的下载、安装、使用、程序结构、视图层、逻辑层、微信小程序等几个部分组织课程,详细讲解整个小程序的开发过程

专为程序员设计的数学课

<p> 限时福利限时福利,<span>15000+程序员的选择!</span> </p> <p> 购课后添加学习助手(微信号:csdn590),按提示消息领取编程大礼包!并获取讲师答疑服务! </p> <p> <br> </p> <p> 套餐中一共包含5门程序员必学的数学课程(共47讲) </p> <p> 课程1:《零基础入门微积分》 </p> <p> 课程2:《数理统计与概率论》 </p> <p> 课程3:《代码学习线性代数》 </p> <p> 课程4:《数据处理的最优化》 </p> <p> 课程5:《马尔可夫随机过程》 </p> <p> <br> </p> <p> 哪些人适合学习这门课程? </p> <p> 1)大学生,平时只学习了数学理论,并未接触如何应用数学解决编程问题; </p> <p> 2)对算法、数据结构掌握程度薄弱的人,数学可以让你更好的理解算法、数据结构原理及应用; </p> <p> 3)看不懂大牛代码设计思想的人,因为所有的程序设计底层逻辑都是数学; </p> <p> 4)想学习新技术,如:人工智能、机器学习、深度学习等,这门课程是你的必修课程; </p> <p> 5)想修炼更好的编程内功,在遇到问题时可以灵活的应用数学思维解决问题。 </p> <p> <br> </p> <p> 在这门「专为程序员设计的数学课」系列课中,我们保证你能收获到这些:<br> <br> <span> </span> </p> <p class="ql-long-24357476"> <span class="ql-author-24357476">①价值300元编程课程大礼包</span> </p> <p class="ql-long-24357476"> <span class="ql-author-24357476">②应用数学优化代码的实操方法</span> </p> <p class="ql-long-24357476"> <span class="ql-author-24357476">③数学理论在编程实战中的应用</span> </p> <p class="ql-long-24357476"> <span class="ql-author-24357476">④程序员必学的5大数学知识</span> </p> <p class="ql-long-24357476"> <span class="ql-author-24357476">⑤人工智能领域必修数学课</span> </p> <p> <br> 备注:此课程只讲程序员所需要的数学,即使你数学基础薄弱,也能听懂,只需要初中的数学知识就足矣。<br> <br> 如何听课? </p> <p> 1、登录CSDN学院 APP 在我的课程中进行学习; </p> <p> 2、登录CSDN学院官网。 </p> <p> <br> </p> <p> 购课后如何领取免费赠送的编程大礼包和加入答疑群? </p> <p> 购课后,添加助教微信:<span> csdn590</span>,按提示领取编程大礼包,或观看付费视频的第一节内容扫码进群答疑交流! </p> <p> <img src="https://img-bss.csdn.net/201912251155398753.jpg" alt=""> </p>

实现简单的文件系统

实验内容: 通过对具体的文件存储空间的管理、文件的物理结构、目录结构和文件操作的实现,加深对文件系统内部功能和实现过程的理解。 要求: 1.在内存中开辟一个虚拟磁盘空间作为文件存储器,在其上实现一个简

机器学习初学者必会的案例精讲

通过六个实际的编码项目,带领同学入门人工智能。这些项目涉及机器学习(回归,分类,聚类),深度学习(神经网络),底层数学算法,Weka数据挖掘,利用Git开源项目实战等。

四分之一悬架模型simulink.7z

首先建立了四分之一车辆悬架系统的数学模型,应用MATLAB/Simulink软件建立该系统的仿真模型,并输入路面激励为随机激励,控制不同的悬架刚度和阻尼,选用最优的参数得到车辆悬架的振动加速度变化曲线

MFC一站式终极全套课程包

该套餐共包含从C小白到C++到MFC的全部课程,整套学下来绝对成为一名C++大牛!!!

C++语言基础视频教程

C++语言基础视频培训课程:本课与主讲者在大学开出的程序设计课程直接对接,准确把握知识点,注重教学视频与实践体系的结合,帮助初学者有效学习。本教程详细介绍C++语言中的封装、数据隐藏、继承、多态的实现等入门知识;主要包括类的声明、对象定义、构造函数和析构函数、运算符重载、继承和派生、多态性实现等。 课程需要有C语言程序设计的基础(可以利用本人开出的《C语言与程序设计》系列课学习)。学习者能够通过实践的方式,学会利用C++语言解决问题,具备进一步学习利用C++开发应用程序的基础。

Java8零基础入门视频教程

这门课程基于主流的java8平台,由浅入深的详细讲解了java SE的开发技术,可以使java方向的入门学员,快速扎实的掌握java开发技术!

HoloLens2开发入门教程

本课程为HoloLens2开发入门教程,讲解部署开发环境,安装VS2019,Unity版本,Windows SDK,创建Unity项目,讲解如何使用MRTK,编辑器模拟手势交互,打包VS工程并编译部署应用到HoloLens上等。

C/C++学习指南全套教程

C/C++学习的全套教程,从基本语法,基本原理,到界面开发、网络开发、Linux开发、安全算法,应用尽用。由毕业于清华大学的业内人士执课,为C/C++编程爱好者的教程。

pokemmo的资源

pokemmo必须的4个rom 分别为绿宝石 火红 心金 黑白 还有汉化补丁 资源不错哦 记得下载

test_head.py

本文件主要是针对使用dlib的imglab标注工具标记的目标检测框和关键点检测而生成的xml文件, 转换为coco数据集格式.

Java面试史上最全的JAVA专业术语面试100问 (前1-50)

前言: 说在前面, 面试题是根据一些朋友去面试提供的,再就是从网上整理了一些。 先更新50道,下一波吧后面的也更出来。 求赞求关注!! 废话也不多说,现在就来看看有哪些面试题 1、面向对象的特点有哪些? 抽象、继承、封装、多态。 2、接口和抽象类有什么联系和区别? 3、重载和重写有什么区别? 4、java有哪些基本数据类型? 5、数组有没有length()方法?String有没有length()方法? 数组没有length()方法,它有length属性。 String有length()方法。 集合求长度用

2019 AI开发者大会

2019 AI开发者大会(AI ProCon 2019)是由中国IT社区CSDN主办的AI技术与产业年度盛会。多年经验淬炼,如今蓄势待发:2019年9月6-7日,大会将有近百位中美顶尖AI专家、知名企业代表以及千余名AI开发者齐聚北京,进行技术解读和产业论证。我们不空谈口号,只谈技术,诚挚邀请AI业内人士一起共铸人工智能新篇章!

linux“开发工具三剑客”速成攻略

工欲善其事,必先利其器。Vim+Git+Makefile是Linux环境下嵌入式开发常用的工具。本专题主要面向初次接触Linux的新手,熟练掌握工作中常用的工具,在以后的学习和工作中提高效率。

DirectX修复工具V4.0增强版

DirectX修复工具(DirectX Repair)是一款系统级工具软件,简便易用。本程序为绿色版,无需安装,可直接运行。 本程序的主要功能是检测当前系统的DirectX状态,如果发现异常则进行修复

20行代码教你用python给证件照换底色

20行代码教你用python给证件照换底色

2019 Python开发者日-培训

本次活动将秉承“只讲技术,拒绝空谈”的理念,邀请十余位身处一线的Python技术专家,重点围绕Web开发、自动化运维、数据分析、人工智能等技术模块,分享真实生产环境中使用Python应对IT挑战的真知灼见。此外,针对不同层次的开发者,大会还安排了深度培训实操环节,为开发者们带来更多深度实战的机会。

我以为我对Mysql事务很熟,直到我遇到了阿里面试官

太惨了,面试又被吊打

机器学习实战系列套餐(必备基础+经典算法+案例实战)

机器学习实战系列套餐以实战为出发点,帮助同学们快速掌握机器学习领域必备经典算法原理并结合Python工具包进行实战应用。建议学习顺序:1.Python必备工具包:掌握实战工具 2.机器学习算法与实战应用:数学原理与应用方法都是必备技能 3.数据挖掘实战:通过真实数据集进行项目实战。按照下列课程顺序学习即可! 课程风格通俗易懂,用最接地气的方式带领大家轻松进军机器学习!提供所有课程代码,PPT与实战数据,有任何问题欢迎随时与我讨论。

Kotlin Programming Cookbook_Code 源码

Kotlin Programming Cookbook_Code 源码 本资源转载自网络,如有侵权,请联系上传者或csdn删除 查看此书详细信息请在美国亚马逊官网搜索此书

网络工程师小白入门--【思科CCNA、华为HCNA等网络工程师认证】

本课程适合CCNA或HCNA网络小白同志,高手请绕道,可以直接学习进价课程。通过本预科课程的学习,为学习网络工程师、思科CCNA、华为HCNA这些认证打下坚实的基础! 重要!思科认证2020年2月24日起,已启用新版认证和考试,包括题库都会更新,由于疫情原因,请关注官网和本地考点信息。题库网络上很容易下载到。

跳槽入职字节跳动,给到20K16薪,只因比别人更懂多线程与高并发

前言 当你开始开始去跳槽面试的时候,明明只是一份15K的工作,却问你会不会多线程,懂不懂高并发,火箭造得让你猝及不防,结果就是凉凉;现如今市场,多线程、高并发编程、分布式、负载均衡、集群等可以说是现在高级后端开发求职的必备技能。 早期的鸟儿有虫吃,现如今做开发的门槛越来越高 但是,术业有专攻,总有一些技术牛逼的程序员可以吊打、碾压面试官! 本人经常隔段时间就偷偷投点简历,请假出去面试几次,目的不是想跳槽,主要是为了看看市场上的技术流行趋势,顺便检验一下自己的水平,当然,如果面到了心仪的公司或者大

linux下利用/proc进行进程树的打印

在linux下利用c语言实现的进程树的打印,主要通过/proc下的目录中的进程文件,获取status中的进程信息内容,然后利用递归实现进程树的打印

Python数据分析与挖掘

92讲视频课+16大项目实战+源码+¥800元课程礼包+讲师社群1V1答疑+社群闭门分享会=99元 &nbsp; 为什么学习数据分析? &nbsp; &nbsp; &nbsp; 人工智能、大数据时代有什么技能是可以运用在各种行业的?数据分析就是。 &nbsp; &nbsp; &nbsp; 从海量数据中获得别人看不见的信息,创业者可以通过数据分析来优化产品,营销人员可以通过数据分析改进营销策略,产品经理可以通过数据分析洞察用户习惯,金融从业者可以通过数据分析规避投资风险,程序员可以通过数据分析进一步挖掘出数据价值,它和编程一样,本质上也是一个工具,通过数据来对现实事物进行分析和识别的能力。不管你从事什么行业,掌握了数据分析能力,往往在其岗位上更有竞争力。 &nbsp;&nbsp; 本课程共包含五大模块: 一、先导篇: 通过分析数据分析师的一天,让学员了解全面了解成为一个数据分析师的所有必修功法,对数据分析师不在迷惑。 &nbsp; 二、基础篇: 围绕Python基础语法介绍、数据预处理、数据可视化以及数据分析与挖掘......这些核心技能模块展开,帮助你快速而全面的掌握和了解成为一个数据分析师的所有必修功法。 &nbsp; 三、数据采集篇: 通过网络爬虫实战解决数据分析的必经之路:数据从何来的问题,讲解常见的爬虫套路并利用三大实战帮助学员扎实数据采集能力,避免没有数据可分析的尴尬。 &nbsp; 四、分析工具篇: 讲解数据分析避不开的科学计算库Numpy、数据分析工具Pandas及常见可视化工具Matplotlib。 &nbsp; 五、算法篇: 算法是数据分析的精华,课程精选10大算法,包括分类、聚类、预测3大类型,每个算法都从原理和案例两个角度学习,让你不仅能用起来,了解原理,还能知道为什么这么做。

程序员的兼职技能课

获取讲师答疑方式: 在付费视频第一节(触摸命令_ALL)片头有二维码及加群流程介绍 限时福利 原价99元,今日仅需39元!购课添加小助手(微信号:csdn590)按提示还可领取价值800元的编程大礼包! 讲师介绍: 苏奕嘉&nbsp;前阿里UC项目工程师 脚本开发平台官方认证满级(六级)开发者。 我将如何教会你通过【定制脚本】赚到你人生的第一桶金? 零基础程序定制脚本开发课程,是完全针对零脚本开发经验的小白而设计,课程内容共分为3大阶段: ①前期将带你掌握Q开发语言和界面交互开发能力; ②中期通过实战来制作有具体需求的定制脚本; ③后期将解锁脚本的更高阶玩法,打通任督二脉; ④应用定制脚本合法赚取额外收入的完整经验分享,带你通过程序定制脚本开发这项副业,赚取到你的第一桶金!

董付国老师Python全栈学习优惠套餐

购买套餐的朋友可以关注微信公众号“Python小屋”,上传付款截图,然后领取董老师任意图书1本。

程序员的算法通关课:知己知彼(第一季)

【超实用课程内容】 程序员对于算法一直又爱又恨!特别是在求职面试时,算法类问题绝对是不可逃避的提问点!本门课程作为算法面试系列的第一季,会从“知己知彼”的角度,聊聊关于算法面试的那些事~ 【哪些人适合学习这门课程?】 求职中的开发者,对于面试算法阶段缺少经验 想了解实际工作中算法相关知识 在职程序员,算法基础薄弱,急需充电 【超人气讲师】 孙秀洋&nbsp;| 服务器端工程师 硕士毕业于哈工大计算机科学与技术专业,ACM亚洲区赛铜奖获得者,先后在腾讯和百度从事一线技术研发,对算法和后端技术有深刻见解。 【课程如何观看?】 PC端:https://edu.csdn.net/course/detail/27272 移动端:CSDN 学院APP(注意不是CSDN APP哦) 本课程为录播课,课程无限观看时长,但是大家可以抓紧时间学习后一起讨论哦~

相关热词 c#对文件改写权限 c#中tostring c#支付宝回掉 c#转换成数字 c#判断除法是否有模 c# 横向chart c#控件选择多个 c#报表如何锁定表头 c#分级显示数据 c# 不区分大小写替换
立即提问
相关内容推荐