QT 4: программирование GUI на С++ | страница 53
>01 void MainWindow::updateRecentFileActions()
>02 {
>03 QMutableStringListIterator i(recentFiles);
>04 while (i.hasNext()) {
>05 if (!QFile::exists(i.next()))
>06 i.remove();
>07 }
>08 for (int j = 0; j < MaxRecentFiles; ++j) {
>09 if (j < recentFiles.count()) {
>10 QString text = tr("&%1 %2")
>11 .arg(j + 1)
>12 .arg(strippedName(recent Files[j]));
>13 recentFileActions[j]->setText(text);
>14 recentFileActions[j]->setData(recentFiles[j]);
>15 recentFileActions[j]->setVisible(true);
>16 } else {
>17 recentFileActions[j]->setVisible(false);
>18 }
>19 }
>20 separatorAction->setVisible(!recentFiles.isEmpty());
>21 }
Сначала мы удаляем все файлы, которые больше не существуют, используя итератор в стиле Java. Некоторые файлы могли использоваться в предыдущем сеансе, но с этого момента их уже не будет. Переменная recentFiles имеет тип QStringList (список QStrings). В главе 11 подробно рассматриваются такие классы—контейнеры, как QStringList, и их связь со стандартной библиотекой шаблонов С++ (Standard Template Library — STL), a также применение в Qt классов итераторов в стиле Java.
Затем мы снова проходим по списку файла, на этот раз пользуясь индексацией массива. Для каждого файла мы создаем строку из амперсанда, номера файла (j + 1), пробела и имени файла (без пути). Для соответствующего пункта меню мы задаем этот текст. Например, если первым был файл С:\My Documents\tab04.sp, пункт меню первого недавно используемого файла будет иметь текст «&1 tab04.sp».
Рис. 3.11. Меню File со списком файлов, которые открывались недавно.
С каждым пунктом меню recentFileActions может быть связан элемент данных «data» типа QVariant. Тип QVariant может хранить многие типы С++ и Qt; он рассматривается в гл. 11. Здесь в элементе меню «data» мы храним полное имя файла, чтобы позже можно было легко его найти. Мы также делаем этот пункт меню видимым.
Если пунктов меню (массив recentFileActions) больше, чем недавно открытых файлов (массив