AXForum  
Вернуться   AXForum > Microsoft Dynamics AX > DAX: Программирование
All
Забыли пароль?
Зарегистрироваться Правила Справка Пользователи Сообщения за день Поиск

 
 
Опции темы Поиск в этой теме Опции просмотра
Старый 19.05.2006, 10:14   #1  
YoYo is offline
YoYo
Участник
Аватар для YoYo
 
3 / 10 (1) +
Регистрация: 19.05.2006
Автоматический поиск строки в форме подбора
Всем привет. Нужен совет начинающему программисту.
При работе с журналом LedgerJournalTable когда создаем строки (LedgerJournalTrans) при выборе типа счета (корсчета) "Главная книга" открывается форма подбора счета из плана счетов. Мне необходимо сделать так, чтобы в форме подбора при наборе первых цифр кода счета курсор автоматически перемещался на первую найденную строку с таким кодом.
Данный механизм например реализован в ОСВ, когда в критериях назначаем фильтр по счетам. Только я не смог разобраться, как это сделано в этом запросе.
Возможно данная тема уже не раз освещалась на форуме, только я не смог найти. Если не трудно, пришлите ссылку на обсуждение вопроса, либо кусочек кода с пояснениями Заранее благодарен!
Старый 19.05.2006, 10:34   #2  
denny is offline
denny
Участник
 
93 / 29 (1) +++
Регистрация: 16.11.2003
Адрес: Novosibirsk
Извините, не понял, что такое OCВ. Быстрый поиск в lookup'е реализуется классом TableLookup_RU, конкретно методом WaitAndSearch. См. также Выбор набора полей из lookup, там этот вопрос затрагивался.
Тем не менее должен предостеречь - набор каждого нового символа заставляет систему перестраивать range и посылать запрос к базе данных, поэтому решение с быстрым поиском может быть не совсем удачным с точки зрения производительности в целом. Не стоит вставлять его во все возможные lookup'ы.
Старый 19.05.2006, 11:00   #3  
denny is offline
denny
Участник
 
93 / 29 (1) +++
Регистрация: 16.11.2003
Адрес: Novosibirsk
Наврал немного. В стандартном лукапе, через SysTableLookup поиск по ключевому полю также осуществляется, но только для данных, уже "отобранных" клиентом, закэшировавшихся. (грубо - тех, которые видит пользователь в открывшейся форме).
Старый 19.05.2006, 12:00   #4  
glibs is offline
glibs
Member
Сотрудники компании It Box
Most Valuable Professional
Лучший по профессии 2011
Лучший по профессии 2009
 
4,942 / 911 (40) +++++++
Регистрация: 10.06.2002
Адрес: I am from Kyiv, Ukraine. Now I am in Moscow. For private contacts: glibs@hotmail.com
Цитата:
Сообщение от YoYo
...
Мне необходимо сделать так, чтобы в форме подбора при наборе первых цифр кода счета курсор автоматически перемещался на первую найденную строку с таким кодом.
...
А вы переключитесь на закладку По типу счета ([Ctrl] + [Tab]). Там работает стандартный поиск в lookup.
__________________
С уважением,
glibs®
Старый 19.05.2006, 13:12   #5  
Vadik is offline
Vadik
Модератор
Аватар для Vadik
Лучший по профессии 2017
Лучший по профессии 2015
 
3,631 / 1849 (69) ++++++++
Регистрация: 18.11.2002
Адрес: гражданин Москвы
Цитата:
Сообщение от glibs
А вы переключитесь на закладку По типу счета ([Ctrl] + [Tab]). Там работает стандартный поиск в lookup.
он то работает, то не работает, в зависимости от
\Forms\LedgerAccountLookup\Methods\run()
Код:
if (callerControl.text() && callerControl.hasChanged())
{
    filterLookup = true;
    LedgerTableAccountType_ds.autoSearch(false);
    TmpLedgerTable_ds.autoSearch(false);
}
__________________
-ТСЯ или -ТЬСЯ ?
Старый 19.05.2006, 13:41   #6  
Волчара is offline
Волчара
Участник
 
210 / 29 (1) +++
Регистрация: 08.02.2003
Адрес: Москва
Цитата:
Сообщение от YoYo
Нужен совет начинающему программисту.
А программировать то может ни чего и не надо?

Цитата:
Сообщение от YoYo
При работе с журналом LedgerJournalTable когда создаем строки (LedgerJournalTrans) при выборе типа счета (корсчета) "Главная книга" открывается форма подбора счета из плана счетов. Мне необходимо сделать так, чтобы в форме подбора при наборе первых цифр кода счета курсор автоматически перемещался на первую найденную строку с таким кодом.
Набираем в поле первые две три или четыре буквы ставим звездочку, автоматически открывается lookup отфильтрованный нужным образом..
__________________
Благодарю за поддержку ИЦ Кариатиду и Koder Logic
Старый 19.05.2006, 13:53   #7  
denny is offline
denny
Участник
 
93 / 29 (1) +++
Регистрация: 16.11.2003
Адрес: Novosibirsk
Цитата:
Сообщение от Волчара
А программировать то может ни чего и не надо?

Это само собой. Но нами здесь движет уже скорее академический интерес
2Vadik: Что-то никакого эффекта запрет autoserach не дает. Можно вообще условие if снять - все равно на закладке "По типу счета" поиск производится, а на закладке "По типу разноски" - нет.

Теперь и я запутался. Еще посмотрю код.
Старый 19.05.2006, 18:13   #8  
AndyD is offline
AndyD
Участник
КОРУС Консалтинг
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
 
