首页 > 其他 > 详细

【Qt5开发及实例】18、图形修饰小工具

时间:2015-01-23 23:06:26      阅读:769      评论:0      收藏:0      [点我收藏+]

图形修饰小工具

无力吐槽,这是我第三遍写这个了,到底是个什么意思???我只要一贴代码,浏览器直接崩溃,呵呵了,我也是,我现在只要写完一段字我就保存,尼玛在掉我就不写了,写到word里面,再贴上来。


效果

技术分享



左边图形展示界面

paintarea.h

/**
* 书本:【Qt5开发及实例】
* 功能:实现绘画各种图形
* 文件:paintarea.h
* 时间:2015年1月21日16:59:25
* 作者:cutter_point
*/

#ifndef PAINTAREA_H
#define PAINTAREA_H

#include <QWidget>
#include <QPen>
#include <QBrush>
#include <QRect>

class PaintArea : public QWidget
{
  Q_OBJECT
public:
  //能绘画的各种形状
  enum Shape{Line, Rectangle, RoundRect, Ellipse, Polygon, Polyline, Points,    //我也是醉了,在括号里面"/**/"这样注释居然会报错= =
             Arc, Path, Text, Pixmap};    //线条,矩形,圆角矩形,椭圆,多边形,折线,点,弧线,路径,文字,像图
  explicit PaintArea(QWidget *parent = 0);

  void setShape(Shape);       //形状设置
  void setPen(QPen);    //画笔设置
  void setBrush(QBrush);      //设置画刷
  void setFillRule(Qt::FillRule);     //设置填充模式
  void paintEvent(QPaintEvent *);   //重画事件

signals:

public slots:

private:
  Shape shape;    //形状
  QPen pen;   //画笔
  QBrush brush;   //画刷
  Qt::FillRule fillRule;      //填充模式

};

#endif // PAINTAREA_H

paintarea.cpp

/**
* 书本:【Qt5开发及实例】
* 功能:实现绘画各种图形
* 文件:paintarea.h
* 时间:2015年1月21日16:59:25
* 作者:cutter_point
*/
#include "paintarea.h"

#include <QPainter>

PaintArea::PaintArea(QWidget *parent) :
  QWidget(parent)
{
  setPalette(QPalette(Qt::white));    //设置为白色
  setAutoFillBackground(true);      //设置背景颜色
  setMinimumSize(400, 400);   //大小范围
  /*
  和上面的写法效果一样
  QPalette p = palette();
  p.setColor(QPalette::Window, Qt::white);
  setPalette(p);
  */

}

//设置形状,设置画笔,设置画刷,设置背景填充模式
void PaintArea::setShape(Shape s)
{
  shape = s;
  update();   //更新
}

void PaintArea::setPen(QPen p)
{
  pen = p;
  update();
}

void PaintArea::setBrush(QBrush b)
{
  brush = b;
  update();
}

void PaintArea::setFillRule(Qt::FillRule rule)    //填充规则
{
  fillRule = rule;
  update();     //重画绘制区窗体
}

//重画函数
void PaintArea::paintEvent(QPaintEvent *)
{
  QPainter p(this);   //获得当前图画功能
  p.setPen(pen);
  p.setBrush(brush);

  //QRect::QRect(int x, int y, int width, int height)  Constructs a rectangle with (x, y) as its top-left corner and the given width and height.
  QRect rect(50, 100, 300, 200);   //画一个矩形,四个参数,第一和第二个是左上角开始的坐标x,y,然后就是宽和高

  static const QPoint points[4] =     //用来画多边形,点,多变线准备
  {
    QPoint(150, 100),
    QPoint(300, 150),
    QPoint(350, 250),
    QPoint(100, 300)
  };

  int startAngle = 30 * 16;   //起始角,这里用1/16来表示单位度,所以这个是30度,也就是16就是1°
  int spanAngle = 120*16;

  QPainterPath path;    //画图像的类
  path.addRect(150, 150, 100, 100);   //开始画了一个矩形
  path.moveTo(100, 100);    //移动到新的画的起始点
  path.cubicTo(300, 100, 200,  200, 300, 300);    //画贝塞尔曲线
  path.cubicTo(100, 300, 200, 200, 100, 100);
  path.setFillRule(fillRule);   //设置填充模式

  //判断要画何种图形
  switch(shape)
    {
    case Line:      //一条直线
      p.drawLine(rect.topLeft(), rect.bottomRight());  break;
    case Rectangle:   //长方形
      p.drawRect(rect); break;
    case RoundRect:       //圆角方形
      p.drawRoundRect(rect);  break;
    case Ellipse:     //椭圆
      p.drawEllipse(rect); break;
    case Polygon:   //多边形
      p.drawPolygon(points, 4); break;
    case Polyline:    //多边线
      p.drawPolyline(points, 4); break;
    case Points:      //点
      p.drawPoints(points, 4); break;
    case Arc:   //弧线
      p.drawArc(rect, startAngle, spanAngle); break;
    case Path:    //路径
      p.drawPath(path); break;
    case Text:      //文字
      p.drawText(rect, Qt::AlignCenter, tr("Hello cutter_point!")); break;
    case Pixmap:    //图片
      p.drawPixmap(150, 150, QPixmap(":/butterfly.png")); break;
    default: break;
    }
}



