Алекс Jenter - Программирование на Visual C++. Архив рассылки
- Название:Программирование на Visual C++. Архив рассылки
- Автор:
- Жанр:
- Издательство:неизвестно
- Год:неизвестен
- ISBN:нет данных
- Рейтинг:
- Избранное:Добавить в избранное
-
Отзывы:
-
Ваша оценка:
Алекс Jenter - Программирование на Visual C++. Архив рассылки краткое содержание
РАССЫЛКА ЯВЛЯЕТСЯ ЧАСТЬЮ ПРОЕКТА RSDN, НА САЙТЕ КОТОРОГО ВСЕГДА МОЖНО НАЙТИ ВСЮ НЕОБХОДИМУЮ РАЗРАБОТЧИКУ ИНФОРМАЦИЮ, СТАТЬИ, ФОРУМЫ, РЕСУРСЫ, ПОЛНЫЙ АРХИВ ПРЕДЫДУЩИХ ВЫПУСКОВ РАССЫЛКИ И МНОГОЕ ДРУГОЕ.
Программирование на Visual C++. Архив рассылки - читать онлайн бесплатно полную версию (весь текст целиком)
Интервал:
Закладка:
• Гиперссылка выглядит, как в IE. Интересно, что цвета для ссылки (обычной и посещённой) берутся из настроек IE, хранящихся в реестре. Если настройки обнаружить не удаётся, используются цвета по умолчанию (синий и фиолетовый).
• При наведении на ссылку курсор приобретает форму руки. Обратите внимание, что под Windows 2000 класс CHyperLinkиспользует системный курсор, а в других версиях Windows создаёт его на лету, избавляя вас от необходимости включать его в ресурсы во всех случаях. Кроме того, следует отметить, что курсор должен располагаться именно на надписи, а не в любой точке статического контрола, даже если вы нарисовали его очень большим.
• Если задержать курсор над ссылкой, появляется всплывающая подсказка с адресом, по которому будет осуществляться переход.
• Класс CHyperLinkподдерживает не только мышиный, но и клавиатурный интерфейс. Ссылка, на которую установлен фокус ввода, выделяется пунктирной рамкой. При этом можно перейти по ней, нажав Enter или Space.
ПРИМЕЧАНИЕ
В типичном модальном диалоге Enter не будет попадать в ссылку, так как диалог преобразует его в нажатие кнопки по умолчанию. При желании изменить это поведение можно, переопределив обработчик OnGetDlgCodeкласса CHyperLink.
Переход по ссылке реализован через функцию ShellExecute. Эта функция понимает как адреса сайтов (при этом открывается броузер), так и почтовые адреса (при этом запускается почтовый клиент).
Список методов класса CHyperLinkприведён в таблице 8.
Метод | Описание |
---|---|
CHyperLinkImpl() | Конструктор. Записывает в переменные объекта значения по умолчанию. |
~CHyperLinkImpl() | Деструктор. Освобождает ресурсы, распределённые в процессе инициализации. |
bool GetLabel(LPTSTR lpstrBuffer, int nLength) const | Возвращает метку гиперссылки (то есть строку, которую пользователь видит на экране). |
bool SetLabel(LPCTSTR lpstrLabel) | Устанавливает метку гиперссылки. Текст сохраняется внутри объекта класса. Память для него распределяется динамически. По умолчанию в качестве метки используется содержимое статического контрола, который связывается с объектом класса. Поэтому часто удаётся обойтись и без метода SetLabel. |
bool GetHyperLink(LPTSTR lpstrBuffer, int nLength) const | Возвращает адрес гиперссылки, по которому осуществляется фактический переход. |
bool SetHyperLink(LPCTSTR lpstrLink) | Устанавливает адрес гиперссылки. Адрес также сохраняется внутри объекта класса в динамически распределяемой памяти. Иногда адрес совпадает с меткой. В этом случае устанавливать его вызовом SetHyperLinkнеобязательно, так как класс CHyperLinkсделает это за вас. |
BOOL SubclassWindow(HWND hWnd) | Подменяет оконную процедуру окна, подключая к нему объект класса. |
bool Navigate() | Осуществляет переход по ссылке. |
void Init() | Инициализирует объект класса: создаёт или загружает курсор в виде руки, создаёт подчёркнутый фонт и тултип для ссылки, загружает из реестра цвета, которые использует IE. |
void DoPaint(CDCHandle dc) | Рисует ссылку. Вы можете переопределить этот метод в производном классе, чтобы изменить её внешний вид. |
ПРИМЕЧАНИЕ
Обратите внимание: если метка и адрес гиперссылки у вас отличаются, метод SetHyperLinkследует вызывать до связывания объекта класса с контролом. Дело в том, что в момент связывания (в функции Init, которая вызывается из SubclassWindow) для ссылки создаётся тултип, в который записывается адрес ссылки. Если адрес ещё не задан, в тултип запишется метка.
Класс CMultiPaneStatusBarпризван облегчить вашу жизнь при работе со строками состояния. Стандартный контрол status bar из набора общих контролов Windows позволяет создать на строке состояния до 256 панелей, в которых можно отображать текст и иконки. Но он не предоставляет никаких средств для автоматического перемещения этих панелей. Программисту на чистом API приходится передвигать их вручную всякий раз, когда строка состояния изменяет свой размер. В MFC эту работу берёт на себя класс CStatusBar. А в WTL вам поможет класс CMultiPaneStatusBar.
Посмотрим, каким образом используется класс CMultiPaneStatusBar. Сначала объект класса связывается с существующей строкой состояния при помощи DDX_CONTROL. Можно и создать строку состояния с нуля, используя метод Create. Затем задаётся набор панелей для строки состояния. Для этого предназначен метод SetPanes. Он принимает количество панелей и массив с их идентификаторами. Идентификаторы используются для последующего обращения к панелям. Одной из панелей можно назначить стандартный идентификатор ID_DEFAULT_PANE. Панель с таким идентификатором растягивается, занимая всё свободное пространство в строке состояния. Остальные панели имеют фиксированный размер (который всегда можно изменить, используя метод SetPaneWidth). О корректном перемещении панелей заботится WTL. Вам остаётся только изменять текст панелей, их иконки и всплывающие подсказки в соответствии с вашими нуждами.
Полный список методов класса CMultiPaneStatusBarприведён в таблице 9.
Метод | Описание |
---|---|
CMultiPaneStatusBarCtrlImpl() | Конструктор. Не выполняет никакой полезной работы. |
~CMultiPaneStatusBarCtrlImpl() | Деструктор. Освобождает память, занятую списком идентификаторов панелей. |
HWND Create(HWND hWndParent, LPCTSTR lpstrText, DWORD dwStyle, UINT nID) HWND Create(HWND hWndParent, UINT nTextID, DWORD dwStyle, UINT nID) | Создают строку состояния. |
BOOL SetPanes(int* pPanes, int nPanes, bool bSetText = true) | Задаёт набор панелей для строки состояния. При этом предыдущий набор полностью теряется. Массив pPanesсодержит идентификаторы панелей. Начальный размер панели подгоняется под строку из ресурсов, идентификатор которой совпадает с идентификатором панели. Если задан флаг bSetText, текст из ресурсов будет сразу же вставлен в соответствующие панели. |
bool GetPaneTextLength(int nPaneID, int* pcchLength = NULL, int* pnType = NULL) const | Возвращает длину текста в панели nPaneIDчерез указатель pcchLength. По адресу pnTypeзаписывается тип панели. В Windows определены следующие типы: SBT_NOBORDERS(панель не имеет видимой рамки), SBT_OWNERDRAW(панель отрисовывается родительским окном), SBT_POPOUT(панель выглядит выпуклой на строке состояния) и SBT_RTLREADING(изменяет направление текста на противоположное). Нулевой тип соответствует обычной панели, которая вдавлена в строку состояния. |
BOOL GetPaneText(int nPaneID, LPTSTR lpstrText, int* pcchLength = NULL, int* pnType = NULL) const | Аналогичен предыдущему, но извлекает также текст панели в буфер lpstrText. |
BOOL SetPaneText(int nPaneID, LPCTSTR lpstrText, int nType = 0) | Задаёт текст (параметр lpstrText) и тип (параметр nType) для панели nPaneID. |
BOOL SetPaneWidth(int nPaneID, int cxWidth) | Устанавливает ширину панели nPaneIDравной cxWidth. |
BOOL GetPaneTipText(int nPaneID, LPTSTR lpstrText, int nSize) const | Извлекает текст всплывающей подсказки для панели nPaneID. |
BOOL SetPaneTipText(int nPaneID, LPCTSTR lpstrText) | Устанавливает текст всплывающей подсказки для панели nPaneID. |
BOOL GetPaneIcon(int nPaneID, HICON& hIcon) const | Извлекает хэндл иконки, назначенной панели nPaneID. |
BOOL SetPaneIcon(int nPaneID, HICON hIcon) | Задаёт иконку для панели nPaneID. |
BOOL UpdatePanesLayout() | Пересчитывает расположение панелей. Вызывайте этот метод всякий раз, когда вы изменяете размеры панелей с помощью методов SetPanesи SetPaneWidth. |
int GetPaneIndexFromID(int nPaneID) const | Определяет индекс панели по её идентификатору. Как известно, стандартный status bar использует для работы с панелями индексы. Вам вряд ли потребуется этот метод, поскольку класс CMultiPaneStatusBarпозволяет вам выполнять все необходимые операции по идентификатору панели. Но для полноты картины стоит упомянуть и его. |
ПРИМЕЧАНИЕ
Читать дальшеИнтервал:
Закладка: