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

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

?? plotter.cpp

?? QT4 gui programming的隨書光盤
?? CPP
字號(hào):
#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;}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
蜜芽一区二区三区| 国产不卡在线视频| 精品国产百合女同互慰| 成人av第一页| 国产一区在线视频| 日韩精品乱码av一区二区| 国产精品视频在线看| 91精品国产综合久久香蕉的特点| eeuss鲁一区二区三区| 久久精品国产99| 亚洲电影第三页| 综合久久国产九一剧情麻豆| 国产视频视频一区| 日韩一区二区在线看| 欧美午夜一区二区三区免费大片| 成人免费不卡视频| 国产一区二区三区黄视频 | 色婷婷精品久久二区二区蜜臀av| 国产麻豆精品一区二区| 免费在线成人网| 一区二区三区在线观看视频| 中文字幕第一区第二区| 2014亚洲片线观看视频免费| 欧美一区二区免费观在线| 欧美视频在线一区二区三区| 色综合网站在线| 91首页免费视频| 99国产精品99久久久久久| 成人综合婷婷国产精品久久| 国产成人亚洲综合a∨猫咪| 激情五月婷婷综合| 精品在线观看免费| 久久成人免费电影| 精品夜夜嗨av一区二区三区| 久久精品免费看| 精品一区二区三区免费视频| 九九热在线视频观看这里只有精品| 日韩电影免费一区| 亚洲欧洲国产日本综合| 亚洲欧美综合色| 久久久久国产一区二区三区四区| 欧美一级高清片在线观看| 欧美日韩一二三| 欧美性生活久久| 91久久精品一区二区三| 99久久99久久精品免费看蜜桃| 成人av高清在线| 91网上在线视频| 日本道色综合久久| 欧美日韩一区精品| 91精品国产综合久久久蜜臀粉嫩 | 午夜成人在线视频| 午夜精品久久久久久不卡8050| 亚洲国产视频直播| 五月婷婷激情综合网| www.日本不卡| 蜜桃av一区二区三区电影| 蜜臀av性久久久久蜜臀aⅴ四虎| 日韩精品久久久久久| 蜜桃av一区二区| 国产在线精品一区二区夜色| 国产一区二三区| 成人国产一区二区三区精品| 91免费观看视频| 欧美久久久久久久久| 日韩欧美国产综合一区| 国产亚洲欧美日韩日本| 国产精品麻豆视频| 亚洲一级二级在线| 麻豆免费精品视频| 成人黄色小视频| 欧美美女一区二区三区| www激情久久| 一区二区三区在线免费视频| 日韩电影在线看| 豆国产96在线|亚洲| 欧美在线观看18| 久久婷婷国产综合精品青草| 亚洲欧洲精品成人久久奇米网| 午夜欧美一区二区三区在线播放| 精品一区二区在线视频| 91小视频免费看| 日韩欧美一区电影| 91首页免费视频| 99国产精品久久久久| 欧美日韩综合不卡| 久久在线免费观看| 亚洲一区二区视频| 国产精品亚洲专一区二区三区| 色综合久久久久网| 亚洲精品一区二区三区99| 一区二区三区av电影 | 日本三级韩国三级欧美三级| 国产91精品一区二区麻豆网站| 欧美在线看片a免费观看| 国产网站一区二区| 日韩av高清在线观看| 99久久99久久精品国产片果冻| 日韩免费福利电影在线观看| 亚洲男人都懂的| 国产成人在线看| 91精品婷婷国产综合久久竹菊| 日韩美女精品在线| 精品一区二区三区不卡| 欧美老人xxxx18| 免费三级欧美电影| 日本韩国欧美在线| 在线观看亚洲精品视频| 91麻豆精品国产91久久久使用方法| 国产午夜精品久久久久久久| 日韩激情一二三区| 色嗨嗨av一区二区三区| 中文幕一区二区三区久久蜜桃| 美日韩黄色大片| 欧美精品久久久久久久久老牛影院| 中文字幕一区二区三区精华液 | 日韩三级中文字幕| 亚洲一区在线观看视频| 99精品欧美一区二区三区小说| 精品播放一区二区| 美国毛片一区二区三区| 欧美高清视频一二三区| 亚洲电影第三页| 欧美专区在线观看一区| 亚洲欧洲综合另类| 99精品视频一区二区三区| 国产亚洲成aⅴ人片在线观看| 精品在线播放免费| 精品日产卡一卡二卡麻豆| 男人操女人的视频在线观看欧美 | 久久久久久久av麻豆果冻| 日本一不卡视频| 欧美一区二区精品在线| 成人一区在线看| 国产性天天综合网| 精品一区二区免费在线观看| 日韩亚洲欧美中文三级| 日韩电影一区二区三区| 亚洲色图欧美偷拍| 99国产精品久| 一区二区三区美女| 欧美自拍偷拍一区| 亚洲一区二区三区四区在线| 欧美综合在线视频| 天天综合日日夜夜精品| 91精品黄色片免费大全| 久久99精品国产麻豆婷婷洗澡| 欧美大尺度电影在线| 国产在线播放一区三区四| 久久青草欧美一区二区三区| 国产精品1区2区3区在线观看| 国产网站一区二区| 91视频你懂的| 亚洲一区av在线| 欧美成人精品3d动漫h| 国产一区二区三区不卡在线观看 | 午夜精品福利一区二区蜜股av | 日韩vs国产vs欧美| 精品99999| 成人激情图片网| 午夜精品福利久久久| 欧美色成人综合| 亚洲国产精品综合小说图片区| 欧美日韩成人综合天天影院 | 国产一区二区三区免费看| 国产精品网站导航| 91精品1区2区| 麻豆国产欧美一区二区三区| 久久久五月婷婷| 色婷婷综合久久久久中文| 日本不卡一二三| 国产精品网站导航| 欧美高清你懂得| 国产成人高清在线| 亚洲一卡二卡三卡四卡| 2023国产精品自拍| 色婷婷亚洲精品| 狠狠色综合日日| 一区二区三区免费网站| 精品乱人伦小说| 91久久久免费一区二区| 狠狠狠色丁香婷婷综合激情| 亚洲视频综合在线| 欧美www视频| 91啦中文在线观看| 久草精品在线观看| 亚洲午夜久久久久久久久电影院| 久久综合久久综合九色| 日本丶国产丶欧美色综合| 国产一区二区三区最好精华液| 亚洲综合丁香婷婷六月香| 久久久综合视频| 制服视频三区第一页精品| eeuss国产一区二区三区| 久久不见久久见中文字幕免费| 一区二区三区在线看| 久久精品视频免费观看| 9191久久久久久久久久久| 99久久99久久精品免费看蜜桃 | a级高清视频欧美日韩|