哎,这个定义实现文件我贴了三遍,尼玛我发现贴代码,最后的空行还不能太多,不然这网站就会让你的浏览器崩溃,呵呵,我不知道别人是不是这样,我这里只要代码最后空行一多就会崩溃。。。。

技术分享


主窗口实现

技术分享


就是这些。

mainwidget.h

/**
* 书本:【Qt5开发及实例】
* 功能:实现绘画各种图形
* 文件:paintarea.h
* 时间:2015年1月21日17:59:59
* 作者:cutter_point
*/
#ifndef MAINWIDGET_H
#define MAINWIDGET_H

#include "paintarea.h"

#include <QWidget>
#include <QLabel>
#include <QComboBox>
#include <QSpinBox>
#include <QPushButton>
#include <QGridLayout>
#include <QGradient>

class MainWidget : public QWidget
{
  Q_OBJECT

public:
  MainWidget(QWidget *parent = 0);
  ~MainWidget();
private:
      PaintArea *paintArea;   //前面写的那个类的一个对象

      QLabel *shapeLabel;     //形状选择标签
      QComboBox *shapeComboBox;
      QLabel *penWidthLabel;      //画笔的线宽
      QSpinBox *penWidthSpinBox;
      QLabel *penColorLabel;      //画笔颜色
      QFrame *penColorFrame;      //画笔颜色的界面
      QPushButton *penColorBtn;   //颜色改变按钮
      QLabel *penStyleLabel;      //画笔风格
      QComboBox *penStyleComboBox;
      QLabel *penCapLabel;    //画笔顶帽
      QComboBox *penCapComboBox;
      QLabel *penJoinLabel;   //画笔连接点
      QComboBox *penJoinComboBox;
      QLabel *fillRuleLabel;      //填充模式
      QComboBox *fillRuleComboBox;
      QLabel *spreadLabel;      //铺展效果
      QComboBox *spreadComboBox;
      QGradient::Spread spread;
      QLabel *brushStyleLabel;      //画刷风格
      QComboBox *brushStyleComboBox;
      QLabel *brushColorLabel;      //画刷颜色
      QFrame *brushColorFrame;    //画刷颜色选择界面
      QPushButton *brushColorBtn;

      QGridLayout *rightLayout;

  protected slots:
      void ShowShape(int);    //显示改变的颜色
      void ShowPenWidth(int value);     //显示改变之后的画笔宽
      void ShowPenColor();      //显示改变之后的画笔颜色
      void ShowPenStyle(int);   //显示改变之后的画笔风格
      void ShowPenCap(int);   //显示改变之后的画笔顶帽
      void ShowPenJoin(int);  //显示改变之后的画笔连接点
      void ShowSpreadStyle();   //显示改变之后的铺展效果
      void ShowFillRule();          //显示改变之后的填充风格
      void ShowBrushColor();    //显示改变之后的画刷颜色
      void ShowBrush(int);    //显示改变之后的画刷

};

#endif // MAINWIDGET_H

mainwidget.cpp

/**
* 书本:【Qt5开发及实例】
* 功能:实现绘画各种图形
* 文件:paintarea.h
* 时间:2015年1月21日18:42:43
* 作者:cutter_point
*/
#include "mainwidget.h"

#include <QColorDialog>

