table_widget->setHorizontalHeaderLabels(header);
//设置表头字体加粗
QFont font = this->horizontalHeader()->font(); font.setBold(true); table_widget->horizontalHeader()->setFont(font);
table_widget->horizontalHeader()->setStretchLastSection(true); //设置充满表宽度 table_widget->verticalHeader()->setResizeMode(QHeaderView::ResizeToContents); table_widget->verticalHeader()->setDefaultSectionSize(10); //设置行高 table_widget->setFrameShape(QFrame::NoFrame); //设置无边框 table_widget->setShowGrid(false); //设置不显示格子线 table_widget->verticalHeader()->setVisible(false); //设置垂直头不可见 table_widget->setSelectionMode(QAbstractItemView::ExtendedSelection); //可多选(Ctrl、Shift、 Ctrl+A都可以) table_widget->setSelectionBehavior(QAbstractItemView::SelectRows); //设置选择行为时每次选择一行 table_widget->setEditTriggers(QAbstractItemView::NoEditTriggers); //设置不可编辑 table_widget->horizontalHeader()->resizeSection(0,150); //设置表头第一列的宽度为150 table_widget->horizontalHeader()->setFixedHeight(25); //设置表头的高度
table_widget->setStyleSheet("selection-background-color:lightblue;"); //设置选中背景色
table_widget->horizontalHeader()->setStyleSheet("QHeaderView::section{background:skyblue;}"); //设置表头背景色
//设置水平、垂直滚动条样式
table_widget->horizontalScrollBar()->setStyleSheet("QScrollBar{background:transparent; height:10px;}" "QScrollBar::handle{background:lightgray; border:2px solid transparent; border-radius:5px;}" "QScrollBar::handle:hover{background:gray;}" "QScrollBar::sub-line{background:transparent;}" "QScrollBar::add-line{background:transparent;}");
table_widget->verticalScrollBar()->setStyleSheet("QScrollBar{background:transparent; width: 10px;}" "QScrollBar::handle{background:lightgray; border:2px solid transparent; border-radius:5px;}" "QScrollBar::handle:hover{background:gray;}" "QScrollBar::sub-line{background:transparent;}" "QScrollBar::add-line{background:transparent;}");
查看了别人的博客。接下来自己就要动手了。先看看效果在依次解析一下,里面遇到一些过程中的问题(干货 ):
一个是用QTableWidget做的,一个是QListWidget做的。先说说QTableWidget
1.首先去掉表格头,和网格
ui->tableWidget->horizontalHeader()->setHidden(true);
ui->tableWidget->setShowGrid(false); //设置不显示格子线
2.表格中第二列加入一个Qlabel。
QLabel *label = new QLabel();
label->setAlignment(Qt::AlignHCenter | Qt::AlignVCenter);
label->setText(QString::number(5-i));
label->setStyleSheet("color:rgb(255, 255, 255);"
"border-radius:4px;"
"background-color:rgb(85, 0, 255);"
"font: 9pt;");
ui->tableWidget->setIndexWidget(index,label);
但是光这样是不行的,tablewidget的单元格默认把label控件撑满
为了解决这个问题,我当时也是查了不少博客,但大多数结果都不是很满意。于是看到有人说用布局的思路。大概思路就是,用一个qwidget来装一个布局,在布局里调整一下控件的margin来达到内部的位置调整,再把qwidget装入单元格,即使他自动撑满也没关系。设置好控件的最大尺寸。label->setMaximumSize(14,14);大功告成。
QWidget *widget = new QWidget;
QHBoxLayout *hLayout;
hLayout = new QHBoxLayout();
hLayout->addWidget(label);
hLayout->setMargin(0);
hLayout->setAlignment(widget, Qt::AlignCenter);
hLayout->setContentsMargins(1, 3, 1, 3);
widget->setLayout(hLayout);
ui->tableWidget->setIndexWidget(index,widget);
2.去掉表格中的虚线,和表格中行的背景色随鼠标移动。
参考了下:大概是在表格中重写一个委托类
QStyledItemDelegate类中一个paint函数。就可以。
StyledDelegate *dele = new StyledDelegate();
ui->tableWidget->setItemDelegate(dele);
class StyledDelegate : public QStyledItemDelegate
{
Q_OBJECT
public:
explicit StyledDelegate(QObject *parent = Q_NULLPTR);
~StyledDelegate();
void StyledDelegate::paint(QPainter* painter, const QStyleOptionViewItem & option, const QModelIndex &index) const
{
QStyleOptionViewItem itemOption(option);
if (itemOption.state & QStyle::State_HasFocus)
{
itemOption.state = itemOption.state ^ QStyle::State_HasFocus;
}
//添加鼠标滑过的背景色
if(option.state & QStyle::State_MouseOver){
painter->fillRect(itemOption.rect, QColor(180, 200, 220));
}
QStyledItemDelegate::paint(painter, itemOption, index);
}
};
但这样也仅仅只能单个单元格。后面想了一下,tablewidget类设计的操作的单元应该是单元格,应该不会封装行或者列之类的。如果真要达到,背景行跟随的话,思路就是取到行数,然后for()循环一个个单元刷掉。思路可以参考一下:https://blog.csdn.net/m0_37907070/article/details/78642599
我这里就不再多写。因为后面想了一下qlistwidget实现这个功能非常简单
先上一下tablewidget的完整源码:
ui->tableWidget->horizontalHeader()->setHidden(true);
ui->tableWidget->verticalHeader()->setHidden(true);
ui->tableWidget->setColumnCount(4);
ui->tableWidget->setRowCount(10);
ui->tableWidget->setEditTriggers(QAbstractItemView::NoEditTriggers);
ui->tableWidget->setHorizontalScrollBarPolicy(Qt::ScrollBarAlwaysOff);
ui->tableWidget->setVerticalScrollBarPolicy(Qt::ScrollBarAlwaysOff);
ui->tableWidget->horizontalHeader()->setSectionResizeMode(QHeaderView::Fixed);
//ui->tableWidget->setFrameShape(QFrame::NoFrame); //设置无边框
ui->tableWidget->setShowGrid(false); //设置不显示格子线
//ui->tableWidget->setSelectionBehavior(QAbstractItemView::SelectRows);
//ui->tableWidget->setStyleSheet("selection-background-color:rgb(255,209,128,0)");
ui->tableWidget->setStyleSheet("QTableWidget::item:selected{background-color:rgb(0,0,0,0);color:rgb(0,0,0)}");
ui->tableWidget->setColumnWidth(0,20);
ui->tableWidget->setColumnWidth(1,20);
ui->tableWidget->setColumnWidth(2,80);
ui->tableWidget->setColumnWidth(3,80);
ui->tableWidget->setMouseTracking(true);
StyledDelegate *dele = new StyledDelegate();
ui->tableWidget->setItemDelegate(dele);
QAbstractItemModel *model = ui->tableWidget->model();
for(int i = 0; i<10; i++)
{
ui->tableWidget->setRowHeight(i,22);
QModelIndex index = model->index(i,1);
QLabel *label = new QLabel();
label->setMaximumSize(14,14);
label->setAlignment(Qt::AlignHCenter | Qt::AlignVCenter);
if(i<5)
{
ui->tableWidget->setItem(i,0,new QTableWidgetItem(QString("S")));
label->setText(QString::number(5-i));
label->setStyleSheet("color:rgb(255, 255, 255);"
"border-radius:4px;"
"background-color:rgb(85, 0, 255);"
"font: 9pt;"
"");
}
else
{
ui->tableWidget->setItem(i,0,new QTableWidgetItem(QString("B")));
label->setText(QString::number(i-4));
label->setStyleSheet("color:rgb(255, 255, 255);"
"border-radius:4px;"
"background-color:rgb(204, 0, 0);"
"font: 9pt;");
}
QWidget *widget = new QWidget;
QHBoxLayout *hLayout;
hLayout = new QHBoxLayout();
hLayout->addWidget(label);
hLayout->setMargin(0);
hLayout->setAlignment(widget, Qt::AlignCenter);
hLayout->setContentsMargins(1, 3, 1, 3);
widget->setLayout(hLayout);
ui->tableWidget->setIndexWidget(index,widget);
QTableWidgetItem * item3 = new QTableWidgetItem(QString("0.001"));
QTableWidgetItem * item4 = new QTableWidgetItem(QString("1000"));
item3->setTextAlignment(Qt::AlignRight| Qt::AlignHCenter);
item4->setTextAlignment(Qt::AlignRight| Qt::AlignHCenter);
ui->tableWidget->setItem(i,2,item3);
ui->tableWidget->setItem(i,3,item4);
}
然后是qlistwidget的
for(int i = 0; i<10; i++)
{
QListWidgetItem *item=new QListWidgetItem;
item->setSizeHint(QSize(0,22));
ui->listWidget->addItem(item);
QLabel *label1 = new QLabel();
QLabel *label2 = new QLabel();
QLabel *label3 = new QLabel("0.001");
QLabel *label4 = new QLabel("100000");
label1->setMaximumSize(16,16);
label2->setMaximumSize(14,14);
label1->setAlignment(Qt::AlignHCenter | Qt::AlignVCenter);
label2->setAlignment(Qt::AlignHCenter | Qt::AlignVCenter);
label3->setAlignment(Qt::AlignHCenter | Qt::AlignRight);
label4->setAlignment(Qt::AlignHCenter | Qt::AlignRight);
if(i<5)
{
label1->setText("S");
label2->setText(QString::number(5-i));
label2->setStyleSheet("color:rgb(255, 255, 255);"
"border-radius:4px;"
"background-color:rgb(85, 0, 255);"
"font: 9pt;");
}
else
{
label1->setText("B");
label2->setText(QString::number(i-4));
label2->setStyleSheet("color:rgb(255, 255, 255);"
"border-radius:4px;"
"background-color:rgb(204, 0, 0);"
"font: 9pt;");
}
QWidget *widget = new QWidget;
QHBoxLayout *hLayout;
hLayout = new QHBoxLayout();
hLayout->addWidget(label1);
hLayout->addWidget(label2);
hLayout->addWidget(label3);
hLayout->addWidget(label4);
hLayout->setMargin(0);
hLayout->setAlignment(widget, Qt::AlignCenter);
hLayout->setContentsMargins(1, 3, 1, 3);
widget->setLayout(hLayout);
ui->listWidget->setItemWidget(item,widget);
}
//样式
QListWidget::item:selected:active { background:rgb(0, 0, 223,0);}
QListWidget::item:selected:!active { background:rgb(0, 0, 223,0);}
是不是感觉Qlistwidget的很简单?
参考一下博客:
https://blog.csdn.net/m0_37907070/article/details/78642599
http://blog.sina.com.cn/s/blog_a6fb6cc90101i8it.html
https://www.cnblogs.com/zhoug2020/p/3789076.html
你可能感兴趣的:(QT控件)
基于QT与STM32的电力参数采集系统(华为云IOT)(211)
DS小龙哥
智能家居与物联网项目实战 qt stm32 华为云 电力采集
文章目录一、前言1.1项目介绍【1】开发背景【2】项目实现的功能【3】项目硬件模块组成1.2设计思路【1】整体设计思路【2】整体构架【3】上位机开发思路【4】供电方式1.3项目开发背景【1】选题的意义【2】可行性分析【3】参考文献【4】摘要1.4开发工具的选择【1】设备端开发【2】上位机开发1.5系统框架图1.6系统功能总结1.7设备原理图1.8硬件实物图二、硬件选型2.1STM32开发板2.2U
基于单片机的家居环境监测系统的设计
lantiandianzi
单片机 嵌入式硬件
本设计基于单片机的家居环境监测系统,采用STM32F103C6T6单片机作为主要的控制芯片,环境监测方面采用SHT30模块实现室内温度和湿度的监测;有害气体监测方面,用MQ-7传感器实现室内一氧化碳气体的监测;采用WIFI模块连接指定热点,通信方案采用MQTT协议,将采集到的数据发送到阿里云物联网平台;采用OLED显示模块对采集到的数据进行显示。
Flutter控件之 Text
眼中有码
用于显示文字Text("Text组件的使用",style:TextStyle(//文字颜色color:Color(0xfff0000),//none不显示装饰线条,underline字体下方,overline字体上方,lineThrough穿过文字decoration:TextDecoration.none,//solid直线,double双下划线,dotted虚线,dashed点下划线,wavy
MQTT: Keep Alive
VFSSoft
# MQTT 网络协议 网络 iot
KeepAlive时间单位是秒。字段长度为2个字节的short。这个值规定了客户端从发送上一个控制包之后,到发送下一个控制包之间最大的时间间隔。客户端需要确保发送控制包的时间间隔不超过这个值。如果在此时间间隔内,没有其他的控制包需要发送给服务器端,客户端可以发送PINGREQ包。客户端可以在任何时刻发送PINGREQ(不受KeepAlive值的限制)。通过发送PINGREQ可以检测服务器端是否正常
vtk qt widget
爱学习的大牛123
vtk 学习 qt vtk QWidget
首先,让我们创建`VTKWidget.h`文件:```#ifndefVTKWIDGET_H#defineVTKWIDGET_H#include#include#include#include#include#includeclassVTKWidget:publicQWidget{Q_OBJECTpublic:explicitVTKWidget(QWidget*parent=nullptr);pri
阿里云 物联网平台 MQTT连接、数据传输
忒可君
阿里云 物联网 云计算
阿里云物联网平台MQTT连接、数据传输1、设备连接阿里云2、多设备之前的通信、数据流转3、设备数据来源的读取。基于C#winform开发上位机,读取设备、仪器、MES或者电子元器件的数据,MQTT传输至阿里云平台,可视化界面构建界面,显示。MQTT的配置、连接、订阅和发布很简单,不论是老版本还是新版本,都可以。数据格式:
浅谈MQTT
CN.LG
Python php 开发语言
一、基本介绍MQTT(MessageQueuingTelemetryTransport)是一种轻量级的消息传输协议,它被设计用于低带宽、不可靠的网络环境中的远程通信。MQTT协议在物联网(IoT)领域非常流行,因为它能够支持大量的设备连接,并且具有低功耗和低带宽消耗的特点。二、关键特点轻量级:MQTT协议的消息头部很小,这使得它非常适合带宽有限的环境。发布/订阅模式:MQTT使用发布/订阅消息模式
嵌入式笔试题(2)
月夕花晨374
系统架构 c++ 数据结构 算法
1.请简述一下MQTT协议MQTT协议是一种轻量级的、基于发布-订阅模式的通信协议,用于在物联网(IoT)和M2M(机器到机器)通信中进行消息传递。其全称为MessageQueuingTelemetryTransport,即消息队列遥测传输。MQTT协议的特点包括:1.轻量级:MQTT协议采用二进制消息格式,使用较小的协议头和消息体,以减少网络带宽和存储消耗。2.发布-订阅模式:MQTT采用发布-
vue 高德地图api爬坑之路(三)Autocomplete 和 PlaceSearch
小C_cao
vue 高德地图API
添加页面控件搜索初始化插件编辑方法/**初始化搜索工具*/mapSearchInit(){letthat=this;//绑定自动提示AMap.plugin(['AMap.Autocomplete','AMap.PlaceSearch'],function(){varautoOptions={input:"tipInput",//值为界面上input空间idcity:'北京',}varautoCom
iOS 如何设置tableViewHeader控件的高度 附代码
hello_Jesse
ios swift xcode
如何设置tableViewHeader控件的高度第一种情况,如果是在控制器中添加的tableView,并且要设置tableViewHeader高度,要重写viewDidLayoutSubviews,看下面代码overridefuncviewDidLayoutSubviews(){super.viewDidLayoutSubviews()headView.frame=CGRect.init(
json qt 解析数组_Qt--解析Json
信息门下跑狗
json qt 解析数组
一、QT5Json简介QT4中使用第三方库QJson解析JSON文件。QT5新增加了处理JSON的类,类均以QJson开头,包含在QtCore模块中。QT5新增加六个相关类:QJsonArray封装JSON数组QJsonDocument读写JSON文档QJsonObject封装JSON对象QJsonObject::iterator用于遍历QJsonObject的STL风格的非const遍历器QJs
QT如何在控件上绘图(例如QLabel,Button,QWidget等)
重生之我在四川卖苕皮
QT qt ui 开发语言
方法一:使用事件过滤机制事件过滤器:由两个函数组成的一种操作,用来完成一个部件对其他部件的事件监视,这两个函数分别是installEventFilter();eventFilter(QObject*obj,QEvent*ev)皆为QObject类中的函数。如何使用:一,ui->paint_widget(子控件名)->installEventFilter(this);//安装事件过滤器二,在.h中加
Qt解析json格式数据
一定会升职加薪
燃犀的QT笔记 qt json 开发语言
文章目录json格式对象格式数组格式QJsonDocument,QJsonObject,QJsonArray,QJsonValue例一:如何构建QJsonObject和QJsonDocument例二:解析前面的嵌套型json数据json格式对象格式一个对象,由一个大括号表示:括号中描述对象的属性:通过键值对来描述对象的属性(可以理解为,大括号中,包含的是一个个的键值对.){"name":"小明",
QT教程-十六,QT中如何解析JSON
重生之我在四川卖苕皮
Qt开发基础教程 json 数据库
一,对json的初步认识(这里我们主要说明最常用的,以一个宏观的概念来说一下),json是一种数据格式,作用就是便于传递信息,我们可以按其结构和对应关系,拿到我们想要的数据。其主要结构为:json对象(大括号包裹{}),以及json数组(中括号包裹[])。例子:json对象{"name":"张三","age":"20","city":"西安"}json数组["Name","张三","age","2
qt自定义下拉菜单框
二氧化矽
qt
Qt自带的QCombBox下拉能够显示的东西有限,想添加其他的控件不太方便,所以就想自己定义一个,基本思路是,一个QLineEdit,一个QPushButton,一个QListWidget组成一个组合控件。过程:1、将QPushButton嵌入进QLineEdit中。_button->setText("...");_lineEdit->setReadOnly(true);_lineEdit->se
WPF样式(Style)与模板(template)区别
@Crazy Snail
wpf windows
WPF(WindowsPresentationFoundation)中的样式和模板都是用于控件外观的重要机制,但它们的目的和使用方式略有不同。1.样式样式是一种可以重复使用的视觉元素,用于定义控件的外观和行为。一旦定义一个样式,可以在应用程序中的多个控件中重复使用它。样式可以包含多种视觉元素,如布局属性、事件触发程序、转换器和动画等。要使用样式,可以在XAML文件中定义"Style"元素,并在控件
QTableView修改其关联的数据模型中的数据
科学的发展-只不过是读大自然写的代码
# qt 表格 数据库
QTableView修改其关联的数据模型中的数据,可以通过以下步骤进行:确定数据模型:首先,需要明确QTableView当前关联的数据模型。这个模型通常是QAbstractTableModel或其子类的实例。这个模型负责存储和管理表格数据。修改模型中的数据:要修改数据模型中的数据,可以直接访问模型的内部数据结构并进行修改。这通常涉及到改变存储在模型中的数组、列表或其他数据结构的内容。如果模型提供了
QT-信号与槽用法实例与注意事项及五个连接方式详解
luckyone906
QT-笔记 Qt事件机制 QT qt 开发语言
1.基本用法2.slots的函数用法3.slots的lambda表达式4.断开连接到对象信号的所有Object5.断开连接到特定信号的所有Object6.断开特定接收者7.connect函数的第5参数Qt::ConnectionType8.QObject::connect:Cannotqueueargumentsoftype'XXX'9.QTimer的singleShot环境:QT版本:5.6.2
Qt/QML学习-Drawer
放假当宅宅
Qt/QML学习 qt 学习
QML学习Drawer例程视频讲解代码main.qmlimportQtQuick2.15importQtQuick.Window2.15importQtQuick.Controls2.15Window{width:640height:480visible:truetitle:qsTr("Drawer")Drawer{id:drawerwidth:parent.width/4height:paren
这项来自中国的AI研究介绍了1位全量化训练(FQT):增强了全量化训练(FQT)的能力至1位
量子位AI
人工智能 机器学习 深度学习
全量化训练(FQT)可以通过将激活、权重和梯度转换为低精度格式来加速深度神经网络的训练。量化过程使得计算速度更快,且内存利用率更低,从而使训练过程更加高效。FQT在尽量减少数值精度的同时,保持了训练的有效性。研究人员一直在研究1位FQT的可行性,试图探索这些限制。该研究首先从理论上分析了FQT,重点关注了如Adam和随机梯度下降(SGD)等知名的优化算法。分析中出现了一个关键发现,那就是FQT收敛
帆软常用 js语句整理
fanjianlei1
帆软 oracle 数据库 sql java javascript
帆软决策报表和普通报表JS整理文章目录帆软决策报表和普通报表JS整理决策报表frm1.获取控件值,赋值2.JS中调用sql语句3.点击控件,展示到对应tab块4.设置当前控件可用,可见5.跳转界面6.执行网页框中的提交入库操作普通报表cpt1.单元格按钮带参查询2.关闭子页面,并重新刷新父页面3.填报页面鼠标移出4.单元格按钮向下扩展,获取同行参数5.帆软公式的或者和并且6.获取给单元格,并给单元
记录|如何全局监听鼠标和键盘等事件
小白鼠零号
winform C# Visual Studio visual studio winform c#
目录前言一、MyMessager类二、Form中进行Timer监听更新时间前言参考文章:C#winfrom长时间检查不到操作,自动关闭应用程序本来是想,如果一段时间没有操作软件,这个软件就自动退出的任务。但是在C#中,采用winform后,有很大的困难。表现为:监听困难,理论上是只要进行Form监听就可以了,但是实际上Form上面有许多的Panel和Button等控件在上面进行监听,所以如果要写鼠
Ubuntu上qt使用SSH样式表
杨~friendship
ubuntu linux 运维 ssh qt 学习 c++
SSH样式表如果学习过web的同学都知道,我们在学习HTML的时候会用到样式表,我们使用它来更改我们的颜色、大小、背景等等。上到后面,老师会说:我们如果在HTML文件中编辑太多的样式,就会让代码看起来非常的繁琐,所以我们开始学习了CSS样式,那么在QT中我们也同样会使用。那我们就开始学习吧!‘1.编辑样式#include"widget.h"#include"ui_widget.h"#include
Ubuntu中qt类与类信号槽的创建及使用
杨~friendship
ubuntu qt linux 学习 c++
今天学习到了新的一个小玩意,我们在QT中创建一个大项目的时候一般会创建多个类,那我们就来学习一下如何在自定义的类中声名和使用信号与槽函数。首先我们CTRL+n来创建我们新的类:我们创建新的C++的类,一个School,一个Students。我使用的是Cmake!!!!不是qmake!!!!!!!!创建好之后呢,我们要先声名一下我们的两个类,看代码:(在mainwindow.h)#ifndefMAI
Qt自定义滑动条
sensetime阿清
Qt qt c++
最近要用到滑动条,Qt自带的QSlider虽然能满足需求,但是操作起来有很多不舒服的地方,于是在它的基础上改了改,分享给大家使用。先放效果图:在QSlider的基础上,改变了样式,绘制了刻度,增加了取整功能,只需要微调就能适应各种需求。头文件。需要包含下面的东西#include#include#include#include#include声明。需要继承QSlider,并重写两个鼠标事件mouse
qt实现三原色滑动条变色
杨~friendship
qt 开发语言 学习 c++ ubuntu linux
在qt中有这样一个控件:就是这个HorizontalSlider他的作用相信大家都知道了,也就是通过滑动来改变数值。今天我们就使用这个控件实现一个三原色滑动变色。实现效果:1.创建UI界面这个就不用多说了,这个大家就按照我的这个去创建就好了。2.编写代码首先我们要初始话我们的属性://初始化红色滑动条ui->hsred->setMaximum(255);ui->hsred->setMinimum(
QT-快捷键-记事本文字放大缩小
打地基的小白
QT 学习路程 qt 开发语言
一、QShortcut类QShortcut简介QShortcut类允许你为你的应用程序定义快捷键。当快捷键被按下时,QShortcut可以触发一个槽函数,或者它可以直接激活一个QWidget。创建QShortcut对象QShortcut可以通过多种构造函数创建,其中最常见的形式是:QShortcut(QKeySequencekey,QWidget*parent,constchar*member=0
自定义view实战(5):手撕安卓侧滑栏
捡一晌贪欢
安卓 # 自定义View实战 android 自定义View LayoutParams layout动画
前言上一篇文章学了下自定义View的onDraw函数及自定义属性,做出来的滚动选择控件还算不错,就是逻辑复杂了一些。这篇文章打算利用自定义view的知识,直接手撕一个安卓侧滑栏,涉及到自定义LayoutParams、带padding和margin的measure和layout、利用requestLayout实现动画效果等,有一定难度,但能重新学到很多知识!需求这里类似旧版QQ(我特别喜欢之前的侧滑
Kevin‘s notes about Qt---Episode 4 多次点击按钮反复执行机械臂动作
Kevin__47
linux 网络 c++ qt
原先版本SDK1.2.1-2020-04-02HMI界面4.0.6.135135控制器1.7.5升级程序0.6.4伺服版本不详(似乎也并不重要)前言在之前的工作中,这个问题并没有得到有效解决,情况如下:在之前版本的程序中,每次动作执行完后需要关闭Qt界面,下一次想要运行机械臂程序时,就算没有改动程序,也需要再次点击编译运行,可以正常运行。直接在Qt界面再次点击一开始放置的“StartMove”按钮
界面控件开发包DevExpress v24.1.4全新发布
界面开发小八哥
devexpress ui 界面控件 UI开发 .net
DevExpressUniversal拥有.NET开发需要的所有平台控件,包含600多个UI控件、报表平台、DevExpressDashboardeXpressApp框架、适用于VisualStudio的CodeRush等一系列辅助工具。屡获大奖的软件开发平台DevExpress近期重要版本v24.1已正式发布,该版本拥有众多新产品和数十个具有高影响力的功能,可为桌面、Web和移动应用提供直观的解
Java序列化进阶篇
g21121
java序列化
1.transient
类一旦实现了Serializable 接口即被声明为可序列化,然而某些情况下并不是所有的属性都需要序列化,想要人为的去阻止这些属性被序列化,就需要用到transient 关键字。
escape()、encodeURI()、encodeURIComponent()区别详解
aigo
JavaScript Web
原文:http://blog.sina.com.cn/s/blog_4586764e0101khi0.html
JavaScript中有三个可以对字符串编码的函数,分别是: escape,encodeURI,encodeURIComponent,相应3个解码函数:,decodeURI,decodeURIComponent 。
下面简单介绍一下它们的区别
1 escape()函
ArcgisEngine实现对地图的放大、缩小和平移
Cb123456
添加矢量数据 对地图的放大、缩小和平移 Engine
ArcgisEngine实现对地图的放大、缩小和平移:
个人觉得是平移,不过网上的都是漫游,通俗的说就是把一个地图对象从一边拉到另一边而已。就看人说话吧.
具体实现:
一、引入命名空间
using ESRI.ArcGIS.Geometry;
using ESRI.ArcGIS.Controls;
二、代码实现.
Java集合框架概述
天子之骄
Java集合框架概述
集合框架
集合框架可以理解为一个容器,该容器主要指映射(map)、集合(set)、数组(array)和列表(list)等抽象数据结构。
从本质上来说,Java集合框架的主要组成是用来操作对象的接口。不同接口描述不同的数据类型。
简单介绍:
Collection接口是最基本的接口,它定义了List和Set,List又定义了LinkLi
旗正4.0页面跳转传值问题
何必如此
java jsp
跳转和成功提示
a) 成功字段非空forward
成功字段非空forward,不会弹出成功字段,为jsp转发,页面能超链接传值,传输变量时需要拼接。接拼接方式list.jsp?test="+strweightUnit+"或list.jsp?test="+weightUnit+&qu
全网唯一:移动互联网服务器端开发课程
cocos2d-x小菜
web开发 移动开发 移动端开发 移动互联 程序员
移动互联网时代来了! App市场爆发式增长为Web开发程序员带来新一轮机遇,近两年新增创业者,几乎全部选择了移动互联网项目!传统互联网企业中超过98%的门户网站已经或者正在从单一的网站入口转向PC、手机、Pad、智能电视等多端全平台兼容体系。据统计,AppStore中超过85%的App项目都选择了PHP作为后端程
Log4J通用配置|注意问题 笔记
7454103
DAO apache tomcat log4j Web
关于日志的等级 那些去 百度就知道了!
这几天 要搭个新框架 配置了 日志 记下来 !做个备忘!
#这里定义能显示到的最低级别,若定义到INFO级别,则看不到DEBUG级别的信息了~!
log4j.rootLogger=INFO,allLog
# DAO层 log记录到dao.log 控制台 和 总日志文件
log4j.logger.DAO=INFO,dao,C
SQLServer TCP/IP 连接失败问题 ---SQL Server Configuration Manager
darkranger
sql c windows SQL Server XP
当你安装完之后,连接数据库的时候可能会发现你的TCP/IP 没有启动..
发现需要启动客户端协议 : TCP/IP
需要打开 SQL Server Configuration Manager...
却发现无法打开 SQL Server Configuration Manager..??
解决方法: C:\WINDOWS\system32目录搜索framedyn.
[置顶] 做有中国特色的程序员
aijuans
程序员
从出版业说起 网络作品排到靠前的,都不会太难看,一般人不爱看某部作品也是因为不喜欢这个类型,而此人也不会全不喜欢这些网络作品。究其原因,是因为网络作品都是让人先白看的,看的好了才出了头。而纸质作品就不一定了,排行榜靠前的,有好作品,也有垃圾。 许多大牛都是写了博客,后来出了书。这些书也都不次,可能有人让为不好,是因为技术书不像小说,小说在读故事,技术书是在学知识或温习知识,有些技术书读得可
document.domain 跨域问题
avords
document
document.domain用来得到当前网页的域名。比如在地址栏里输入:javascript:alert(document.domain); //www.315ta.com我们也可以给document.domain属性赋值,不过是有限制的,你只能赋成当前的域名或者基础域名。比如:javascript:alert(document.domain = "315ta.com");
关于管理软件的一些思考
houxinyou
管理
工作好多看年了,一直在做管理软件,不知道是我最开始做的时候产生了一些惯性的思维,还是现在接触的管理软件水平有所下降.换过好多年公司,越来越感觉现在的管理软件做的越来越乱.
在我看来,管理软件不论是以前的结构化编程,还是现在的面向对象编程,不管是CS模式,还是BS模式.模块的划分是很重要的.当然,模块的划分有很多种方式.我只是以我自己的划分方式来说一下.
做为管理软件,就像现在讲究MVC这
NoSQL数据库之Redis数据库管理(String类型和hash类型)
bijian1013
redis 数据库 NoSQL
一.Redis的数据类型
1.String类型及操作
String是最简单的类型,一个key对应一个value,string类型是二进制安全的。Redis的string可以包含任何数据,比如jpg图片或者序列化的对象。
Set方法:设置key对应的值为string类型的value
Tomcat 一些技巧
征客丶
java tomcat dos
以下操作都是在windows 环境下
一、Tomcat 启动时配置 JAVA_HOME
在 tomcat 安装目录,bin 文件夹下的 catalina.bat 或 setclasspath.bat 中添加
set JAVA_HOME=JAVA 安装目录
set JRE_HOME=JAVA 安装目录/jre
即可;
二、查看Tomcat 版本
在 tomcat 安装目
【Spark七十二】Spark的日志配置
bit1129
spark
在测试Spark Streaming时,大量的日志显示到控制台,影响了Spark Streaming程序代码的输出结果的查看(代码中通过println将输出打印到控制台上),可以通过修改Spark的日志配置的方式,不让Spark Streaming把它的日志显示在console
在Spark的conf目录下,把log4j.properties.template修改为log4j.p
Haskell版冒泡排序
bookjovi
冒泡排序 haskell
面试的时候问的比较多的算法题要么是binary search,要么是冒泡排序,真的不想用写C写冒泡排序了,贴上个Haskell版的,思维简单,代码简单,下次谁要是再要我用C写冒泡排序,直接上个haskell版的,让他自己去理解吧。
sort [] = []
sort [x] = [x]
sort (x:x1:xs)
| x>x1 = x1:so
java 路径 配置文件读取
bro_feng
java
这几天做一个项目,关于路径做如下笔记,有需要供参考。
取工程内的文件,一般都要用相对路径,这个自然不用多说。
在src统计目录建配置文件目录res,在res中放入配置文件。
读取文件使用方式:
1. MyTest.class.getResourceAsStream("/res/xx.properties")
2. properties.load(MyTest.
读《研磨设计模式》-代码笔记-简单工厂模式
bylijinnan
java 设计模式
声明: 本文只为方便我个人查阅和理解,详细的分析以及源代码请移步 原作者的博客http://chjavach.iteye.com/
package design.pattern;
/*
* 个人理解:简单工厂模式就是IOC;
* 客户端要用到某一对象,本来是由客户创建的,现在改成由工厂创建,客户直接取就好了
*/
interface IProduct {
SVN与JIRA的关联
chenyu19891124
SVN
SVN与JIRA的关联一直都没能装成功,今天凝聚心思花了一天时间整合好了。下面是自己整理的步骤:
一、搭建好SVN环境,尤其是要把SVN的服务注册成系统服务
二、装好JIRA,自己用是jira-4.3.4破解版
三、下载SVN与JIRA的插件并解压,然后拷贝插件包下lib包里的三个jar,放到Atlassian\JIRA 4.3.4\atlassian-jira\WEB-INF\lib下,再
JWFDv0.96 最新设计思路
comsci
数据结构 算法 工作 企业应用 公告
随着工作流技术的发展,工作流产品的应用范围也不断的在扩展,开始进入了像金融行业(我已经看到国有四大商业银行的工作流产品招标公告了),实时生产控制和其它比较重要的工程领域,而
vi 保存复制内容格式粘贴
daizj
vi 粘贴 复制 保存原格式 不变形
vi是linux中非常好用的文本编辑工具,功能强大无比,但对于复制带有缩进格式的内容时,粘贴的时候内容错位很严重,不会按照复制时的格式排版,vi能不能在粘贴时,按复制进的格式进行粘贴呢? 答案是肯定的,vi有一个很强大的命令可以实现此功能 。
在命令模式输入:set paste,则进入paste模式,这样再进行粘贴时
shell脚本运行时报错误:/bin/bash^M: bad interpreter 的解决办法
dongwei_6688
shell脚本
出现原因:windows上写的脚本,直接拷贝到linux系统上运行由于格式不兼容导致
解决办法:
1. 比如文件名为myshell.sh,vim myshell.sh
2. 执行vim中的命令 : set ff?查看文件格式,如果显示fileformat=dos,证明文件格式有问题
3. 执行vim中的命令 :set fileformat=unix 将文件格式改过来就可以了,然后:w
高一上学期难记忆单词
dcj3sjt126com
word english
honest 诚实的;正直的
argue 争论
classical 古典的
hammer 锤子
share 分享;共有
sorrow 悲哀;悲痛
adventure 冒险
error 错误;差错
closet 壁橱;储藏室
pronounce 发音;宣告
repeat 重做;重复
majority 大多数;大半
native 本国的,本地的,本国
hibernate查询返回DTO对象,DTO封装了多个pojo对象的属性
frankco
POJO hibernate查询 DTO
DTO-数据传输对象;pojo-最纯粹的java对象与数据库中的表一一对应。
简单讲:DTO起到业务数据的传递作用,pojo则与持久层数据库打交道。
有时候我们需要查询返回DTO对象,因为DTO
Partition List
hcx2013
partition
Given a linked list and a value x, partition it such that all nodes less than x come before nodes greater than or equal to x.
You should preserve the original relative order of th
Spring MVC测试框架详解——客户端测试
jinnianshilongnian
上一篇《Spring MVC测试框架详解——服务端测试》已经介绍了服务端测试,接下来再看看如果测试Rest客户端,对于客户端测试以前经常使用的方法是启动一个内嵌的jetty/tomcat容器,然后发送真实的请求到相应的控制器;这种方式的缺点就是速度慢;自Spring 3.2开始提供了对RestTemplate的模拟服务器测试方式,也就是说使用RestTemplate测试时无须启动服务器,而是模拟一
关于推荐个人观点
liyonghui160com
推荐系统 关于推荐个人观点
回想起来,我也做推荐了3年多了,最近公司做了调整招聘了很多算法工程师,以为需要多么高大上的算法才能搭建起来的,从实践中走过来,我只想说【不是这样的】
第一次接触推荐系统是在四年前入职的时候,那时候,机器学习和大数据都是没有的概念,什么大数据处理开源软件根本不存在,我们用多台计算机web程序记录用户行为,用.net的w
不间断旋转的动画
pangyulei
动画
CABasicAnimation* rotationAnimation;
rotationAnimation = [CABasicAnimation animationWithKeyPath:@"transform.rotation.z"];
rotationAnimation.toValue = [NSNumber numberWithFloat: M
自定义annotation
sha1064616837
java enum annotation reflect
对象有的属性在页面上可编辑,有的属性在页面只可读,以前都是我们在页面上写死的,时间一久有时候会混乱,此处通过自定义annotation在类属性中定义。越来越发现Java的Annotation真心很强大,可以帮我们省去很多代码,让代码看上去简洁。
下面这个例子 主要用到了
1.自定义annotation:@interface,以及几个配合着自定义注解使用的几个注解
2.简单的反射
3.枚举
Spring 源码
up2pu
spring
1.Spring源代码
https://github.com/SpringSource/spring-framework/branches/3.2.x
注:兼容svn检出
2.运行脚本
import-into-eclipse.bat
注:需要设置JAVA_HOME为jdk 1.7
build.gradle
compileJava {
sourceCompatibilit
利用word分词来计算文本相似度
yangshangchuan
word word分词 文本相似度 余弦相似度 简单共有词
word分词提供了多种文本相似度计算方式:
方式一:余弦相似度,通过计算两个向量的夹角余弦值来评估他们的相似度
实现类:org.apdplat.word.analysis.CosineTextSimilarity
用法如下:
String text1 = "我爱购物";
String text2 = "我爱读书";
String text3 =