Помощь - Поиск - Пользователи - Календарь
Полная версия этой страницы: Web AxWidget
Форум на CrossPlatform.RU > Библиотеки > Qt > Qt Script. Интеграция WebKit
Саша
Проблеммы встроить WebBrowser в Qt-приложение не составляет. НО получившийся браузер НЕ ВСЕ клавиши пускает, например, до JScript-ов. В частности не пускает стрелочки, Backspace, PgUp, PgDown. В чём несложно убедиться написав такой HTML-код:

CODE

<script>
function on_keydown( e )
{
var keyChar = String.fromCharCode(event.which);
window.status = event.keyCode;
document.all["StatusLine"].innerText = event.keyCode;
}
document.onkeydown = on_keydown;
</SCRIPT>
<BODY>
ppppppppp
</BODY>
<P ID=StatusLine>
aaaaa
</P>

и сравнив результаты его работы в обычном IExplorer-е или (другом браузере) и браузере написаном на Qt.
После нескольких дней поиска была найдена виртуальная ф-я класса QAxWidget::translateKeyEvent. Если снаследовать этот класс и переопределив эту ф-ю возвращать в ней всегда true, все клавиши начинают доходить, НО теперь все те проблемные клавиши начинают приходить дважды, например, в полях ввода. что несложно проверить на следующем HTML-коде:
CODE

<HTML>
<BODY>
<INPUT TYPE=TEXT></INPUT>
</BODY>
</HTML>

Чтобы увидеть нехороший эффект нужно ввести в поле редактирования буквы, а потом поперемещать в нём текстовый курсор при помощи клавиш "вправо", "влево". Курсор будет смещаться сразу на 2 символа.
В Интернете я после всего этого наткнулся на страницу
http://www.crossplatform.ru/documentation/...baxwidget-h.php.
Там тоже переопределяется ф-я QAxWidget::translateKeyEvent. Но как было отмечено появляется дублирование клавишь.
Что делать???!!!
ViGOur
А как ты переопределил функцию translateKeyEvent? Так же как в примере или по своему?
ViGOur
А вот и ответ у тролей:
Цитата
Some key events happen twice with ActiveX controls hosted by QAxWidget, this does not happen for all key presses, but usually happens with accelerators.
-----
This behavior is as per design, best way to avoid this in your control is to re-implement the translateKeyEvent of QAxWidget & return false. The default QAxWidget implementation returns true in this scenario, which inturn sends the message directly to the control's window procedure. This is required for common servers like Internet Explorer and Microsoft Office.
Some key events happen twice with ActiveX controls hosted by QAxWidget

В общих словах, как я понял, в translateKeyEvent нужно возвращать не true, а false. :)
Саша
Вначале я переопределил по-своему: просто "return true". потом попробовал как в примере. Результат то-же - двойное нажатие. Если возвращать всегда false - то не доходят вообще никакие клавиши. Ещё один интересный факт: ф-я translateKeyEvent вызывается 1 РАЗ! А нажатий оказывается 2. Даже хуки не показывают 2-ное нажатие и MSVisual-овский Spy.
ViGOur
А если попробовать так:
     virtual bool translateKeyEvent(int message, int keycode) const
     {
         if (message >= WM_KEYFIRST && message <= WM_KEYLAST)
             return false;
         else
             return QAxWidget::translateKeyEvent(message, keycode);
     }
Как я понимаю идет речь о закрытии событий для кнопок: лево, право, вверх, вних и бекспэйс.

Просто как написано в описании: bool QAxWidget::translateKeyEvent ( int message, int keycode ) const [virtual protected]
Цитата
If the function returns false the processing of the key event is ignored by ActiveQt, ie. the ActiveX control might handle it or not.
Саша
ViGOur, залез я по твоей ссылке к тролям...
Как я понял, они этот баг вначале хотели исправить в 4-ой версии, а потом всё-таки отвергли (2007-12-06 17:25 - Resolution set to 'Rejected'). И сказали, что нужно возвращать false. Но я ж говорю, что тогда не доходят сообщения до скриптов. Может им снова баг написать? Я только пока не знаю как.
Саша
Цитата(ViGOur @ 25.1.2008, 11:26) *
А если попробовать так:
     virtual bool translateKeyEvent(int message, int keycode) const
     {
         if (message >= WM_KEYFIRST && message <= WM_KEYLAST)
             return false;
         else
             return QAxWidget::translateKeyEvent(message, keycode);
     }