MainWidget::MainWidget(QWidget *parent)
  : QWidget(parent)
{
  paintArea = new PaintArea;    //创建一个头文件对象

  shapeLabel = new QLabel(tr("SHAPE"));   //形状
  shapeComboBox = new QComboBox;
  shapeComboBox->addItem(tr("Line"), PaintArea::Line);
  shapeComboBox->addItem(tr("Rectangle"), PaintArea::Rectangle);
  shapeComboBox->addItem(tr("RoundedRect"),PaintArea::RoundRect);
  shapeComboBox->addItem(tr("Ellipse"),PaintArea::Ellipse);
  shapeComboBox->addItem(tr("Polygon"),PaintArea::Polygon);
  shapeComboBox->addItem(tr("Polyline"),PaintArea::Polyline);
  shapeComboBox->addItem(tr("Points"),PaintArea::Points);
  shapeComboBox->addItem(tr("Arc"),PaintArea::Arc);
  shapeComboBox->addItem(tr("Path"),PaintArea::Path);
  shapeComboBox->addItem(tr("Text"),PaintArea::Text);
  shapeComboBox->addItem(tr("Pixmap"),PaintArea::Pixmap);
  connect(shapeComboBox, SIGNAL(activated(int)), this, SLOT(ShowShape(int)));   //相应的连接

  penColorLabel = new QLabel(tr("pen color:"));     //画笔颜色选择控件
  penColorFrame = new QFrame;
  penColorFrame->setFrameStyle(QFrame::Panel|QFrame::Sunken);  //新创建的界面的风格是下凹的
  penColorFrame->setAutoFillBackground(true);   //设置背景颜色
  penColorFrame->setPalette(QPalette(Qt::blue));      //设置调色板为蓝色
  penColorBtn = new QPushButton(tr("change"));      //更改按钮
  connect(penColorBtn, SIGNAL(clicked()), this, SLOT(ShowPenColor()));

  penWidthLabel = new QLabel(tr("pen width"));    //画笔线宽
  penWidthSpinBox = new QSpinBox;
  penWidthSpinBox->setRange(0, 998);
  connect(penWidthSpinBox, SIGNAL(valueChanged(int)), this, SLOT(ShowPenWidth(int)));

  penStyleLabel = new QLabel(tr("pen style"));    //画笔风格选择
  penStyleComboBox = new QComboBox;
  penStyleComboBox->addItem(tr("SolidLine"), static_cast<int>(Qt::SolidLine));   //实线
  penStyleComboBox->addItem(tr("DashLine"), static_cast<int>(Qt::DashLine));   //虚线
  penStyleComboBox->addItem(tr("DotLine"), static_cast<int>(Qt::DotLine));   //点虚线
  penStyleComboBox->addItem(tr("DashDotLine"), static_cast<int>(Qt::DashDotLine));   //点虚线2
  penStyleComboBox->addItem(tr("DashDotDotLine"), static_cast<int>(Qt::DashDotDotLine));   //点虚线3
  penStyleComboBox->addItem(tr("CustomDashLine"), static_cast<int>(Qt::CustomDashLine));   //越来越虚线
  connect(penStyleComboBox, SIGNAL(activated(int)), this, SLOT(ShowPenStyle(int)));

  //画笔顶帽风格选择
  penCapLabel =new QLabel(tr("pen cap:"));        //画笔顶端风格选择下拉列表框
  penCapComboBox =new QComboBox;
  penCapComboBox->addItem(tr("SquareCap"),Qt::SquareCap);   //方向。。。,包含终止然后突出一半的线宽
  penCapComboBox->addItem(tr("FlatCap"),Qt::FlatCap);     //方向的线条,不包含终点
  penCapComboBox->addItem(tr("RoundCap"),Qt::RoundCap);   //一个圆形的线条
  connect(penCapComboBox,SIGNAL(activated(int)),this,SLOT(ShowPenCap (int)));

  penJoinLabel =new QLabel(tr("画笔连接点:"));     //画笔连接点风格选择下拉列表框
  penJoinComboBox =new QComboBox;
  penJoinComboBox->addItem(tr("BevelJoin"),Qt::BevelJoin);    //线连接处的转折处没有三角突出
  penJoinComboBox->addItem(tr("MiterJoin"),Qt::MiterJoin);      //线连接处的转折处有三角突出
  penJoinComboBox->addItem(tr("RoundJoin"),Qt::RoundJoin);  //线连接处的转折处圆润
  connect(penJoinComboBox,SIGNAL(activated(int)),this,SLOT(ShowPenJoin (int)));

  fillRuleLabel =new QLabel(tr("填充模式:"));    	//填充模式选择下拉列表框
  fillRuleComboBox =new QComboBox;
  fillRuleComboBox->addItem(tr("Odd Even"),Qt::OddEvenFill);      //以一个点画水平射线,有奇数个交点那么这儿点得填充
  fillRuleComboBox->addItem(tr("Winding"),Qt::WindingFill);   //设线,方向抵消之后不为0就填充
  connect(fillRuleComboBox,SIGNAL(activated(int)),this,SLOT (ShowFillRule()));

  spreadLabel =new QLabel(tr("铺展效果:"));    	//铺展效果选择下拉列表框
  spreadComboBox =new QComboBox;
  spreadComboBox->addItem(tr("PadSpread"),QGradient::PadSpread);    //对非渐变的区域填充单一起始颜色或终止颜色
  spreadComboBox->addItem(tr("RepeatSpread"),QGradient::RepeatSpread);    //对渐变器明显作用
  spreadComboBox->addItem(tr("ReflectSpread"),QGradient:: ReflectSpread);   //缓和的作用
  connect(spreadComboBox,SIGNAL(activated(int)),this,SLOT (ShowSpreadStyle()));

  brushColorLabel =new QLabel(tr("画刷颜色:"));   	//画刷颜色选择控件
  brushColorFrame =new QFrame;
  brushColorFrame->setFrameStyle(QFrame::Panel|QFrame::Sunken);
  brushColorFrame->setAutoFillBackground(true);
  brushColorFrame->setPalette(QPalette(Qt::green));
  brushColorBtn =new QPushButton(tr("更改"));
  connect(brushColorBtn,SIGNAL(clicked()),this,SLOT (ShowBrushColor()));

  brushStyleLabel =new QLabel(tr("画刷风格:"));   	//画刷风格选择下拉列表框
  brushStyleComboBox =new QComboBox;
  brushStyleComboBox->addItem(tr("SolidPattern"),static_cast<int>(Qt::SolidPattern));
  brushStyleComboBox->addItem(tr("Dense1Pattern"),static_cast<int>(Qt::Dense1Pattern));
  brushStyleComboBox->addItem(tr("Dense2Pattern"),static_cast<int>(Qt::Dense2Pattern));
  brushStyleComboBox->addItem(tr("Dense3Pattern"),static_cast<int>(Qt::Dense3Pattern));
  brushStyleComboBox->addItem(tr("Dense4Pattern"),static_cast<int>(Qt::Dense4Pattern));
  brushStyleComboBox->addItem(tr("Dense5Pattern"),static_cast<int>(Qt::Dense5Pattern));
  brushStyleComboBox->addItem(tr("Dense6Pattern"),static_cast<int>(Qt::Dense6Pattern));
  brushStyleComboBox->addItem(tr("Dense7Pattern"),static_cast<int>(Qt::Dense7Pattern));
  brushStyleComboBox->addItem(tr("HorPattern"),static_cast<int>(Qt::HorPattern));
  brushStyleComboBox->addItem(tr("VerPattern"),static_cast<int>(Qt::VerPattern));
  brushStyleComboBox->addItem(tr("CrossPattern"),static_cast<int>(Qt::CrossPattern));
  brushStyleComboBox->addItem(tr("BDiagPattern"),static_cast<int>(Qt::BDiagPattern));
  brushStyleComboBox->addItem(tr("FDiagPattern"),static_cast<int>(Qt::FDiagPattern));
  brushStyleComboBox->addItem(tr("DiagCrossPattern"),static_cast<int>(Qt:: DiagCrossPattern));
  brushStyleComboBox->addItem(tr("LinearGradientPattern"),static_cast<int>(Qt:: LinearGradientPattern));
  brushStyleComboBox->addItem(tr("ConicalGradientPattern"),static_cast<int>(Qt:: ConicalGradientPattern));
  brushStyleComboBox->addItem(tr("RadialGradientPattern"),static_cast<int>(Qt:: RadialGradientPattern));
  brushStyleComboBox->addItem(tr("TexturePattern"),static_cast<int>(Qt::TexturePattern));
  connect(brushStyleComboBox,SIGNAL(activated(int)),this,SLOT (ShowBrush(int)));

  rightLayout =new QGridLayout;                   //控制面板的布局,网格布局
  rightLayout->addWidget(shapeLabel,0,0);
  rightLayout->addWidget(shapeComboBox,0,1);
  rightLayout->addWidget(penColorLabel,1,0);
  rightLayout->addWidget(penColorFrame,1,1);
  rightLayout->addWidget(penColorBtn,1,2);
  rightLayout->addWidget(penWidthLabel,2,0);
  rightLayout->addWidget(penWidthSpinBox,2,1);
  rightLayout->addWidget(penStyleLabel,3,0);
  rightLayout->addWidget(penStyleComboBox,3,1);
  rightLayout->addWidget(penCapLabel,4,0);
  rightLayout->addWidget(penCapComboBox,4,1);
  rightLayout->addWidget(penJoinLabel,5,0);
  rightLayout->addWidget(penJoinComboBox,5,1);
  rightLayout->addWidget(fillRuleLabel,6,0);
  rightLayout->addWidget(fillRuleComboBox,6,1);
  rightLayout->addWidget(spreadLabel,7,0);
  rightLayout->addWidget(spreadComboBox,7,1);
  rightLayout->addWidget(brushColorLabel,8,0);
  rightLayout->addWidget(brushColorFrame,8,1);
  rightLayout->addWidget(brushColorBtn,8,2);
  rightLayout->addWidget(brushStyleLabel,9,0);
  rightLayout->addWidget(brushStyleComboBox,9,1);

  //总布局分配
  QHBoxLayout *mainLayout = new QHBoxLayout(this);      //整体的布局
  mainLayout->addWidget(paintArea);
  mainLayout->addLayout(rightLayout);   //右边的一大块添加进去
  mainLayout->setStretchFactor(paintArea, 1);     //弹簧如果有那就返回true,没有这个界面的布局的话false
  mainLayout->setStretchFactor(rightLayout, 0);   //??????

  ShowShape(shapeComboBox->currentIndex());   //显示默认的图形
}