2,560 / 2479 (88) +++++++++
Регистрация: 20.08.2005
Может это не ваша ситуация

На форме используется один буфер для поиска по AutoSearch. Этот буфер сбрасывается при нажатии на управляющие кнопки или при смене фокуса контрола, по которому идет поиск.
Если же выбирать закладки при помощи мыши, то этот буфер не сбрасывается и при попытке начать поиск в новом датасоурсе на самом деле ищется не вновь набираемый текст, а добавляется к уже записанному в буфере.
Обойти этот эффект можно нажатием на управляющие кнопки (стрелки) или переключением с помощью CTRL+TAB. Можно так же программным способом при помощи WinApi. Вот пример для этой формы
X++:
void tabChanged(int _from, int _to)
{
    #define.EM_SETSEL(0x00B1)
    #define.VK_RIGHT(39)
    #winapi
    ;
    super(_from, _to);

    switch (_to)
    {
        case 1:
            element.selectMode(element.control(Control::tmpLedgerTable_AccountNum));
            winapi::sendMessageEx(element.control(Control::tmpLedgerTable_AccountNum).hWnd(), #WM_KEYDOWN, #VK_RIGHT, 0);
            winapi::sendMessageEx(element.control(Control::tmpLedgerTable_AccountNum).hWnd(), #EM_SETSEL, 0, -1);
            break;
        case 2:
            element.selectMode(element.control(Control::LedgerTableAccountType_AccountNum));
            winapi::sendMessageEx(element.control(Control::LedgerTableAccountType_AccountNum).hWnd(), #WM_KEYDOWN, #VK_RIGHT, 0);
            winapi::sendMessageEx(element.control(Control::LedgerTableAccountType_AccountNum).hWnd(), #EM_SETSEL, 0, -1);
            break;
    }

}
__________________
Axapta v.3.0 sp5 kr2
Старый 24.05.2006, 11:22   #9  
YoYo is offline
YoYo
Участник
Аватар для YoYo
 
3 / 10 (1) +
Регистрация: 19.05.2006
Эх, спасибо ребята :)
Сейчас буду обрабатывать полученную информацию и смотреть как лучше. А академический интерес - это верно, он зачастую присутствует да и разве можно научиться чему-нибудь не попробовав?
Всем спасибо большое за ответы!!!!
__________________
Всему свой час и Время каждому из дней!
Родиться - время, время - жить и умирать.
Швырять камнями, но затем и собирать...
Молчать есть время, говорить с Душой своей...
Старый 13.07.2010, 15:43   #10  
Nati is offline
Nati
Участник
 
3 / 10 (1) +
Регистрация: 28.10.2005
:( ds_AutoSearch(false), tabChanged
На форме используется один буфер для поиска по AutoSearch. Этот буфер сбрасывается при нажатии на управляющие кнопки или при смене фокуса контрола, по которому идет поиск.
Если же выбирать закладки при помощи мыши, то этот буфер не сбрасывается и при попытке начать поиск в новом датасоурсе на самом деле ищется не вновь набираемый текст, а добавляется к уже записанному в буфере.
Обойти этот эффект можно нажатием на управляющие кнопки (стрелки) или переключением с помощью CTRL+TAB. Можно так же программным способом при помощи WinApi. Вот пример для этой формы
X++:
void tabChanged(int _from, int _to)
{
    #define.EM_SETSEL(0x00B1)
    #define.VK_RIGHT(39)
    #winapi
    ;
    super(_from, _to);

    switch (_to)
    {
        case 1:
            element.selectMode(element.control(Control::tmpLedgerTable_AccountNum));
            winapi::sendMessageEx(element.control(Control::tmpLedgerTable_AccountNum).hWnd(), #WM_KEYDOWN, #VK_RIGHT, 0);
            winapi::sendMessageEx(element.control(Control::tmpLedgerTable_AccountNum).hWnd(), #EM_SETSEL, 0, -1);
            break;
        case 2:
            element.selectMode(element.control(Control::LedgerTableAccountType_AccountNum));
            winapi::sendMessageEx(element.control(Control::LedgerTableAccountType_AccountNum).hWnd(), #WM_KEYDOWN, #VK_RIGHT, 0);
            winapi::sendMessageEx(element.control(Control::LedgerTableAccountType_AccountNum).hWnd(), #EM_SETSEL, 0, -1);
            break;
    }

}
[/QUOTE]

ЗДРАВСТВУЙТЕ ВСЕМ
ЭТО НЕ РАБОТАЕТ - "буфер для поиска по AutoSearch" не сбрасывается
 

Похожие темы
Тема Автор Раздел Ответов Посл. сообщение
Подскажите красивое решение задачи (поиск данных на форме) DTD DAX: Программирование 4 22.01.2009 08:54
Как не выводить заголовки в форме, если нет строк? DreamCreator DAX: Программирование 9 29.05.2008 15:10
Поиск в Grid по полю DataMethod Tiruvileijadal' DAX: Программирование 20 14.05.2007 13:37
Журналы и строки на одной форме. chi DAX: Программирование 16 08.06.2005 11:21
Функция "Удалить строки" Oks DAX: Функционал 1 03.07.2002 18:09

Ваши права в разделе
Вы не можете создавать новые темы
Вы не можете отвечать в темах
Вы не можете прикреплять вложения
Вы не можете редактировать свои сообщения

BB коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход

Рейтинг@Mail.ru
Часовой пояс GMT +3, время: 07:22.