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

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

?? dictionarymodel.cpp

?? Qt開發的GRE背單詞軟件
?? CPP
字號:
#include "DictionaryModel.h"
#include "Library.h"
#include <QtSql/QSqlQuery>

DictionaryModel::DictionaryModel(QObject *parent, const QString& user) : 
	QSqlTableModel(parent), 
	userName(user),
	recite(false),
	upper(false),
	newWordColor   (Qt::red),
	unfamiliarColor(Qt::darkGray),
	familiarColor  (Qt::darkGreen) {}

void DictionaryModel::setDictionary(const QString& d)
{
	setTable(dictName = d);
	copyCredits();
	select();
}

void DictionaryModel::setShowChinese(bool show, int row)
{
	rowBeShowed = show ? row : -1;   // -1 makes this row invisible
	dataChanged(index(rowBeShowed, CHINESE), index(rowBeShowed, CHINESE));  // refresh
}

QVariant DictionaryModel::data(const QModelIndex &idx, int role) const
{
	if(role == Qt::DisplayRole)
	{
		if(idx.column() == ENGLISH)
			if(upper)
				return QSqlTableModel::data(idx, role).toString().toUpper();
		if(idx.column() == CHINESE)
			if(recite && idx.row() != rowBeShowed)  // -1 makes this row invisible
				return QString();
	}
	else if(role == Qt::TextColorRole)
	{
		if(idx.column() == ENGLISH)
		{
			int credit = getCredit(idx.row());
			if(credit < filter.threshold1)
				return newWordColor;
			if(credit >= filter.threshold2)
				return familiarColor;
			else
				return unfamiliarColor;
		}
	}
	
	return QSqlTableModel::data(idx, role);
}

bool DictionaryModel::setData(const QModelIndex& idx, const QVariant& value, int role)
{
	if(idx.column() == CREDIT && role == Qt::EditRole)  // to user table
		Library::setCredit(dictName, userName, getEnglish(idx.row()), value.toInt());
	return QSqlTableModel::setData(idx, value, role);
}

QString DictionaryModel::getFilterString(const Filter& flt) {
	return tr("%1 AND %2").arg(getUnitRangeFilter(flt)).arg(getCreditRangeFilter(flt));
}

QString DictionaryModel::getUnitRangeFilter(const Filter& flt)
{
	const int minID = flt.unitSize * (flt.currentUnit - 1) + 1;
	const int maxID = flt.unitSize * flt.currentUnit;
	return tr("(編號 BETWEEN %1 AND %2)").arg(minID).arg(maxID);
}

QString DictionaryModel::getCreditRangeFilter(const Filter& flt)
{
	QStringList clauses;
	if(flt.showNew)
		clauses << tr("(得分<%1)").arg(flt.threshold1);
	if(flt.showUnFamiliar)
		clauses << tr("(得分 BETWEEN %1 AND %2)").arg(flt.threshold1).arg(flt.threshold2-1);
	if(flt.showFamiliar)
		clauses << tr("(得分>=%1)").arg(flt.threshold2);
	return "(" + clauses.join(tr(" OR ")) + ")";
}

void DictionaryModel::updateFilter(const Filter& flt)
{
	filter = flt;
	setFilter(getFilterString(filter));
}

int DictionaryModel::getID(int row) const {
	return data(index(row, ID)).toInt();
}
QString DictionaryModel::getEnglish(int row, bool origional) const {
	return origional ? QSqlQueryModel::data(index(row, ENGLISH)).toString()
					 : data(index(row, ENGLISH)).toString();
}
QString DictionaryModel::getChinese(int row) const {
	return data(index(row, CHINESE)).toString();
}
QString DictionaryModel::getPhonetic(int row) const {
	return data(index(row, PHONETIC)).toString();
}
QString DictionaryModel::getNote(int row) const {
	return data(index(row, NOTE)).toString();
}
QString DictionaryModel::getEnglishColor(int row) const {
	return data(index(row, ENGLISH), Qt::TextColorRole).toString();
}
int DictionaryModel::getCredit(int row) const {
	return data(index(row, CREDIT)).toInt();
}