//根据选择的形状设定形状显示
void MainWidget::ShowShape(int value)
{
  PaintArea::Shape shape = PaintArea::Shape(shapeComboBox->itemData(value, Qt::UserRole).toInt());
  paintArea->setShape(shape);
}

//显示画笔
void MainWidget::ShowBrush(int value)
{
  //首先得到画刷的颜色
  QColor color = brushColorFrame->palette().color(QPalette::Window);
  Qt::BrushStyle style = Qt::BrushStyle(brushStyleComboBox->itemData(value, Qt::UserRole).toInt());   //得到画刷的风格

  if(style == Qt::LinearGradientPattern)    //如果当前选定的风格是线性渐变
    {
      QLinearGradient linearGradient(0, 0, 400, 400);   //整个页面的起始位置和结束位置
      linearGradient.setColorAt(0.0, Qt::white);   //前面的那个数字是整个长度的0.x来表示
      linearGradient.setColorAt(0.2, color);    //这个表示在长度的五分之一的时候设置颜色是color
      linearGradient.setColorAt(1.0, Qt::black);    //这三个是颜色的渐变过程
      linearGradient.setSpread(spread);   //对这个spread进行渐变
      paintArea->setBrush(linearGradient);    //设置画刷
    }
  else if(style == Qt::RadialGradientPattern)   //圆形渐变
    {
      QRadialGradient radialGradient(200, 200, 150, 150, 100);    //分别是圆心,半径,焦点坐标,焦点就是颜色渐变的开始地方
      radialGradient.setColorAt(0.0, Qt::white);
      radialGradient.setColorAt(0.2, color);
      radialGradient.setColorAt(1.0, Qt::black);
      radialGradient.setSpread(spread);   //设置扩散
    }
  else if(style == Qt::TexturePattern)    //这个是为了画图形
    {
      //设置画刷是一个图形就可以了
      paintArea->setBrush(QBrush(QPixmap(":/butterfly.png")));
    }
  else
    {
      paintArea->setBrush(QBrush(color, style));    //设置一个普通的画刷
    }

}

