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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? spreadsheet.cpp

?? 關于嵌入式的QT圖形用戶界面C GUI Programming with QT4書籍的配套源碼
?? CPP
字號:
#include <QtGui>#include "cell.h"#include "spreadsheet.h"Spreadsheet::Spreadsheet(QWidget *parent)    : QTableWidget(parent){    autoRecalc = true;    setItemPrototype(new Cell);    setSelectionMode(ContiguousSelection);    connect(this, SIGNAL(itemChanged(QTableWidgetItem *)),            this, SLOT(somethingChanged()));    clear();}QString Spreadsheet::currentLocation() const{    return QChar('A' + currentColumn())           + QString::number(currentRow() + 1);}QString Spreadsheet::currentFormula() const{    return formula(currentRow(), currentColumn());}QTableWidgetSelectionRange Spreadsheet::selectedRange() const{    QList<QTableWidgetSelectionRange> ranges = selectedRanges();    if (ranges.isEmpty())        return QTableWidgetSelectionRange();    return ranges.first();}void Spreadsheet::clear(){    setRowCount(0);    setColumnCount(0);    setRowCount(RowCount);    setColumnCount(ColumnCount);    for (int i = 0; i < ColumnCount; ++i) {        QTableWidgetItem *item = new QTableWidgetItem;        item->setText(QString(QChar('A' + i)));        setHorizontalHeaderItem(i, item);    }    setCurrentCell(0, 0);}bool Spreadsheet::readFile(const QString &fileName){    QFile file(fileName);    if (!file.open(QIODevice::ReadOnly)) {        QMessageBox::warning(this, tr("Spreadsheet"),                             tr("Cannot read file %1:\n%2.")                             .arg(file.fileName())                             .arg(file.errorString()));        return false;    }    QDataStream in(&file);    in.setVersion(QDataStream::Qt_4_1);    quint32 magic;    in >> magic;    if (magic != MagicNumber) {        QMessageBox::warning(this, tr("Spreadsheet"),                             tr("The file is not a Spreadsheet file."));        return false;    }    clear();    quint16 row;    quint16 column;    QString str;    QApplication::setOverrideCursor(Qt::WaitCursor);    while (!in.atEnd()) {        in >> row >> column >> str;        setFormula(row, column, str);    }    QApplication::restoreOverrideCursor();    return true;}bool Spreadsheet::writeFile(const QString &fileName){    QFile file(fileName);    if (!file.open(QIODevice::WriteOnly)) {        QMessageBox::warning(this, tr("Spreadsheet"),                             tr("Cannot write file %1:\n%2.")                             .arg(file.fileName())                             .arg(file.errorString()));        return false;    }    QDataStream out(&file);    out.setVersion(QDataStream::Qt_4_1);    out << quint32(MagicNumber);    QApplication::setOverrideCursor(Qt::WaitCursor);    for (int row = 0; row < RowCount; ++row) {        for (int column = 0; column < ColumnCount; ++column) {            QString str = formula(row, column);            if (!str.isEmpty())                out << quint16(row) << quint16(column) << str;        }    }    QApplication::restoreOverrideCursor();    return true;}void Spreadsheet::sort(const SpreadsheetCompare &compare){    QList<QStringList> rows;    QTableWidgetSelectionRange range = selectedRange();    int i;    for (i = 0; i < range.rowCount(); ++i) {        QStringList row;        for (int j = 0; j < range.columnCount(); ++j)            row.append(formula(range.topRow() + i,                               range.leftColumn() + j));        rows.append(row);    }    qStableSort(rows.begin(), rows.end(), compare);    for (i = 0; i < range.rowCount(); ++i) {        for (int j = 0; j < range.columnCount(); ++j)            setFormula(range.topRow() + i, range.leftColumn() + j,                       rows[i][j]);    }    clearSelection();    somethingChanged();}void Spreadsheet::cut(){    copy();    del();}void Spreadsheet::copy(){    QTableWidgetSelectionRange range = selectedRange();    QString str;    for (int i = 0; i < range.rowCount(); ++i) {        if (i > 0)            str += "\n";        for (int j = 0; j < range.columnCount(); ++j) {            if (j > 0)                str += "\t";            str += formula(range.topRow() + i, range.leftColumn() + j);        }    }    QApplication::clipboard()->setText(str);}void Spreadsheet::paste(){    QTableWidgetSelectionRange range = selectedRange();    QString str = QApplication::clipboard()->text();    QStringList rows = str.split('\n');    int numRows = rows.count();    int numColumns = rows.first().count('\t') + 1;    if (range.rowCount() * range.columnCount() != 1            && (range.rowCount() != numRows                || range.columnCount() != numColumns)) {        QMessageBox::information(this, tr("Spreadsheet"),                tr("The information cannot be pasted because the copy "                   "and paste areas aren't the same size."));        return;    }    for (int i = 0; i < numRows; ++i) {        QStringList columns = rows[i].split('\t');        for (int j = 0; j < numColumns; ++j) {            int row = range.topRow() + i;            int column = range.leftColumn() + j;            if (row < RowCount && column < ColumnCount)                setFormula(row, column, columns[j]);        }    }    somethingChanged();}void Spreadsheet::del(){    foreach (QTableWidgetItem *item, selectedItems())        delete item;}void Spreadsheet::selectCurrentRow(){    selectRow(currentRow());}void Spreadsheet::selectCurrentColumn(){    selectColumn(currentColumn());}void Spreadsheet::recalculate(){    for (int row = 0; row < RowCount; ++row) {        for (int column = 0; column < ColumnCount; ++column) {            if (cell(row, column))                cell(row, column)->setDirty();        }    }    viewport()->update();}void Spreadsheet::setAutoRecalculate(bool recalc){    autoRecalc = recalc;    if (autoRecalc)        recalculate();}void Spreadsheet::findNext(const QString &str, Qt::CaseSensitivity cs){    int row = currentRow();    int column = currentColumn() + 1;    while (row < RowCount) {        while (column < ColumnCount) {            if (text(row, column).contains(str, cs)) {                clearSelection();                setCurrentCell(row, column);                activateWindow();                return;            }            ++column;        }        column = 0;        ++row;    }    QApplication::beep();}void Spreadsheet::findPrevious(const QString &str,                               Qt::CaseSensitivity cs){    int row = currentRow();    int column = currentColumn() - 1;    while (row >= 0) {        while (column >= 0) {            if (text(row, column).contains(str, cs)) {                clearSelection();                setCurrentCell(row, column);                activateWindow();                return;            }            --column;        }        column = ColumnCount - 1;        --row;    }    QApplication::beep();}void Spreadsheet::somethingChanged(){    if (autoRecalc)        recalculate();    emit modified();}Cell *Spreadsheet::cell(int row, int column) const{    return static_cast<Cell *>(item(row, column));}void Spreadsheet::setFormula(int row, int column,                             const QString &formula){    Cell *c = cell(row, column);    if (!c) {        c = new Cell;        setItem(row, column, c);    }    c->setFormula(formula);}QString Spreadsheet::formula(int row, int column) const{    Cell *c = cell(row, column);    if (c) {        return c->formula();    } else {        return "";    }}QString Spreadsheet::text(int row, int column) const{    Cell *c = cell(row, column);    if (c) {        return c->text();    } else {        return "";    }}bool SpreadsheetCompare::operator()(const QStringList &row1,                                    const QStringList &row2) const{    for (int i = 0; i < KeyCount; ++i) {        int column = keys[i];        if (column != -1) {            if (row1[column] != row2[column]) {                if (ascending[i]) {                    return row1[column] < row2[column];                } else {                    return row1[column] > row2[column];                }            }        }    }    return false;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美亚洲一区二区在线观看| 久久99精品网久久| 国产成人久久精品77777最新版本| 在线观看不卡一区| 久久久综合网站| 六月丁香综合在线视频| 欧美三级欧美一级| 18成人在线观看| 99免费精品在线| 国产清纯美女被跳蛋高潮一区二区久久w | 欧美精品一区二| 丝袜亚洲另类丝袜在线| 欧美亚洲国产一卡| 亚洲精品视频免费观看| av中文一区二区三区| 亚洲国产电影在线观看| 国产成人自拍高清视频在线免费播放| 欧美高清视频一二三区 | 亚洲免费观看高清在线观看| 国产成人精品亚洲日本在线桃色| 精品国产乱码久久久久久夜甘婷婷| 香蕉加勒比综合久久| 欧美欧美午夜aⅴ在线观看| 亚洲成人av电影在线| 欧美日韩一区二区三区不卡| 一个色在线综合| 欧美精品电影在线播放| 香蕉成人啪国产精品视频综合网| 欧美日韩综合色| 另类调教123区| 国产午夜精品一区二区三区嫩草 | 久久99蜜桃精品| 国产婷婷精品av在线| 91在线国产福利| 香蕉乱码成人久久天堂爱免费| 5566中文字幕一区二区电影| 蜜乳av一区二区| 国产精品伦理在线| 欧美三级午夜理伦三级中视频| 免费黄网站欧美| 国产视频911| 久久综合色婷婷| 不卡的电视剧免费网站有什么| 亚洲日本在线a| 日韩欧美精品在线视频| 成人av网站在线| 青青草97国产精品免费观看无弹窗版 | 91成人免费电影| 国产一区二区在线观看免费| 一区二区久久久久| 国产精品丝袜久久久久久app| 色噜噜久久综合| 国产精品一区一区三区| 亚洲制服丝袜在线| 国产精品日产欧美久久久久| 欧美午夜电影网| 成人福利视频网站| 久久爱另类一区二区小说| 日韩福利视频网| 国产成人超碰人人澡人人澡| a在线播放不卡| 国产日韩精品一区二区三区 | 国产在线视频不卡二| 亚洲午夜久久久久久久久久久 | 日本高清不卡在线观看| 国产在线精品免费av| 日韩1区2区日韩1区2区| 亚洲猫色日本管| 国产精品私房写真福利视频| 久久众筹精品私拍模特| 精品国产乱码久久久久久闺蜜| 欧美伦理电影网| 欧美日韩在线三级| 欧美视频你懂的| 777午夜精品免费视频| 欧美日韩午夜在线| 欧美日本一区二区三区四区| 91行情网站电视在线观看高清版| 波多野结衣亚洲| 99国产欧美另类久久久精品| 国产高清在线精品| av电影一区二区| 99r国产精品| 欧美视频在线不卡| 91精品国产美女浴室洗澡无遮挡| 日韩一级二级三级| 久久久久久麻豆| 一区在线中文字幕| 一区二区三区成人在线视频 | 99综合电影在线视频| 欧洲色大大久久| 日韩欧美视频一区| 欧美激情一区三区| 亚洲国产美女搞黄色| 美腿丝袜一区二区三区| 成人性视频网站| 精品免费国产一区二区三区四区| 久久一区二区视频| 一区二区在线观看av| 日本视频中文字幕一区二区三区 | 欧美精品v国产精品v日韩精品| 日韩一区二区视频| 国产精品麻豆久久久| 性久久久久久久久| 成人在线视频一区二区| 在线精品亚洲一区二区不卡| 久久综合狠狠综合久久综合88| |精品福利一区二区三区| 美国十次了思思久久精品导航| 不卡av在线免费观看| 欧美一区二区免费观在线| 国产精品成人一区二区艾草| 日韩av电影免费观看高清完整版在线观看| 国产精品久久久久久久久久免费看 | 1024成人网色www| 欧美aⅴ一区二区三区视频| 95精品视频在线| 久久久一区二区三区| 奇米色777欧美一区二区| 在线一区二区视频| 综合亚洲深深色噜噜狠狠网站| 国产一区在线观看视频| 7777精品伊人久久久大香线蕉的| 一区二区欧美在线观看| 成人免费看视频| 国产精品视频一区二区三区不卡| 日本不卡中文字幕| 中文字幕 久热精品 视频在线| 日本视频免费一区| 欧美日韩二区三区| 亚洲一区欧美一区| 一本色道久久综合狠狠躁的推荐| 久久久影视传媒| 国产成人啪免费观看软件| 欧美精品一区二区精品网| 日本不卡视频在线| 欧美一区二区三区四区视频 | 欧美影片第一页| 亚洲一区在线看| 欧美日韩一区高清| 视频在线观看91| 欧美一区日本一区韩国一区| 蜜桃视频免费观看一区| 久久一区二区视频| av中文字幕不卡| 亚洲成人激情自拍| 日韩一区二区免费电影| 国内精品久久久久影院色| 久久久精品tv| 色婷婷久久综合| 午夜精品一区二区三区免费视频| 欧美一区二区三区人| 国产传媒欧美日韩成人| 国产精品精品国产色婷婷| 欧美日韩aaa| 国产91丝袜在线播放| 亚洲成人一二三| 久久久高清一区二区三区| 色婷婷激情综合| 美女在线一区二区| 亚洲免费观看高清完整版在线| 91精品国产综合久久久久久漫画| 国产成人av福利| 天堂在线一区二区| 日韩电影在线观看一区| 久久青草国产手机看片福利盒子| 在线免费亚洲电影| 国产一区二区福利| 日韩国产精品久久久久久亚洲| 久久精品男人的天堂| 欧美精品一卡二卡| 99re亚洲国产精品| 极品少妇xxxx精品少妇| 亚洲国产毛片aaaaa无费看| 国产日韩欧美激情| 日韩欧美一区二区三区在线| 91麻豆swag| 成人小视频免费在线观看| 青青草国产精品亚洲专区无| 亚洲最色的网站| 亚洲少妇最新在线视频| 国产午夜精品一区二区| 欧美一级一区二区| 欧美精品自拍偷拍| 欧美日韩视频在线一区二区 | 国产成人精品一区二区三区网站观看| 天天色天天爱天天射综合| 亚洲一区二区精品久久av| 一区二区三区丝袜| 亚洲欧洲综合另类| 一区二区三区av电影| 亚洲卡通欧美制服中文| 中文字幕亚洲不卡| 国产精品久久久爽爽爽麻豆色哟哟| 精品欧美乱码久久久久久| 欧美成人午夜电影| 久久久精品综合| 国产精品麻豆99久久久久久| 中文字幕在线观看不卡视频| 一区在线观看视频|