亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? plotter.cpp

?? QT4 gui programming的隨書光盤
?? CPP
字號:
#include <QtGui>#include <cmath>#include "plotter.h"Plotter::Plotter(QWidget *parent)    : QWidget(parent){    setBackgroundRole(QPalette::Dark);    setAutoFillBackground(true);    setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Expanding);    setFocusPolicy(Qt::StrongFocus);    rubberBandIsShown = false;    zoomInButton = new QToolButton(this);    zoomInButton->setIcon(QIcon(":/images/zoomin.png"));    zoomInButton->adjustSize();    connect(zoomInButton, SIGNAL(clicked()), this, SLOT(zoomIn()));    zoomOutButton = new QToolButton(this);    zoomOutButton->setIcon(QIcon(":/images/zoomout.png"));    zoomOutButton->adjustSize();    connect(zoomOutButton, SIGNAL(clicked()), this, SLOT(zoomOut()));    setPlotSettings(PlotSettings());}void Plotter::setPlotSettings(const PlotSettings &settings){    zoomStack.clear();    zoomStack.append(settings);    curZoom = 0;    zoomInButton->hide();    zoomOutButton->hide();    refreshPixmap();}void Plotter::zoomOut(){    if (curZoom > 0) {        --curZoom;        zoomOutButton->setEnabled(curZoom > 0);        zoomInButton->setEnabled(true);        zoomInButton->show();        refreshPixmap();    }}void Plotter::zoomIn(){    if (curZoom < zoomStack.count() - 1) {        ++curZoom;        zoomInButton->setEnabled(curZoom < zoomStack.count() - 1);        zoomOutButton->setEnabled(true);        zoomOutButton->show();        refreshPixmap();    }}void Plotter::setCurveData(int id, const QVector<QPointF> &data){    curveMap[id] = data;    refreshPixmap();}void Plotter::clearCurve(int id){    curveMap.remove(id);    refreshPixmap();}QSize Plotter::minimumSizeHint() const{    return QSize(6 * Margin, 4 * Margin);}QSize Plotter::sizeHint() const{    return QSize(12 * Margin, 8 * Margin);}void Plotter::paintEvent(QPaintEvent * /* event */){    QStylePainter painter(this);    painter.drawPixmap(0, 0, pixmap);    if (rubberBandIsShown) {        painter.setPen(palette().light().color());        painter.drawRect(rubberBandRect.normalized()                                       .adjusted(0, 0, -1, -1));    }    if (hasFocus()) {        QStyleOptionFocusRect option;        option.initFrom(this);        option.backgroundColor = palette().dark().color();        painter.drawPrimitive(QStyle::PE_FrameFocusRect, option);    }}void Plotter::resizeEvent(QResizeEvent * /* event */){    int x = width() - (zoomInButton->width()                       + zoomOutButton->width() + 10);    zoomInButton->move(x, 5);    zoomOutButton->move(x + zoomInButton->width() + 5, 5);    refreshPixmap();}void Plotter::mousePressEvent(QMouseEvent *event){    QRect rect(Margin, Margin,               width() - 2 * Margin, height() - 2 * Margin);    if (event->button() == Qt::LeftButton) {        if (rect.contains(event->pos())) {            rubberBandIsShown = true;            rubberBandRect.setTopLeft(event->pos());            rubberBandRect.setBottomRight(event->pos());            updateRubberBandRegion();            setCursor(Qt::CrossCursor);        }    }}void Plotter::mouseMoveEvent(QMouseEvent *event){    if (rubberBandIsShown) {        updateRubberBandRegion();        rubberBandRect.setBottomRight(event->pos());        updateRubberBandRegion();    }}void Plotter::mouseReleaseEvent(QMouseEvent *event){    if ((event->button() == Qt::LeftButton) && rubberBandIsShown) {        rubberBandIsShown = false;        updateRubberBandRegion();        unsetCursor();        QRect rect = rubberBandRect.normalized();        if (rect.width() < 4 || rect.height() < 4)            return;        rect.translate(-Margin, -Margin);        PlotSettings prevSettings = zoomStack[curZoom];        PlotSettings settings;        double dx = prevSettings.spanX() / (width() - 2 * Margin);        double dy = prevSettings.spanY() / (height() - 2 * Margin);        settings.minX = prevSettings.minX + dx * rect.left();        settings.maxX = prevSettings.minX + dx * rect.right();        settings.minY = prevSettings.maxY - dy * rect.bottom();        settings.maxY = prevSettings.maxY - dy * rect.top();        settings.adjust();        zoomStack.resize(curZoom + 1);        zoomStack.append(settings);        zoomIn();    }}void Plotter::keyPressEvent(QKeyEvent *event){    switch (event->key()) {    case Qt::Key_Plus:        zoomIn();        break;    case Qt::Key_Minus:        zoomOut();        break;    case Qt::Key_Left:        zoomStack[curZoom].scroll(-1, 0);        refreshPixmap();        break;    case Qt::Key_Right:        zoomStack[curZoom].scroll(+1, 0);        refreshPixmap();        break;    case Qt::Key_Down:        zoomStack[curZoom].scroll(0, -1);        refreshPixmap();        break;    case Qt::Key_Up:        zoomStack[curZoom].scroll(0, +1);        refreshPixmap();        break;    default:        QWidget::keyPressEvent(event);    }}void Plotter::wheelEvent(QWheelEvent *event){    int numDegrees = event->delta() / 8;    int numTicks = numDegrees / 15;    if (event->orientation() == Qt::Horizontal) {        zoomStack[curZoom].scroll(numTicks, 0);    } else {        zoomStack[curZoom].scroll(0, numTicks);    }    refreshPixmap();}void Plotter::updateRubberBandRegion(){    QRect rect = rubberBandRect.normalized();    update(rect.left(), rect.top(), rect.width(), 1);    update(rect.left(), rect.top(), 1, rect.height());    update(rect.left(), rect.bottom(), rect.width(), 1);    update(rect.right(), rect.top(), 1, rect.height());}void Plotter::refreshPixmap(){    pixmap = QPixmap(size());    pixmap.fill(this, 0, 0);    QPainter painter(&pixmap);    painter.initFrom(this);    drawGrid(&painter);    drawCurves(&painter);    update();}void Plotter::drawGrid(QPainter *painter){    QRect rect(Margin, Margin,               width() - 2 * Margin, height() - 2 * Margin);    if (!rect.isValid())        return;    PlotSettings settings = zoomStack[curZoom];    QPen quiteDark = palette().dark().color().light();    QPen light = palette().light().color();    for (int i = 0; i <= settings.numXTicks; ++i) {        int x = rect.left() + (i * (rect.width() - 1)                                 / settings.numXTicks);        double label = settings.minX + (i * settings.spanX()                                          / settings.numXTicks);        painter->setPen(quiteDark);        painter->drawLine(x, rect.top(), x, rect.bottom());        painter->setPen(light);        painter->drawLine(x, rect.bottom(), x, rect.bottom() + 5);        painter->drawText(x - 50, rect.bottom() + 5, 100, 20,                          Qt::AlignHCenter | Qt::AlignTop,                          QString::number(label));    }    for (int j = 0; j <= settings.numYTicks; ++j) {        int y = rect.bottom() - (j * (rect.height() - 1)                                   / settings.numYTicks);        double label = settings.minY + (j * settings.spanY()                                          / settings.numYTicks);        painter->setPen(quiteDark);        painter->drawLine(rect.left(), y, rect.right(), y);        painter->setPen(light);        painter->drawLine(rect.left() - 5, y, rect.left(), y);        painter->drawText(rect.left() - Margin, y - 10, Margin - 5, 20,                          Qt::AlignRight | Qt::AlignVCenter,                          QString::number(label));    }    painter->drawRect(rect.adjusted(0, 0, -1, -1));}void Plotter::drawCurves(QPainter *painter){    static const QColor colorForIds[6] = {        Qt::red, Qt::green, Qt::blue, Qt::cyan, Qt::magenta, Qt::yellow    };    PlotSettings settings = zoomStack[curZoom];    QRect rect(Margin, Margin,               width() - 2 * Margin, height() - 2 * Margin);    if (!rect.isValid())        return;    painter->setClipRect(rect.adjusted(+1, +1, -1, -1));    QMapIterator<int, QVector<QPointF> > i(curveMap);    while (i.hasNext()) {        i.next();        int id = i.key();        QVector<QPointF> data = i.value();        QPolygonF polyline(data.count());        for (int j = 0; j < data.count(); ++j) {            double dx = data[j].x() - settings.minX;            double dy = data[j].y() - settings.minY;            double x = rect.left() + (dx * (rect.width() - 1)                                         / settings.spanX());            double y = rect.bottom() - (dy * (rect.height() - 1)                                           / settings.spanY());            polyline[j] = QPointF(x, y);        }        painter->setPen(colorForIds[uint(id) % 6]);        painter->drawPolyline(polyline);    }}PlotSettings::PlotSettings(){    minX = 0.0;    maxX = 10.0;    numXTicks = 5;    minY = 0.0;    maxY = 10.0;    numYTicks = 5;}void PlotSettings::scroll(int dx, int dy){    double stepX = spanX() / numXTicks;    minX += dx * stepX;    maxX += dx * stepX;    double stepY = spanY() / numYTicks;    minY += dy * stepY;    maxY += dy * stepY;}void PlotSettings::adjust(){    adjustAxis(minX, maxX, numXTicks);    adjustAxis(minY, maxY, numYTicks);}void PlotSettings::adjustAxis(double &min, double &max, int &numTicks){    const int MinTicks = 4;    double grossStep = (max - min) / MinTicks;    double step = std::pow(10.0, std::floor(std::log10(grossStep)));    if (5 * step < grossStep) {        step *= 5;    } else if (2 * step < grossStep) {        step *= 2;    }    numTicks = int(std::ceil(max / step) - std::floor(min / step));    if (numTicks < MinTicks)        numTicks = MinTicks;    min = std::floor(min / step) * step;    max = std::ceil(max / step) * step;}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品国产三级国产aⅴ原创| 午夜欧美大尺度福利影院在线看| 亚洲欧美日本在线| 日韩成人午夜电影| 99热这里都是精品| 精品99一区二区| 日韩精品乱码免费| 欧美四级电影在线观看| 国产精品天天看| 国产一区二区中文字幕| 91麻豆精品国产91久久久使用方法 | 亚洲黄色小视频| 国产成人夜色高潮福利影视| 欧美一区二区三区免费视频| 亚洲在线一区二区三区| av高清久久久| 成人免费一区二区三区视频 | 亚洲女爱视频在线| 粉嫩绯色av一区二区在线观看| 欧美一区二区三区的| 亚洲第一激情av| 欧美日韩免费电影| 亚洲国产日韩av| 在线观看欧美精品| 亚洲一区二区免费视频| 欧美这里有精品| 亚洲中国最大av网站| 欧美亚洲动漫另类| 亚洲国产一区视频| 欧美三级电影网| 亚洲高清一区二区三区| 欧美老女人第四色| 日本网站在线观看一区二区三区| 欧美日韩亚洲另类| 日本女人一区二区三区| 欧美一区二区三区不卡| 韩国女主播成人在线观看| 久久伊99综合婷婷久久伊| 国产麻豆精品theporn| 亚洲国产精品高清| 99re成人在线| 亚洲午夜一二三区视频| 欧美喷潮久久久xxxxx| 美女视频黄 久久| 久久综合狠狠综合久久综合88 | 亚洲黄色尤物视频| 精品视频全国免费看| 午夜在线电影亚洲一区| 日韩欧美中文字幕制服| 国产一区二区在线视频| 国产精品国产三级国产| av中文一区二区三区| 成人免费小视频| 欧美日韩精品一区二区三区四区| 日本一不卡视频| 欧美国产日韩亚洲一区| 色乱码一区二区三区88| 免费成人深夜小野草| 国产欧美一区二区精品性色超碰| 91社区在线播放| 日本美女视频一区二区| 欧美激情一区二区三区全黄| 欧美网站大全在线观看| 精品一区二区三区蜜桃| 亚洲男人的天堂在线aⅴ视频| 欧美日本在线一区| 成人性视频免费网站| 视频在线观看国产精品| 中日韩免费视频中文字幕| 欧美精品国产精品| 成人激情av网| 麻豆成人久久精品二区三区红| 中文在线资源观看网站视频免费不卡| 在线观看视频一区二区| 国产一区二区三区免费在线观看| 一个色综合av| 欧美国产精品v| 日韩一级视频免费观看在线| 91免费国产在线| 国产一区啦啦啦在线观看| 亚洲成人动漫av| 中文字幕在线观看不卡| 欧美tickle裸体挠脚心vk| 欧洲日韩一区二区三区| 国产精品系列在线播放| 日韩电影一区二区三区四区| 自拍偷拍亚洲激情| 国产色综合久久| www国产成人| 欧美一区二区三区免费大片 | 51久久夜色精品国产麻豆| 99国产麻豆精品| 高清beeg欧美| 狠狠v欧美v日韩v亚洲ⅴ| 午夜精彩视频在线观看不卡| 尤物视频一区二区| 国产欧美精品一区二区三区四区| 欧美二区三区91| 香蕉影视欧美成人| 国产日本欧洲亚洲| 日韩女优毛片在线| 日韩一区二区三区视频| 中文字幕在线不卡一区| 91精品国产欧美一区二区18| 欧美午夜影院一区| 美女在线一区二区| 成人精品免费看| 精品视频1区2区| 久久综合久色欧美综合狠狠| 中文字幕一区日韩精品欧美| 五月天亚洲精品| 国产精品1024久久| 欧美日韩一区二区欧美激情| 精品少妇一区二区三区在线视频| 中文字幕av一区二区三区| 亚洲综合无码一区二区| 激情都市一区二区| 欧美曰成人黄网| 久久久精品免费网站| 亚洲一区二区三区中文字幕| 国产精品一区在线观看乱码 | 国产精品污污网站在线观看| 亚洲一区二区三区中文字幕| 国产在线一区二区| 欧美日韩国产免费| 国产精品久久久久久久久久久免费看 | 91捆绑美女网站| 日韩欧美在线网站| 亚洲人123区| 国产精品白丝av| 日韩无一区二区| 亚洲主播在线观看| 成+人+亚洲+综合天堂| 欧美电视剧免费全集观看| 亚洲资源在线观看| 99国内精品久久| 日本一区二区三区免费乱视频 | 亚洲人午夜精品天堂一二香蕉| 日韩中文字幕91| 日本电影亚洲天堂一区| 国产亚洲精品aa午夜观看| 日韩高清不卡一区二区| 色激情天天射综合网| 中国色在线观看另类| 国产原创一区二区| 欧美一二三区在线| 无吗不卡中文字幕| 欧美少妇性性性| 一区二区在线观看视频| 91蜜桃婷婷狠狠久久综合9色| 26uuu精品一区二区| 日本欧美一区二区三区乱码| 欧美色综合影院| 亚洲一区二区高清| 色噜噜夜夜夜综合网| 亚洲另类在线一区| 91视频一区二区| 亚洲欧美日韩在线播放| 91丝袜美女网| 亚洲伦理在线精品| 色综合久久中文字幕| 综合久久国产九一剧情麻豆| 99久久婷婷国产综合精品电影 | 日韩女优av电影| 久久成人免费网| 久久蜜桃av一区精品变态类天堂| 久久精品国产**网站演员| 日韩欧美国产午夜精品| 六月丁香婷婷久久| 精品国产乱码91久久久久久网站| 久久国产免费看| 久久蜜桃香蕉精品一区二区三区| 国产精品一区在线观看你懂的| 久久久久青草大香线综合精品| 国产美女视频91| 国产精品亲子伦对白| 91丝袜美女网| 午夜久久久久久久久久一区二区| 欧美日韩大陆在线| 美脚の诱脚舐め脚责91| 久久色中文字幕| 成人18精品视频| 一区二区在线观看不卡| 欧美日本国产视频| 另类小说一区二区三区| 国产欧美日韩精品一区| 99这里只有精品| 五月婷婷另类国产| 26uuu亚洲婷婷狠狠天堂| 国产成人免费视频一区| 亚洲久本草在线中文字幕| 69av一区二区三区| 国产一区二区h| 最新成人av在线| 91精品国产91久久久久久最新毛片| 狠狠色丁香久久婷婷综合_中| 国产精品欧美精品| 欧美精品777| 国产a区久久久| 亚洲bt欧美bt精品|