//设置画刷颜色,然后调用展示画刷来实现
void MainWidget::ShowBrushColor()
{
  QColor color = QColorDialog::getColor(static_cast<int>(Qt::blue));    //强制转化蓝色为int类型,然后赋值给颜色选择对话框
  brushColorFrame->setPalette(QPalette(color));   //设置调色板颜色给定
  ShowBrush(brushStyleComboBox->currentIndex());  //选择当前选中的画笔风格,调用ShowBrush函数来显示

}

//铺展效果展示
void MainWidget::ShowSpreadStyle()
{
  spread = QGradient::Spread(spreadComboBox->itemData(spreadComboBox->currentIndex(), Qt::UserRole).toInt());   //设置铺展方式
}

//填充颜色的选择
void MainWidget::ShowFillRule()
{
  Qt::FillRule rule = Qt::FillRule(fillRuleComboBox->itemData(fillRuleComboBox->currentIndex(), Qt::UserRole).toInt()); //把当前选择的填充方式拿出来
  paintArea->setFillRule(rule);   //设定新的填充规则

}

//获得与画笔相关的属性
void MainWidget::ShowPenColor()
{
  //显示画笔的颜色
  QColor color = QColorDialog::getColor(static_cast<int> (Qt::blue));   //画笔颜色
  penColorFrame->setPalette(QPalette(color));     //设置画笔颜色界面的初始颜色
  int value = penWidthSpinBox->value();     //设置画笔宽度

  //画笔风格
  Qt::PenStyle style = Qt::PenStyle(penStyleComboBox->itemData(penStyleComboBox->currentIndex(), Qt::UserRole).toInt());
  //顶帽
  Qt::PenCapStyle cap = Qt::PenCapStyle(penCapComboBox->itemData(penCapComboBox->currentIndex(), Qt::UserRole).toInt());
  //连接点
  Qt::PenJoinStyle join = Qt::PenJoinStyle(penJoinComboBox->itemData(penJoinComboBox->currentIndex(), Qt::UserRole).toInt());

  //设置这个块区域画笔
  paintArea->setPen(QPen(color, value, style, cap, join));

}


