mirror of
https://git.lyx.org/repos/lyx.git
synced 2025-01-11 19:14:51 +00:00
Use a custom model + QListView instead of QListWidget in the Symbols
dialog. Functionality is unchanged. Populating the 'All Symbols' panel for utf8 files is around 5s. Not nice, but bearable. There's still room for improvement. git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@23883 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
parent
7f02beb990
commit
0d5e1782f0
@ -160,8 +160,87 @@ QString getBlock(char_type c)
|
|||||||
} // namespace anon
|
} // namespace anon
|
||||||
|
|
||||||
|
|
||||||
|
/////////////////////////////////////////////////////////////////////
|
||||||
|
//
|
||||||
|
// GuiSymbols::Model
|
||||||
|
//
|
||||||
|
/////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
class GuiSymbols::Model : public QAbstractItemModel
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
Model(GuiSymbols * parent)
|
||||||
|
: QAbstractItemModel(parent), parent_(parent)
|
||||||
|
{}
|
||||||
|
|
||||||
|
QModelIndex index(int row, int column, QModelIndex const &) const
|
||||||
|
{
|
||||||
|
return createIndex(row, column);
|
||||||
|
}
|
||||||
|
|
||||||
|
QModelIndex parent(QModelIndex const &) const
|
||||||
|
{
|
||||||
|
return QModelIndex();
|
||||||
|
}
|
||||||
|
|
||||||
|
int rowCount(QModelIndex const &) const
|
||||||
|
{
|
||||||
|
return symbols_.count();
|
||||||
|
}
|
||||||
|
|
||||||
|
int columnCount(QModelIndex const &) const
|
||||||
|
{
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
QVariant data(QModelIndex const & index, int role) const
|
||||||
|
{
|
||||||
|
static QString const strCharacter = qt_("Character: ");
|
||||||
|
static QString const strCodePoint = qt_("Code Point: ");
|
||||||
|
|
||||||
|
static char codeName[10];
|
||||||
|
|
||||||
|
char_type c = symbols_.at(index.row());
|
||||||
|
|
||||||
|
if (role == Qt::TextAlignmentRole)
|
||||||
|
return QVariant(Qt::AlignCenter);
|
||||||
|
|
||||||
|
if (role == Qt::DisplayRole)
|
||||||
|
return toqstr(c);
|
||||||
|
|
||||||
|
if (role == Qt::ToolTipRole) {
|
||||||
|
sprintf(codeName, "0x%04x", c);
|
||||||
|
return strCharacter + toqstr(c) + '\n'
|
||||||
|
+ strCodePoint + QLatin1String(codeName);
|
||||||
|
}
|
||||||
|
|
||||||
|
//LYXERR0("role: " << role << " row: " << index.row());
|
||||||
|
return QVariant();
|
||||||
|
}
|
||||||
|
|
||||||
|
void reset(QList<char_type> const & symbols)
|
||||||
|
{
|
||||||
|
symbols_ = symbols;
|
||||||
|
QAbstractItemModel::reset();
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
friend class GuiSymbols;
|
||||||
|
GuiSymbols * parent_;
|
||||||
|
|
||||||
|
QList<char_type> symbols_;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
/////////////////////////////////////////////////////////////////////
|
||||||
|
//
|
||||||
|
// GuiSymbols
|
||||||
|
//
|
||||||
|
/////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
GuiSymbols::GuiSymbols(GuiView & lv)
|
GuiSymbols::GuiSymbols(GuiView & lv)
|
||||||
: DialogView(lv, "symbols", qt_("Symbols")), encoding_("ascii")
|
: DialogView(lv, "symbols", qt_("Symbols")), encoding_("ascii"),
|
||||||
|
model_(new Model(this))
|
||||||
{
|
{
|
||||||
setupUi(this);
|
setupUi(this);
|
||||||
|
|
||||||
@ -174,6 +253,7 @@ GuiSymbols::GuiSymbols(GuiView & lv)
|
|||||||
int size = font.pointSize() + 3;
|
int size = font.pointSize() + 3;
|
||||||
font.setPointSize(size);
|
font.setPointSize(size);
|
||||||
symbolsLW->setFont(font);
|
symbolsLW->setFont(font);
|
||||||
|
symbolsLW->setModel(model_);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -193,7 +273,7 @@ void GuiSymbols::updateView()
|
|||||||
bool const utf8 = toqstr(encoding_).startsWith("utf8");
|
bool const utf8 = toqstr(encoding_).startsWith("utf8");
|
||||||
if (utf8)
|
if (utf8)
|
||||||
categoryFilterCB->setChecked(false);
|
categoryFilterCB->setChecked(false);
|
||||||
categoryFilterCB->setEnabled(!utf8);
|
//categoryFilterCB->setEnabled(!utf8);
|
||||||
updateSymbolList();
|
updateSymbolList();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -225,7 +305,7 @@ void GuiSymbols::on_closePB_clicked()
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void GuiSymbols::on_symbolsLW_itemActivated(QListWidgetItem *)
|
void GuiSymbols::on_symbolsLW_activated(QModelIndex const &)
|
||||||
{
|
{
|
||||||
on_okPB_clicked();
|
on_okPB_clicked();
|
||||||
}
|
}
|
||||||
@ -245,9 +325,9 @@ void GuiSymbols::on_chosenLE_returnPressed()
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void GuiSymbols::on_symbolsLW_itemClicked(QListWidgetItem * item)
|
void GuiSymbols::on_symbolsLW_clicked(QModelIndex const & index)
|
||||||
{
|
{
|
||||||
QString const text = item->text();
|
QString const text = model_->data(index, Qt::DisplayRole).toString();
|
||||||
if (text.isEmpty())
|
if (text.isEmpty())
|
||||||
return;
|
return;
|
||||||
if (chosenLE->isEnabled())
|
if (chosenLE->isEnabled())
|
||||||
@ -291,7 +371,7 @@ void GuiSymbols::updateSymbolList(bool update_combo)
|
|||||||
bool const nocategory = category.isEmpty();
|
bool const nocategory = category.isEmpty();
|
||||||
char_type range_start = 0x0000;
|
char_type range_start = 0x0000;
|
||||||
char_type range_end = 0x110000;
|
char_type range_end = 0x110000;
|
||||||
symbolsLW->clear();
|
QList<char_type> s;
|
||||||
if (update_combo) {
|
if (update_combo) {
|
||||||
used_blocks.clear();
|
used_blocks.clear();
|
||||||
categoryCO->clear();
|
categoryCO->clear();
|
||||||
@ -310,10 +390,6 @@ void GuiSymbols::updateSymbolList(bool update_combo)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static char codeName[10];
|
|
||||||
static QString const strCharacter = qt_("Character: ");
|
|
||||||
static QString const strCodePoint = qt_("Code Point: ");
|
|
||||||
|
|
||||||
SymbolsList::const_iterator const end = symbols_.end();
|
SymbolsList::const_iterator const end = symbols_.end();
|
||||||
int numItem = 0;
|
int numItem = 0;
|
||||||
for (SymbolsList::const_iterator it = symbols_.begin(); it != end; ++it) {
|
for (SymbolsList::const_iterator it = symbols_.begin(); it != end; ++it) {
|
||||||
@ -329,15 +405,9 @@ void GuiSymbols::updateSymbolList(bool update_combo)
|
|||||||
// we do not want control or space characters
|
// we do not want control or space characters
|
||||||
if (cat == QChar::Other_Control || cat == QChar::Separator_Space)
|
if (cat == QChar::Other_Control || cat == QChar::Separator_Space)
|
||||||
continue;
|
continue;
|
||||||
QListWidgetItem * lwi = new QListWidgetItem(toqstr(c));
|
|
||||||
++numItem;
|
++numItem;
|
||||||
if (show_all || c >= range_start && c <= range_end) {
|
if (show_all || c >= range_start && c <= range_end)
|
||||||
sprintf(codeName, "0x%04x", c);
|
s.append(c);
|
||||||
lwi->setTextAlignment(Qt::AlignCenter);
|
|
||||||
lwi->setToolTip(strCharacter + toqstr(c) + '\n'
|
|
||||||
+ strCodePoint + QLatin1String(codeName));
|
|
||||||
symbolsLW->addItem(lwi);
|
|
||||||
}
|
|
||||||
if (update_combo) {
|
if (update_combo) {
|
||||||
QString block = getBlock(c);
|
QString block = getBlock(c);
|
||||||
if (category.isEmpty())
|
if (category.isEmpty())
|
||||||
@ -346,6 +416,7 @@ void GuiSymbols::updateSymbolList(bool update_combo)
|
|||||||
used_blocks[block] = numItem;
|
used_blocks[block] = numItem;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
model_->reset(s);
|
||||||
|
|
||||||
if (update_combo) {
|
if (update_combo) {
|
||||||
// update category combo
|
// update category combo
|
||||||
|
@ -18,8 +18,6 @@
|
|||||||
#include <map>
|
#include <map>
|
||||||
#include <set>
|
#include <set>
|
||||||
|
|
||||||
class QListWidgetItem;
|
|
||||||
|
|
||||||
namespace lyx {
|
namespace lyx {
|
||||||
namespace frontend {
|
namespace frontend {
|
||||||
|
|
||||||
@ -43,8 +41,8 @@ public Q_SLOTS:
|
|||||||
void on_applyPB_clicked();
|
void on_applyPB_clicked();
|
||||||
void on_okPB_clicked();
|
void on_okPB_clicked();
|
||||||
void on_closePB_clicked();
|
void on_closePB_clicked();
|
||||||
void on_symbolsLW_itemActivated(QListWidgetItem *);
|
void on_symbolsLW_activated(QModelIndex const & index);
|
||||||
void on_symbolsLW_itemClicked(QListWidgetItem * item);
|
void on_symbolsLW_clicked(QModelIndex const & index);
|
||||||
void on_categoryCO_activated(QString const & text);
|
void on_categoryCO_activated(QString const & text);
|
||||||
void on_categoryFilterCB_toggled(bool);
|
void on_categoryFilterCB_toggled(bool);
|
||||||
void on_chosenLE_returnPressed();
|
void on_chosenLE_returnPressed();
|
||||||
@ -67,6 +65,10 @@ private:
|
|||||||
typedef std::set<char_type> SymbolsList;
|
typedef std::set<char_type> SymbolsList;
|
||||||
///
|
///
|
||||||
SymbolsList symbols_;
|
SymbolsList symbols_;
|
||||||
|
/// custom model for symbol list view
|
||||||
|
class Model;
|
||||||
|
friend class Model;
|
||||||
|
Model * model_;
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace frontend
|
} // namespace frontend
|
||||||
|
@ -82,7 +82,7 @@
|
|||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item row="1" column="0" colspan="3" >
|
<item row="1" column="0" colspan="3" >
|
||||||
<widget class="QListWidget" name="symbolsLW" >
|
<widget class="QListView" name="symbolsLW" >
|
||||||
<property name="sizePolicy" >
|
<property name="sizePolicy" >
|
||||||
<sizepolicy vsizetype="Preferred" hsizetype="Preferred" >
|
<sizepolicy vsizetype="Preferred" hsizetype="Preferred" >
|
||||||
<horstretch>0</horstretch>
|
<horstretch>0</horstretch>
|
||||||
@ -116,9 +116,6 @@
|
|||||||
<property name="spacing" >
|
<property name="spacing" >
|
||||||
<number>0</number>
|
<number>0</number>
|
||||||
</property>
|
</property>
|
||||||
<property name="currentRow" >
|
|
||||||
<number>-1</number>
|
|
||||||
</property>
|
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item row="2" column="0" colspan="3" >
|
<item row="2" column="0" colspan="3" >
|
||||||
|
Loading…
Reference in New Issue
Block a user