QT 4: программирование GUI на С++
Шрифт:
QTextStream имеет различные опции, аналогичные опциям <iostream>. Установить опции можно путем передачи в поток специальных объектов — манипуляторов потока. В следующем примере устанавливаются опции showbase, uppercasedigits и hex перед выводом целого числа 12345678, и в результате получается текст «0xBC614E»:
Ниже перечислены функции, устанавливающие опции для QTextStream (рис. 12.1):
• setIntegerBase(int):
0 —
2 — двоичное представление,
8 — восьмеричное представление,
10 — десятичное представление,
16 — шестнадцатеричное представление.
• setNumberFlags(NumberFlags):
ShowBase — показывать префикс для оснований 2 («0b»), 8 («0») или 16 («0x»),
ForceSign — всегда показывать знак перед числами,
ForcePoint — всегда показывать десятичную точку,
UppercaseBase — префиксы оснований выдавать на верхнем регистре,
UppercaseDigits — буквы шестнадцатеричных чисел выдавать на верхнем регистре.
• setRealNumberNotation(RealNumberNotation):
FixedNotation — формат с фиксированной точкой (например, 0.000123),
ScientificNotation — научный формат (например, 0.12345678e-04),
SmartNotation — формат с фиксированной точкой или научный формат в зависимости от того, какой из них компактнее.
• setRealNumberPrecision(int) — устанавливает максимальное количество генерируемых цифр (по умолчанию 6).
• setFieldWidth(int) — устанавливает минимальный размер поля.
• setFieldAlignment(FieldAlignment):
AlignLeft — выравнивание влево, заполнитель занимает правую часть поля,
AlignRight — выравнивание вправо, заполнитель занимает левую часть поля,
AlignCenter — выравнивание по центру, заполнитель занимает оба края поля,
AlignAccountingStyle — заполнитель занимает область между знаком и числом.
• setPadChar(QChar) — устанавливает символ, используемый в качестве заполнителя (пробел по умолчанию).
Опции можно также устанавливать с помощью функций—членов:
Класс QTextStream, как и QDataStream, работает с каким-нибудь подклассом QIODevice: QFile, QTemporaryFile, QBuffer, QProcess, QTcpSocket или QUdpSocket. Кроме того, его можно использовать непосредственно со строкой типа QString. Например:
В
Теперь рассмотрим простой пример текстового формата файлов. В приложении Электронная таблица, описанном в части I , мы использовали двоичный формат для хранения данных этого приложения. Данные представляют собой последовательность троек (строка, столбец, формула) — по одной на каждую непустую ячейку. Запись данных в виде текста выполняется просто; ниже показан фрагмент пересмотренной версии функции Spreadsheet::writeFile:
Мы использовали простой формат, когда одна строка соответствует одной ячейке, причем пробелы разделяют номер строки и номер столбца, а также номер столбца и формулу. Формула может содержать пробелы, но мы предполагаем, что она не может содержать ни одного символа '\n' (который используется для завершения строки). Теперь давайте рассмотрим соответствующий программный код, предназначенный для чтения файла:
Мы считываем одним оператором одну строку данных приложения Электронная таблица. Функция readLine удаляет завершающий символ '\n'. Функция QString::split возвращает список строк, разбивая строку на части согласно обнаруженным символам—разделителям. Например, при обработке строки «5 19 Total value» будет получен список из четырех элементов [«5», «19», «Total», «value»].
Данные могут быть извлечены, если имеется по крайней мере три поля. Функция QStringList::takeFirst удаляет первый элемент списка и возвращает удаленный элемент. Мы используем ее для извлечения номеров строк и столбцов. Мы не делаем никакой проверки ошибок; если считываемый номер строки или номер столбца оказывается не числом, функция QString::toInt возвратит 0. Вызывая функцию setFormula, мы помещаем оставшиеся поля в одну строку.