//获取当前选中对的所对应的画笔,只是这个是改变了宽度
void MainWidget::ShowPenWidth(int value)
{
  //显示画笔的颜色
//  QColor color = QColorDialog::getColor(static_cast<int> (Qt::blue));   //画笔颜色
  QColor color = penColorFrame->palette().color(QPalette::Window);     //设置画笔颜色界面的初始颜色
//  int value = penWidthSpinBox->value();     //设置画笔宽度

  //画笔风格
  Qt::PenStyle style = Qt::PenStyle(penStyleComboBox->itemData(penStyleComboBox->currentIndex(), Qt::UserRole).toInt());
  //顶帽
  Qt::PenCapStyle cap = Qt::PenCapStyle(penCapComboBox->itemData(penCapComboBox->currentIndex(), Qt::UserRole).toInt());
  //连接点
  Qt::PenJoinStyle join = Qt::PenJoinStyle(penJoinComboBox->itemData(penJoinComboBox->currentIndex(), Qt::UserRole).toInt());

  //设置这个块区域画笔
  paintArea->setPen(QPen(color, value, style, cap, join));
}

void MainWidget::ShowPenStyle(int styleValue)
{
  //显示画笔的颜色
//  QColor color = QColorDialog::getColor(static_cast<int> (Qt::blue));   //画笔颜色
  QColor color = penColorFrame->palette().color(QPalette::Window);     //设置画笔颜色界面的初始颜色
  int value = penWidthSpinBox->value();     //设置画笔宽度

  //画笔风格
  Qt::PenStyle style = Qt::PenStyle(penStyleComboBox->itemData(styleValue, Qt::UserRole).toInt());    //设置style
  //顶帽
  Qt::PenCapStyle cap = Qt::PenCapStyle(penCapComboBox->itemData(penCapComboBox->currentIndex(), Qt::UserRole).toInt());
  //连接点
  Qt::PenJoinStyle join = Qt::PenJoinStyle(penJoinComboBox->itemData(penJoinComboBox->currentIndex(), Qt::UserRole).toInt());

  //设置这个块区域画笔
  paintArea->setPen(QPen(color, value, style, cap, join));
}