Как я понимаю идет речь о закрытии событий для кнопок: лево, право, вверх, вних и бекспэйс.

Просто как написано в описании: bool QAxWidget::translateKeyEvent ( int message, int keycode ) const [virtual protected]
Цитата
If the function returns false the processing of the key event is ignored by ActiveQt, ie. the ActiveX control might handle it or not.



Попробовал. Теперь до скриптов не доходят клавиши. Я ж говорю. Проблема сводится к поговорке. "Нос вытянул - ножка увязла, ножку вытянул - нос увяз".
ViGOur
Раз отвергли, то нужно сначала попробовать самому обойти эту проблему, тебе же нужно использовать сейчас этот функционал, а не ждать пока они исправят.

Попробуй вариации: (message == WM_KEYFIRST && message == WM_KEYLAST)

У меня к сожалению нет готового проекта с WebBrowser, а то сам попробовал бы. :)
Саша
Цитата(ViGOur @ 25.1.2008, 11:37) *
Раз отвергли, то нужно сначала попробовать самому обойти эту проблему, тебе же нужно использовать сейчас этот функционал, а не ждать пока они исправят.

Покажи как ты переопределяешь translateKeyEvent, что у тебя ни одно событие нажатия клавиш не доходит.

Значит так чтоб не доходили клавиши я пишу так:
CODE

bool CQWebBrowser::translateKeyEvent ( int message, int keycode ) const
{
return false;
}

НО клавиши не доходят ТОЛЬКО до скриптов
Саша
Цитата(ViGOur @ 25.1.2008, 11:37) *
У меня к сожалению нет готового проекта с WebBrowser, а то сам попробовал бы. :)

Для версии Qt 3.3.4 могу щас побыстрому попробовать собрать проект
ViGOur
Стоп, а тебе нужно, чтобы кнопки-стрелочки и бекспэйс доходили до твоего javascript или нет?
ViGOur
Цитата(Guest_Саша_* @ 25.1.2008, 11:54) *
Для версии Qt 3.3.4 могу щас побыстрому попробовать собрать проект
У меня сейчас только 4.3.2, хотя могу попробовать переключиться на поддержку Qt3.
Саша
Цитата(ViGOur @ 25.1.2008, 11:56) *
Стоп, а тебе нужно, чтобы кнопки-стрелочки и бекспэйс доходили до твоего javascript или нет?

В том-то и дело, что нужно
ViGOur
Тогда оформлять как баг, или попробовать заморочиться с исправлением самим :)
Саша
Цитата(ViGOur @ 25.1.2008, 12:05) *
Тогда оформлять как баг, или попробовать заморочиться с исправлением самим :)

Вот я и не знаю что делать. Наверное нужно и то и другое. Но с Qt я только начинаю разбираться. А тут в потроха его лезть надо.
ViGOur
угу, нужно лезть, заодно и получше изучишь Qt изнутри. :)
А если что-то не понятно будет, то для того и существует форум...
Alexandr
Я бы использовал ,на вашем месте, модуль QtWebKit. ActiveX - это проприетарные костыли и поддерживаются они тролльтехами только из-за широкого распостранения и отсутствия своего(и они это положение исправляют).
Вот моя заметка на эту тему Simple web browser.
Qt 4.4 выйдет через месяц, а пока можно использовать вполне рабочую Qt 4.4 Pre-release
Успехов!
klochec_v
еще такой вопрос у когонить была такая проблема что при перезагрузке браузера(или другой причине) пропадал курсор(приглашение ввода) в поле ввода текста. нажимая текстовые клавиши на клавиатур они появляются в поле ввода однако никакие другие клавиши не работают получается курсора нет а фокус как бы есть...
Для просмотра полной версии этой страницы, пожалуйста, пройдите по ссылке.
Форум IP.Board © 2001-2025 IPS, Inc.