void DictionaryModel::shuffle()
{
	QSqlQuery query;
	query.exec(tr("UPDATE %1 SET 排序=random() WHERE %2").arg(dictName)
														 .arg(getUnitRangeFilter(filter)));
	sort(SORTING, Qt::AscendingOrder);
}

int DictionaryModel::getWordCount(bool newWords, bool unfamiliar, bool familiar) const
{
	Filter flt = filter;
	flt.showNew        = newWords;
	flt.showUnFamiliar = unfamiliar;
	flt.showFamiliar   = familiar;
	QSqlQuery query;
	query.exec(tr("SELECT count(編號) FROM %1 WHERE %2").arg(dictName)
														.arg(getFilterString(flt)));
	return query.next() ? query.value(0).toInt() : 0;
}

int DictionaryModel::getNewWordCount() const {
	return getWordCount(true, false, false);
}
int DictionaryModel::getUnfamiliarCount() const {
	return getWordCount(false, true, false);
}
int DictionaryModel::getFamiliarCount() const {
	return getWordCount(false, false, true);
}

// copy credits from user table to dictionary table
void DictionaryModel::copyCredits()
{
	QSqlQuery query;
	query.exec(tr("UPDATE %1 SET 得分=0").arg(dictName));
	query.exec(tr("UPDATE %1 SET 得分=(SELECT %2.credit FROM %2 WHERE %2.word=%1.單詞) \
				   WHERE 單詞 in (SELECT word FROM %1, %2 WHERE %2.word=%1.單詞)")
				   .arg(dictName).arg(userName));
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲成在人线免费| 91麻豆免费看片| 成人午夜免费电影| 欧美日韩精品综合在线| 久久久精品免费网站| 亚洲午夜久久久久久久久电影网| 国产一区二区看久久| 91久久免费观看| 中文字幕乱码久久午夜不卡 | 久久久蜜桃精品| 亚洲综合色在线| 成人a级免费电影| 2023国产精华国产精品| 五月婷婷色综合| 色天天综合色天天久久| 国产女人aaa级久久久级| 久久精品国产亚洲aⅴ| 欧美在线观看一区二区| 中文字幕一区二区在线播放 | 亚欧色一区w666天堂| 99精品热视频| 国产精品毛片久久久久久| 久久草av在线| 欧美精品vⅰdeose4hd| 亚洲黄网站在线观看| 成人黄色国产精品网站大全在线免费观看 | 欧美精品日日鲁夜夜添| 中文字幕中文乱码欧美一区二区 | 波多野结衣欧美| 久久影院午夜论| 久久91精品久久久久久秒播| 欧美日韩精品系列| 亚洲欧美日韩一区二区| zzijzzij亚洲日本少妇熟睡| 精品99一区二区| 亚洲电影一级黄| 91成人在线精品| 国产精品久久久久一区二区三区 | 成人一区二区在线观看| wwwwxxxxx欧美| 紧缚奴在线一区二区三区| 欧美成人一区二区三区在线观看| 男男视频亚洲欧美| 日韩限制级电影在线观看| 欧美bbbbb| 久久久精品tv| youjizz国产精品| 最新日韩av在线| xf在线a精品一区二区视频网站| 日日噜噜夜夜狠狠视频欧美人| 欧美色视频在线| 日本网站在线观看一区二区三区 | 欧美一级一区二区| 久久爱www久久做| 欧美激情一区不卡| 97精品国产97久久久久久久久久久久| 专区另类欧美日韩| 欧美日韩一区视频| 久久99久久精品| 国产精品久久久久国产精品日日| 色综合中文字幕| 免费在线看一区| 欧美高清在线精品一区| 91久久精品一区二区二区| 丝袜诱惑亚洲看片| 久久久精品免费免费| 91国偷自产一区二区三区成为亚洲经典 | 日本怡春院一区二区| 久久久亚洲午夜电影| 在线免费观看视频一区| 九一九一国产精品| 亚洲在线免费播放| 久久久久国产精品人| 欧美性色欧美a在线播放| 国精品**一区二区三区在线蜜桃| 国产一区二区三区久久久| 一区在线中文字幕| 日韩欧美高清一区| 色8久久精品久久久久久蜜| 黄色精品一二区| 亚洲成人自拍一区| 国产精品免费人成网站| 日韩欧美激情一区| 一本久久精品一区二区| 国产精品996| 日本女人一区二区三区| 亚洲免费观看高清| 久久精品一二三| 日韩一区二区三| 欧美色窝79yyyycom| 国产69精品久久99不卡| 日本成人在线不卡视频| 一区二区成人在线视频| 中文字幕精品一区| 久久奇米777| 日韩免费一区二区| 欧美高清www午色夜在线视频| 99久久777色| 成人av集中营| 粉嫩av亚洲一区二区图片| 精品在线一区二区| 美女诱惑一区二区| 偷偷要91色婷婷| 亚洲丰满少妇videoshd| 亚洲精品日韩一| 国产精品福利一区二区三区| 国产视频一区二区在线观看| 欧美精品一区视频| 日韩三级免费观看| 91精品国产综合久久福利| 欧美日韩视频不卡| 欧美日韩精品一区二区三区蜜桃| 色噜噜夜夜夜综合网| 精品国产乱码久久久久久1区2区 | 欧美精品亚洲二区| 欧美另类久久久品| 欧美美女一区二区| 欧洲日韩一区二区三区| 一本色道a无线码一区v| 欧美视频三区在线播放| 精品污污网站免费看| 欧美日韩激情在线| 这里只有精品99re| 日韩一区二区电影| 久久九九久精品国产免费直播| 久久久.com| 国产精品久久久久aaaa樱花| 亚洲精品成人少妇| 青青青伊人色综合久久| 国精产品一区一区三区mba视频| 国产精品羞羞答答xxdd| 9i在线看片成人免费| 91美女在线看| 欧美日韩中文字幕一区| 日韩欧美123| 国产女人18水真多18精品一级做| 国产精品久久久久婷婷二区次| 中文字幕精品综合| 亚洲二区在线观看| 国内久久精品视频| 99热精品国产| 在线播放日韩导航| 国产日韩欧美制服另类| 一区二区三区日韩欧美| 日本美女一区二区三区视频| 国产一区二区在线看| 91色九色蝌蚪| 亚洲一区二区四区蜜桃| 日韩精品高清不卡| 成人蜜臀av电影| 欧美日韩一区二区三区高清| 2020国产精品久久精品美国| 成人免费视频在线观看| 欧美aaaaa成人免费观看视频| 国产成人久久精品77777最新版本 国产成人鲁色资源国产91色综 | 日本一区二区不卡视频| 亚洲综合视频在线观看| 国产精品乡下勾搭老头1| 欧美在线视频不卡| 国产欧美日韩激情| 日本美女一区二区| 91丨九色丨蝌蚪丨老版| 精品免费日韩av| 亚洲一区二区三区视频在线 | 99re在线视频这里只有精品| 91精品国产全国免费观看 | 欧美巨大另类极品videosbest | 亚洲免费观看高清在线观看| 婷婷久久综合九色综合绿巨人| 成人三级伦理片| 欧美一区二区不卡视频| 亚洲欧美日韩系列| 国产一区二区三区香蕉 | 五月婷婷综合网| 91麻豆免费看| 国产欧美日韩在线| 免费国产亚洲视频| 欧美日韩视频在线观看一区二区三区| 国产精品天美传媒沈樵| 国产剧情av麻豆香蕉精品| 欧美精品日韩综合在线| 亚洲影视资源网| 91蜜桃免费观看视频| 欧美国产成人精品| 国产成人无遮挡在线视频| 欧美tk—视频vk| 日韩精品一区第一页| 欧美日韩精品一区二区三区 | 亚洲成a天堂v人片| 色综合久久中文综合久久97| 亚洲国产精品黑人久久久| 国产精品影音先锋| 久久婷婷成人综合色| 激情综合色播激情啊| 欧美xxxxx牲另类人与| 久久激情五月激情| 欧美电视剧在线看免费| 久久精品国产77777蜜臀| 精品噜噜噜噜久久久久久久久试看| 免费成人性网站|