void MainWidget::ShowPenCap(int capValue)
{
  //显示画笔的颜色
//  QColor color = QColorDialog::getColor(static_cast<int> (Qt::blue));   //画笔颜色
  QColor color = penColorFrame->palette().color(QPalette::Window);     //设置画笔颜色界面的初始颜色
  int value = penWidthSpinBox->value();     //设置画笔宽度

  //画笔风格
  Qt::PenStyle style = Qt::PenStyle(penStyleComboBox->itemData(penStyleComboBox->currentIndex(), Qt::UserRole).toInt());
  //顶帽
//  Qt::PenCapStyle cap = Qt::PenCapStyle(penCapComboBox->itemData(penCapComboBox->currentIndex(), Qt::UserRole).toInt());
  Qt::PenCapStyle cap = Qt::PenCapStyle(penCapComboBox->itemData(capValue, Qt::UserRole).toInt());
  //连接点
  Qt::PenJoinStyle join = Qt::PenJoinStyle(penJoinComboBox->itemData(penJoinComboBox->currentIndex(), Qt::UserRole).toInt());

  //设置这个块区域画笔
  paintArea->setPen(QPen(color, value, style, cap, join));
}

void MainWidget::ShowPenJoin(int joinValue)
{
  //显示画笔的颜色
//  QColor color = QColorDialog::getColor(static_cast<int> (Qt::blue));   //画笔颜色
  QColor color = penColorFrame->palette().color(QPalette::Window);     //设置画笔颜色界面的初始颜色
  int value = penWidthSpinBox->value();     //设置画笔宽度

  //画笔风格
  Qt::PenStyle style = Qt::PenStyle(penStyleComboBox->itemData(penStyleComboBox->currentIndex(), Qt::UserRole).toInt());
  //顶帽
  Qt::PenCapStyle cap = Qt::PenCapStyle(penCapComboBox->itemData(penCapComboBox->currentIndex(), Qt::UserRole).toInt());
//  Qt::PenCapStyle cap = Qt::PenCapStyle(penCapComboBox->itemData(capValue, Qt::UserRole).toInt());
  //连接点
//  Qt::PenJoinStyle join = Qt::PenJoinStyle(penJoinComboBox->itemData(penJoinComboBox->currentIndex(), Qt::UserRole).toInt());
  Qt::PenJoinStyle join = Qt::PenJoinStyle(penJoinComboBox->itemData(joinValue, Qt::UserRole).toInt());

  //设置这个块区域画笔
  paintArea->setPen(QPen(color, value, style, cap, join));
}




MainWidget::~MainWidget()
{
}

这里我就得说一下里面的那个渐变的实现了,我觉得理解是有点麻烦的,比如线性渐变和圆形渐变的差别,还有圆形渐变的焦点的作用

我们先看看几张图就会明白了。

技术分享

技术分享

好的,这个是我在网上找的图,我做的那个不知道为什么没有显示,但是代码应该是没有错的,好的线性渐变这里有好几个变化

linearGradient.setColorAt(0.0, Qt::white);   //前面的那个数字是整个长度的0.x来表示
      linearGradient.setColorAt(0.2, color);    //这个表示在长度的五分之一的时候设置颜色是color
      linearGradient.setColorAt(1.0, Qt::black);    //这三个是颜色的渐变过程

这里就是线性变化的代码,没错就是里面注释说的,从图中(X1,Y1)到(X2, Y2)的变化是从白到黑的

radialGradient.setColorAt(0.0, Qt::white);
      radialGradient.setColorAt(0.2, color);
      radialGradient.setColorAt(1.0, Qt::black);

而第二个图就是那个白色的地方就是第三个参数焦点了

主函数显示

/**
* 书本:【Qt5开发及实例】
* 功能:实现绘画各种图形
* 文件:main.cpp
* 时间:2015年1月23日18:42:54
* 作者:cutter_point
*/
#include "mainwidget.h"
#include <QApplication>
#include <QFont>

int main(int argc, char *argv[])
{
  QApplication a(argc, argv);
  QFont f("迷你简丫丫", 12);   //设置字体
  a.setFont(f);

  MainWidget w;
  w.show();

  return a.exec();
}

最后,我们展示一下这个程序:

技术分享技术分享技术分享技术分享技术分享技术分享技术分享技术分享技术分享技术分享技术分享







【Qt5开发及实例】18、图形修饰小工具

原文:http://blog.csdn.net/cutter_point/article/details/43059735

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!