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

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

?? plotter.cpp

?? linux環(huán)境下利用QT4做的一個(gè)小程序
?? 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一区二区三区免费野_久草精品视频
日韩一区在线看| 国产欧美一区二区精品秋霞影院 | 成人美女视频在线看| 欧美va在线播放| 国产高清亚洲一区| 中文字幕中文字幕一区| 色屁屁一区二区| 丝袜美腿亚洲综合| 精品免费视频一区二区| 国产福利一区在线| 亚洲柠檬福利资源导航| 欧美日韩五月天| 美女视频黄久久| 欧美国产精品久久| 91久久久免费一区二区| 天天色综合成人网| 精品国产乱码久久久久久免费| 国产不卡在线一区| 一区二区三区在线影院| 日韩精品一区二区在线| av一本久道久久综合久久鬼色| 亚洲综合视频网| 久久夜色精品一区| 欧洲av在线精品| 狠狠色丁香久久婷婷综| 一区免费观看视频| 日韩欧美国产一区二区在线播放| 国产99久久久国产精品| 亚洲高清一区二区三区| 欧美—级在线免费片| 欧美日韩中文一区| 成人免费看片app下载| 日韩精品电影一区亚洲| 国产精品视频yy9299一区| 欧美夫妻性生活| 懂色av噜噜一区二区三区av| 日韩中文字幕亚洲一区二区va在线 | 色视频欧美一区二区三区| 蜜臀精品久久久久久蜜臀| 国产精品三级av| 日韩欧美国产系列| 欧美在线你懂得| 成人妖精视频yjsp地址| 日韩在线观看一区二区| 亚洲精品伦理在线| 国产日韩欧美激情| 日韩视频在线你懂得| 色综合中文字幕国产| 久久精品国产77777蜜臀| 一区二区三区免费网站| 国产精品免费观看视频| 26uuu色噜噜精品一区二区| 欧美三级午夜理伦三级中视频| 波多野结衣91| 风间由美一区二区三区在线观看| 美女国产一区二区三区| 亚洲第四色夜色| 亚洲精品视频自拍| 国产精品高潮久久久久无| 日韩精品一区二区三区视频在线观看| 欧美在线免费播放| 日本道免费精品一区二区三区| 国产91精品精华液一区二区三区| 青椒成人免费视频| 亚洲va欧美va人人爽午夜| 亚洲精品国产精华液| 亚洲欧美日韩精品久久久久| 日本一区二区高清| 久久精品综合网| 国产香蕉久久精品综合网| 国产亚洲精品中文字幕| 亚洲精品在线观看网站| 精品国产免费一区二区三区四区| 日韩欧美中文一区| 日韩欧美激情在线| 精品对白一区国产伦| 欧美精品一区视频| 久久蜜桃av一区二区天堂| 国产亚洲综合性久久久影院| 国产无一区二区| 国产精品成人网| 亚洲激情图片一区| 亚洲黄色性网站| 亚洲综合一区二区精品导航| 亚洲午夜久久久久久久久电影网| 亚洲电影你懂得| 午夜精品久久久久久久久久| 婷婷中文字幕综合| 免费成人在线影院| 国产精品一二一区| 99久久777色| 在线看日本不卡| 欧美一级欧美一级在线播放| 欧美大肚乱孕交hd孕妇| 久久久久国产一区二区三区四区 | 日韩欧美亚洲国产另类| 精品欧美一区二区久久 | 欧美成人女星排行榜| 久久日一线二线三线suv| 国产欧美久久久精品影院| 亚洲欧洲99久久| 亚洲综合区在线| 精品一二三四区| 99re视频精品| 在线不卡的av| 国产三级精品三级在线专区| 一区二区理论电影在线观看| 欧美aⅴ一区二区三区视频| 国产美女精品在线| 在线一区二区三区| 精品久久久久久无| 亚洲人成在线观看一区二区| 日韩电影在线一区| 成人精品国产福利| 69久久99精品久久久久婷婷| 国产婷婷一区二区| 亚洲福利一区二区| 国产成人av影院| 欧美精品第1页| 国产精品国产三级国产普通话99| 日本欧美一区二区| 91原创在线视频| 26uuu另类欧美| 亚洲国产日日夜夜| 成人黄色av网站在线| 日韩欧美另类在线| 亚洲一区二区在线视频| 国产黑丝在线一区二区三区| 欧美在线影院一区二区| 亚洲国产成人一区二区三区| 日韩电影一二三区| 色综合色综合色综合| 久久女同互慰一区二区三区| 午夜欧美一区二区三区在线播放| 春色校园综合激情亚洲| 欧美mv日韩mv| 日韩高清在线电影| 欧美视频中文字幕| 视频一区二区三区入口| 成人a免费在线看| 久久综合狠狠综合| 美女在线视频一区| 欧美日韩综合一区| 亚洲乱码国产乱码精品精小说 | 在线免费观看视频一区| 国产欧美综合色| 韩国理伦片一区二区三区在线播放| 欧美日韩在线播放三区| 亚洲精品乱码久久久久| 99久久综合狠狠综合久久| www激情久久| 美女视频一区二区三区| 欧美日韩精品系列| 一区二区在线看| 色婷婷av一区二区三区gif| 国产欧美视频在线观看| 国产成人综合在线观看| 久久亚洲一级片| 国内精品不卡在线| 精品精品国产高清a毛片牛牛 | 久久成人久久鬼色| 欧美一区二区在线看| 午夜精品爽啪视频| 欧美精品日韩一本| 亚洲超丰满肉感bbw| 欧美日韩美少妇| 亚洲h动漫在线| 欧美精品在线一区二区三区| 亚洲成va人在线观看| 欧美日韩国产影片| 视频精品一区二区| 欧美日韩国产精选| 视频一区国产视频| 欧美成人vps| 国产在线精品免费av| 国产欧美精品一区aⅴ影院| 丁香啪啪综合成人亚洲小说 | 亚洲综合999| 精品婷婷伊人一区三区三| 丝袜脚交一区二区| 日韩美女视频一区二区在线观看| 91九色02白丝porn| 天堂一区二区在线免费观看| 在线不卡欧美精品一区二区三区| 美女久久久精品| 国产欧美精品国产国产专区| 成人免费av在线| 亚洲综合视频网| 欧美成人高清电影在线| 夫妻av一区二区| 亚洲一二三专区| 日韩一级免费一区| 国产成人免费在线观看| 日韩理论片中文av| 欧美日韩精品欧美日韩精品一综合| 久久国产精品99久久久久久老狼| 久久久久久免费网| 色爱区综合激月婷婷| 日本亚洲免费观看| 国产精品人成在线观看免费|