Перейти из форума на сайт.

НовостиФайловые архивы
ПоискАктивные темыТоп лист
ПравилаКто в on-line?
Вход Забыли пароль? Первый раз на этом сайте? Регистрация
Компьютерный форум Ru.Board » Компьютеры » Программы » Закладки » AutoIT (Часть 1)

Модерирует : gyra, Maz

Widok (12-01-2009 14:47): лимит страниц. продолжаем здесь  Версия для печати • ПодписатьсяДобавить в закладки
Страницы: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138

   

AddXL

Newbie
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору

AutoIt3

 
Домашняя страница: http://www.autoitscript.com
Страница загрузки: http://www.autoitscript.com/autoit3/downloads.php
 
Описание:

Цитата:
AutoIt v3 - это язык для написания сценариев, напоминающий BASIC. Основным его назначением является автоматизация работ с Windows GUI (графическим интерфейсом пользователя MS Windows). Для выполнения этой сложной задачи предоставляется комбинация испытанных методов, включающих в себя - симуляцию нажатий комбинаций клавиш клавиатуры, перемещения указателя мыши и управления окнами и его визуальными элементами. Как показывает практика, эти "приводные ремни" весьма эффективны для получения работающих решений в ситуациях, когда другие стандартные средства (например, VBScript и SendKeys) оказываются бессильны.
Умеет он очень и очень многое! Бесплатный.

 
Помощь по AutoIT:
  • Справку на русском (и не только) вы всегда(?) сможете найти тут
  • Справочник по командам rundll32
  • Русский справочник по API-функциям
  • Помощь по Регулярным выражениям
  • AutoIt v3: Your Quick Guide (652 КБ) - Ваш быстрый гид в мир AutoIt-а (книга в формате pdf)
     
    Инструметы для AutoIt:
  • AutoIt3Wrapper [Страница закачки] - Программа для компилляции скрипта с дополнительными возможностями (добавление иконки, описании и т.п).
  • Koda (724 Kb) - Визуализация работы с GUI - аналог Visual Basic.
  • CodeWizard (400 Kb) - нечто простенькое на вариант Koda.
  • AutoItMacroGenerator (34 Kb) - Записывает в реальном времени действия пользователя в AutoIt код.
  • ScriptWriter (78 Kb) - Аналог AutoItMacroGenerator.
  • API Constants (1042 Kb) - Утилита для просмотра всех констант API-Функции и не только.
  • Страница закачки утилит которые идут в отдельной поставке редактора SciTE.
  • AutoIt меню для браузера Opera
     
    Готовые скрипты и программы с открытым кодом на AutoIt:
  • Коллекция AutoIt скриптов от Sanja Alone
  • Коллекция скриптов на http://msfn.org
  • Пополняющийся со временем сайт с полезными утилитами и функциями на AutoIt
  • Desktop Icons Restorator - Скрипт-Программа для сохранения/восстановления позиции иконок р.стола.
  • CaptureIt - Утилита предназначена для захвата изображений с вашего экрана.
  • SwitchIt - Скрипт для конвертирования выделенного текста
  • Скрипт расскраски кода AutoIt для публикации в форумах
     
    Общие вопросы и решения на Autoit:
  • Обработчик скриптов добавляющий отладчик (debugger)
  • Интеракция между несколькими скриптами
  • Пример использование интеракции между скриптами - Добавление элементов GUI с внешнего модуля
  • Копирование большого файла с отображением данных прогресса
  • Создание динамического меню в Tray Icon (значёк в области уведомления)
  • Пример создания своего мастера (Wizard)
  • Метод позволяющий запускать код VBS не создавая временных файлов
  • Описание функции GUIRegisterMsg()
  • Пример перехвата вводимых символов с клавиатуры
  • Пример деактивирования TabItem
  • Пример вывода лога в Edit-поле (с поддержкой форматирования текста)
  • Пример остановки/начало выполнения скрипта + Слежение за б.обмена с заменой неподдерживаемых в имени файла символов
  • Пример использования меню с иконками (ModernMenu.au3) -> Список программ в меню значка в системном трее
     
  • Как по PID процесса вычислить путь запускаемого файла
  • Получение IP по подключенному сокету
     
    Отдельные функции (UDF):
  • Функции Отключения/Подключения к Интернету
  • Функция проверки подключения к Интернету
  • Функция для получения структуры директории включая подкаталоги
  • Функция для поиска в файлах
  • Функция для смены разрешения экрана
  • Функция для смены раскладки клавиатуры в определённом окне
  • Функция для получения списка процессов с допол. инфой (путь к исполняемому файлу и др.)
  • Функции и пример для отображения детального процесса закачки файла
  • Функция (и пример использования) для отображения стильного диалога “О Программе” - [Усовершенствованная версия]
  • Функция возвращает пронумерованный список всех классов определённого окна + функция получения хендлов для этих классов
  • Функция для получения заголовка окна (или его идентификатора) по ID процесса (PID)
  • Функция _StringIsUTF8Format() + _StringToUTF() - Первая проверяет если строка содержится в UTF-8 формате, вторая преобразовывает строку в UTF-8 формат
  • Функция _FileOpenDialogEx - Возвращает массив (или строку) с полными путями к выбранным файлам
  • _AU3_Lib* Функции - Предназначены для обработки подключаемых библиотек через #include
  • Функция транслитерации строки
  • Расширенная библиотека для работы с реестром
     
    За шапкой следит ViSiToR  

  • Всего записей: 6 | Зарегистр. 24-11-2005 | Отправлено: 13:20 24-11-2005 | Исправлено: Maz, 11:50 17-04-2017
    ViSiToR



    Silver Member
    Редактировать | Профиль | Сообщение | ICQ | Цитировать | Сообщить модератору
    baic

    Цитата:
    Этот код открывает папку из которой запускается скрипт

    Это ярлык для запуска интернета (IExplore)? У него свойства другие, можно использовать самопальную функцию (от amel27) для подобных ярлыков:
     

    Код:
     
    _ShellExecuteEx(@DesktopDir & "\Inet1.lnk")
     
    Func _ShellExecuteEx($sCmd, $sArgs = "", $sFolder = "", $sVerb = "", $iState = @SW_SHOWNORMAL, $hWnd = 0)
        Local $stINFO = DllStructCreate("long;long;long;ptr;ptr;ptr;ptr;long;long;long;ptr;long;long;long;long")
        Local $stVerb = DllStructCreate("char[15];char")
        Local $stPath = DllStructCreate("char[255];char")
        Local $stArgs = DllStructCreate("char[255];char")
        Local $stWDir = DllStructCreate("char[255];char")
     
        DllStructSetData($stVerb, 1, $sVerb)
     
        DllStructSetData($stPath, 1, $sCmd)
        DllStructSetData($stWDir, 1, $sFolder)
        DllStructSetData($stArgs, 1, $sArgs)
     
        DllStructSetData($stINFO, 1, DllStructGetSize($stINFO))
        DllStructSetData($stINFO, 2, BitOR(0xC, 0x40, 0x400))
        DllStructSetData($stINFO, 3, $hWnd)
        DllStructSetData($stINFO, 4, DllStructGetPtr($stVerb))
        DllStructSetData($stINFO, 5, DllStructGetPtr($stPath))
        DllStructSetData($stINFO, 6, DllStructGetPtr($stArgs))
        DllStructSetData($stINFO, 7, DllStructGetPtr($stWDir))
        DllStructSetData($stINFO, 8, $iState)
     
        Local $aRet = DllCall("shell32.dll", "int", "ShellExecuteEx", "ptr", DllStructGetPtr($stINFO))
        If Not IsArray($aRet) Or Not $aRet[0] Then Return SetError(2, 0, 0)
     
        Return 1
    EndFunc

     


    ----------
    ViSiToR a.k.a CreatoR
    CreatoR это не ник, CreatoR это стиль жизни!

    Всего записей: 3251 | Зарегистр. 01-04-2006 | Отправлено: 14:19 15-02-2008
    baic

    Full Member
    Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
    ViSiToR
    если добавляю в текст...MsgBox(0, "Example", @DesktopCommonDir & "\Inet1.lnk")...то
    появляется MsgBox и запускается ярлык Inet1.lnk, но если убираю...MsgBox(0, "Example", @DesktopCommonDir & "\Inet1.lnk")...то ярлык Inet1.lnk не запускается
     
    ...заранее благодарен, если поможете...
     
     
     

    Код:
     
     _ShellExecuteEx(@DesktopCommonDir & "\Inet1.lnk")
    MsgBox(0, "Example", @DesktopCommonDir & "\Inet1.lnk")
     
    Func _ShellExecuteEx($sCmd, $sArgs = "", $sFolder = "", $sVerb = "", $iState = @SW_SHOWNORMAL, $hWnd = 0)
        Local $stINFO = DllStructCreate("long;long;long;ptr;ptr;ptr;ptr;long;long;long;ptr;long;long;long;long")
        Local $stVerb = DllStructCreate("char[15];char")
        Local $stPath = DllStructCreate("char[255];char")
        Local $stArgs = DllStructCreate("char[255];char")
        Local $stWDir = DllStructCreate("char[255];char")
     
        DllStructSetData($stVerb, 1, $sVerb)
     
        DllStructSetData($stPath, 1, $sCmd)
        DllStructSetData($stWDir, 1, $sFolder)
        DllStructSetData($stArgs, 1, $sArgs)
     
        DllStructSetData($stINFO, 1, DllStructGetSize($stINFO))
        DllStructSetData($stINFO, 2, BitOR(0xC, 0x40, 0x400))
        DllStructSetData($stINFO, 3, $hWnd)
        DllStructSetData($stINFO, 4, DllStructGetPtr($stVerb))
        DllStructSetData($stINFO, 5, DllStructGetPtr($stPath))
        DllStructSetData($stINFO, 6, DllStructGetPtr($stArgs))
        DllStructSetData($stINFO, 7, DllStructGetPtr($stWDir))
        DllStructSetData($stINFO, 8, $iState)
     
        Local $aRet = DllCall("shell32.dll", "int", "ShellExecuteEx", "ptr", DllStructGetPtr($stINFO))
        If Not IsArray($aRet) Or Not $aRet[0] Then Return SetError(2, 0, 0)
     
        Return 1
    EndFunc
     
     
     


    Всего записей: 434 | Зарегистр. 07-09-2002 | Отправлено: 18:49 15-02-2008
    ViSiToR



    Silver Member
    Редактировать | Профиль | Сообщение | ICQ | Цитировать | Сообщить модератору
    baic

    Цитата:
    если убираю...MsgBox(0, "Example", @DesktopCommonDir & "\Inet1.lnk")...то ярлык Inet1.lnk не запускается

    Очень странно... можно вместо MsgBox поставить паузу - Sleep(100) .
     
    Какого типа этот ярлык? обычный ярлык, или с системными свойствами (как ярлык для MS Word к примеру).

    ----------
    ViSiToR a.k.a CreatoR
    CreatoR это не ник, CreatoR это стиль жизни!

    Всего записей: 3251 | Зарегистр. 01-04-2006 | Отправлено: 19:43 15-02-2008
    elchupakabra



    Advanced Member
    Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
    Еще такой вопрос... поставил билд 3.2.10.0, теперь откомпилированные им скрипты не декомпилируются (пишет, что скрипт не был скомпилирован AutoIt), с 3.2.4.9 такой проблемы не было. Это решаемо?

    Всего записей: 1571 | Зарегистр. 05-11-2005 | Отправлено: 19:49 15-02-2008
    ViSiToR



    Silver Member
    Редактировать | Профиль | Сообщение | ICQ | Цитировать | Сообщить модератору

    Цитата:
    откомпилированные им скрипты не декомпилируются

    Декомпилляция не поддерживается с версии позже 3.2.5.1. Об этом напоминается в самом декомпилляторе
     

    Цитата:
    Это решаемо?

    Теоретический да, но мне лично не попадались подобные декомпиляторы

    ----------
    ViSiToR a.k.a CreatoR
    CreatoR это не ник, CreatoR это стиль жизни!

    Всего записей: 3251 | Зарегистр. 01-04-2006 | Отправлено: 20:23 15-02-2008
    baic

    Full Member
    Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
    ViSiToR
     
    ...ярлык Inet1.lnk для подключения к интернету...ADSL
    ...счас по-пробую слип...
     
     
    Добавлено:
    ...слип не помог

    Всего записей: 434 | Зарегистр. 07-09-2002 | Отправлено: 08:50 16-02-2008
    ViSiToR



    Silver Member
    Редактировать | Профиль | Сообщение | ICQ | Цитировать | Сообщить модератору
    baic

    Цитата:
    ярлык Inet1.lnk для подключения к интернету...ADSL

     
    Что показывает этот скрипт:
     

    Код:
    #include <Array.au3>
     
    $aData = FileGetShortcut(@DesktopDir & "\Inet1.lnk")
     
    _ArrayDisplay($aData)

     
    А если попробовать ещё так:
     

    Код:
     
    Run(@ComSpec & ' /c start "" "' & @DesktopCommonDir & '\Inet1.lnk"', '', @SW_HIDE)

     
    И ещё вопрос на всякий случай - @DesktopCommonDir это именно то что нужно? это путь к папке C:\Documents and Settings\All Users.WINDOWS\Рабочий стол.
    Для текущего пользователя нужно использовать @DesktopDir

    ----------
    ViSiToR a.k.a CreatoR
    CreatoR это не ник, CreatoR это стиль жизни!

    Всего записей: 3251 | Зарегистр. 01-04-2006 | Отправлено: 09:10 16-02-2008
    baic

    Full Member
    Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
    ViSiToR

    Цитата:
     
    @DesktopCommonDir это именно то что нужно? это путь к папке C:\Documents and Settings\All Users.WINDOWS\Рабочий стол
     

     
    ...да именно так
     

    Цитата:
     
    #include <Array.au3>
     
    $aData = FileGetShortcut(@DesktopDir & "\Inet1.lnk")
     
    _ArrayDisplay($aData)
     

    ...не помогло
     

    Цитата:
     
    Run(@ComSpec & ' /c start "" "' & @DesktopCommonDir & '\Inet1.lnk"', '', @SW_HIDE)
     

     

    Цитата:
     
     Что показывает этот скрипт:
     

    ...создаю на рабочем столе (под админом) новое соединение с Инетом...ADSL..."добавить ярлык на рабочий стол"...вот его нужно запустить после логона...убирать галку в свойстве подключения не хотца, т.к. на этом примере хотелось бы разобраться, чем корректо можно запускать ярлыки с рабочего стола...
    ...заранее спасибо за внимание!
     
     
     
     
     
     
     
    Добавлено:
    Run....тоже не помогло...забыл дописать...

    Всего записей: 434 | Зарегистр. 07-09-2002 | Отправлено: 09:25 16-02-2008
    ViSiToR



    Silver Member
    Редактировать | Профиль | Сообщение | ICQ | Цитировать | Сообщить модератору
    baic

    Цитата:
    ...не помогло

    Это была не помощь, а пример, что на экране отобразилось? ничего? значит ярлык не четабельный.
     
    Ну а это хоть что-то показывает:
     

    Код:
    MsgBox(0, "", FileExists(@DesktopCommonDir & '\Inet1.lnk'))

     
    ?
     

     
     
    P.S
    Для подсоединения с интернетом можно использовать:
     

    Код:
    Rasdial.exe "имя_подключения" "login" "password"


    ----------
    ViSiToR a.k.a CreatoR
    CreatoR это не ник, CreatoR это стиль жизни!

    Всего записей: 3251 | Зарегистр. 01-04-2006 | Отправлено: 09:41 16-02-2008
    baic

    Full Member
    Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
    ViSiToR
    [quote]
     Ну а это хоть что-то показывает:
     Код:
    MsgBox(0, "", FileExists(@DesktopCommonDir & '\Inet1.lnk'))
    [quote]
    показывает 1
     
    Добавлено:
    сори за...

    Всего записей: 434 | Зарегистр. 07-09-2002 | Отправлено: 09:58 16-02-2008
    Maza Faka



    Advanced Member
    Редактировать | Профиль | Сообщение | ICQ | Цитировать | Сообщить модератору
    XpycTMD

    Цитата:
    Вопрос а как сделать чтобы при выборе даты их календаря она записывалась в файл соответсвующий определенному сотруднику???

    Привет. Наконец-то нашёл время посмотреть твой код. В общем такой пример:
    в папке D:\Database имеются *.ini файлы с именами сотрудников, например ivanov.ini, petrov.ini и т.д., формат *.ini-файла такой, как ты приводил, при нажатии на кнопку "Set" происходит запись дат в *.ini-файл с именем сотрудника, если, что не понятно, спрашивай.

    Код:
    #NoTrayIcon
    #include
    <GUIConstants.au3>
    #include <File.au3>
    #include <Array.au3>
     
    Opt("GuiOnEventMode", 1)
     
    $Filter = "*.ini"
    $Flag = "1"
     
    $dbPatch = "D:\Database"
     
    $Version = "0.7"
    $ProgramTitle = "Crew Manager " & $Version
     
    $GUIWidth
    = 800
    $GUIHeight = 600
    $GUILeft = (@DesktopWidth - $GUIWidth) / 2
    $GUITop = (@DesktopHeight - $GUIHeight) / 2
    $CrewListTop = 120
     
    $CrewManager = GUICreate($ProgramTitle, $GUIWidth, $GUIHeight, $GUILeft, $GUITop, $WS_VISIBLE + $WS_CLIPSIBLINGS + $WS_OVERLAPPEDWINDOW)
    GUISetFont(10, 400, 0, "Tahoma")
    GUICtrlCreateLabel("Crew Manager", 210, 0, 555, 65, $SS_CENTER + $SS_CENTERIMAGE)
    GUICtrlSetFont(-1, 38, 800, 0, "Tahoma")
    GUICtrlSetColor(-1, 0x0000FF)
    GUISetOnEvent($GUI_EVENT_CLOSE, "Quit")
     
    GUICtrlCreateLabel("PPC", 125, 70, 255, 20, $SS_CENTER + $SS_CENTERIMAGE)
    GUICtrlSetFont(-1, 10, 800, 0, "Tahoma")
     
    GUICtrlCreateLabel("PPC Passed Date", 125, 95, 125, 20, $SS_CENTER + $SS_CENTERIMAGE)
    GUICtrlSetFont(-1, 10, 800, 0, "Tahoma")
     
    GUICtrlCreateLabel("PPC Next Date", 260, 95, 125, 20, $SS_CENTER + $SS_CENTERIMAGE)
    GUICtrlSetFont(-1, 10, 800, 0, "Tahoma")
     
    $Crew = _FileListToArray($dbPatch, $Filter, $Flag)
    If @error Then
        MsgBox(16, "??????", "??? *.ini ?????? ? ???????? " & $dbPatch)
        Exit
    EndIf

     
    $PPCPassedDate = $Crew
    $PPCPassedDateChecker
    = $Crew
    $PPCNextDate
    = $Crew
    $PPCNextDateChecker
    = $Crew
    $SetButton
    = $Crew
    $hPPC_Passed_Date
    = $Crew
    $hPPC_Next_Date
    = $Crew
     
    For $i = 1 To $Crew[0]
        GUICtrlCreateLabel(StringReplace($Crew[$i], ".ini", ""), 10, $CrewListTop, 110, 25, $SS_CENTERIMAGE)
        GUICtrlSetFont(-1, 10, 800, 0, "Tahoma")
     
        $PPCPassedDate[$i] = IniRead($dbPatch &"\"& $Crew[$i], "PPC", "PPCPassedDate", "0000/00/00")
        $ReadDate = _ParsStringDate($PPCPassedDate[$i])
     
        $hPPC_Passed_Date[$i] = GUICtrlCreateDate($ReadDate, 125, $CrewListTop, 105, 25, $DTS_SHORTDATEFORMAT)
     
        $PPCPassedDateChecker[$i] = GUICtrlCreateLabel("", 230, $CrewListTop, 25, 25, $WS_BORDER)
     
        $PPCNextDate[$i] = IniRead($dbPatch &"\"& $Crew[$i], "PPC", "PPCNextDate", "0000/00/00")
        $ReadDate = _ParsStringDate($PPCNextDate[$i])
     
        $hPPC_Next_Date[$i] = GUICtrlCreateDate($ReadDate, 260, $CrewListTop, 105, 25, $DTS_SHORTDATEFORMAT)
     
        $PPCNextDateChecker[$i] = GUICtrlCreateLabel("", 365, $CrewListTop, 25, 25, $WS_BORDER)
     
        $SetButton[$i] = GUICtrlCreateButton("Set", 400, $CrewListTop, 50, 25)
        GUICtrlSetOnEvent(-1, "_WriteDate")
     
        $CrewListTop = $CrewListTop + 30
    Next
     
    GUISetState(@SW_SHOW)
     
    While 1
        Sleep(100)
    WEnd
     
    Func
    Quit()
        Exit
    EndFunc
     
    Func
    _ParsStringDate($sString)
        Local $DateSplit, $sDate
        $DateSplit
    = StringSplit($sString, ".")
     
        For $i = $DateSplit[0] To 1 Step -1
            $sDate &= $DateSplit[$i] & "/"
        Next
     
        Return
    $sDate
    EndFunc
     
    Func
    _WriteDate()
        Local $iSearchIdnex, $iPassedDate, $iNextDate
     
        $iSearchIndex
    = _ArraySearch($SetButton, @GUI_CtrlId, 1)
        If @error Then Return
     
        $iPassedDate = GUICtrlRead($hPPC_Passed_Date[$iSearchIndex])
        $iNextDate = GUICtrlRead($hPPC_Next_Date[$iSearchIndex])
     
        IniWrite($dbPatch &"\"& $Crew[$iSearchIndex], "PPC", "PPCPassedDate", $iPassedDate)
        IniWrite($dbPatch &"\"& $Crew[$iSearchIndex], "PPC", "PPCNextDate", $iNextDate)
    EndFunc

    Всего записей: 1420 | Зарегистр. 25-10-2006 | Отправлено: 15:22 16-02-2008
    XpycTMD

    Junior Member
    Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
    NIKZZZZ
    Спасибо большое то что надо
     
    Maza Faka
    Спасибо большое. А вариант записи возможен только по средством кнопки, просто хотелось чтобы дата при выборе в календаре сразу записывалась в фаил. А то практира показывает что надо который будет работать с программой не внимательный и может забыть нажать на кнопку.
    И еще вопрос для чего вот это функция

    Код:
    Func _ParsStringDate($sString)
        Local $DateSplit, $sDate
        $DateSplit
    = StringSplit($sString, ".")
     
        For $i = $DateSplit[0] To 1 Step -1
            $sDate &= $DateSplit[$i] & "/"
        Next
     
        Return
    $sDate
    EndFunc

     
    Добавлено
    Вопрос снят. Сделал так

    Код:
    $hPPC_Passed_Date[$i] = GUICtrlCreateDate($ReadDate, 125, $CrewListTop, 105, 25, $DTS_SHORTDATEFORMAT)
    GUICtrlSetOnEvent(-1, "_WriteDate")

     

    Всего записей: 120 | Зарегистр. 17-01-2006 | Отправлено: 10:49 17-02-2008 | Исправлено: XpycTMD, 10:58 17-02-2008
    NIKZZZZ



    Gold Member
    Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
    Есть такой вопрос по DllCallback.
     
    DllCallback функция принимает следующие параметры:
     

    Код:
    //
    //Callback function:
    //
    Callback(
        IN      DWORD msgId,    // message ID
        IN      WPARAM param1,   // usually file name
        INOUT   LPARAM param2,   // usually error code
        IN      void  *unused
        )
     
        //first parameter: full file path for if  MSG_PROCESS, message string for others
        TCHAR *message  = (TCHAR *) param1;
        TCHAR *filePath = (TCHAR *) param1;
        DWORD percent   = (DWORD)   param1;
     
        //second parameter: message back to caller if MSG_PROCESS, error code for others
        DWORD errorCode = param2;
        DWORD *msg_back = (DWORD *) param2;

     
    Здесь msgId отределяет , что такое param1 - число или указатель на строку. Функция DllCallbackRegister() допускает только однозначное трактование каждого параметра. В связи с этим распознавание типа param1 приходится делать в самой функции.
    .......

    Код:
    $pCallBack = DllCallbackRegister('CallBack', 'int', 'dword;WPARAM;LPARAM;dword')
    .......
    Func CallBack($msgId, $param1,$a,$b)
      Switch $msgId
        Case $MSG_PROGRESS
          $Percent=$param1
          ..........
        Case $MSG_PROCESS
          $Str=DllStructCreate('wstr[1024]',$param1)
          $FilePath=DllStructGetData($Str,1)
          ..........
      EndSwitch
    EndFunc

     
    Часть ,определяющая $FilePath не работает, но если ее заменить на
     

    Код:
        Case $MSG_PROCESS
          $Str=DllStructCreate('ushort[1024]',$param1)
          $FilePath=''
          $i=1
          While 0
            $Tmp=DllStructGetData($s2,1,$i)
            If $Tmp=0 Then ExitLoop
            $FilePath&=Chrw($Tmp)
            $i+=1
          WEnd
          .......

     
    все нормально. Это баг ?
     
     

    Всего записей: 5365 | Зарегистр. 08-02-2006 | Отправлено: 17:48 17-02-2008 | Исправлено: NIKZZZZ, 17:53 17-02-2008
    NIKZZZZ



    Gold Member
    Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
    Еще одна проблема - при длительной работе DllCall GUI окно перестает обновляться, хотя Callback функция постоянно его изменяет. Можно ли обновить окно принудительно ?

    Всего записей: 5365 | Зарегистр. 08-02-2006 | Отправлено: 10:13 18-02-2008
    ViSiToR



    Silver Member
    Редактировать | Профиль | Сообщение | ICQ | Цитировать | Сообщить модератору
    NIKZZZZ

    Цитата:
    Это баг ?

    Трудно сказать, не видно всей картины
     

    Цитата:
    при длительной работе DllCall GUI окно перестает обновляться, хотя Callback функция постоянно его изменяет

    Известное ограничение в AutoIt - при вызове Dll, копировании файлов, выводе MsgBox и несколько других функции, осноавная работа скрипта останавливается. CallBack поможет только на уровне функционала, с графикой в этом случае будут всегда проблемы. Как вариант, вешать вызов Dll на внешний скрипт, при необходимости можно возвращать данные в родительский скрипт .
     

    Цитата:
    Можно ли обновить окно принудительно ?

    Можно попробовать _WinAPI_RedrawWindow(). Хотя это зависит от того, в каких целях нужно обновлять окно.

    ----------
    ViSiToR a.k.a CreatoR
    CreatoR это не ник, CreatoR это стиль жизни!

    Всего записей: 3251 | Зарегистр. 01-04-2006 | Отправлено: 11:05 18-02-2008
    Loopback



    Junior Member
    Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
    NIKZZZZ

    Цитата:
    все нормально. Это баг ?

    А что это за "wstr" такой интересный в DllStructCreate('wstr[1024]',$param1)? Может быть "wchar" имелось в виду? Думаю, если вставить проверку @error после этого вызова, то будет видно, что структура не создается.

    Всего записей: 174 | Зарегистр. 08-03-2002 | Отправлено: 22:56 18-02-2008
    NIKZZZZ



    Gold Member
    Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
    Loopback

    Цитата:
    А что это за "wstr"


    Просто не подумав написал по аналогии с
     $pCallBack = DllCallbackRegister('CallBack', 'int', 'dword;WSTR;LPARAM;dword')
     
     
     
    Добавлено:
    Еще странный глюк.

    Код:
    Func Function1()
      Local $dll
      $dll = DllOpen($apifunc)
      Do
        $pCallBack = DllCallbackRegister('CallBack', 'int', .........)
        DllCall($dll, "ptr", 'RegisterMessageCallback', 'ptr', 0, 'ptr', DllCallbackGetPtr($pCallBack), 'ptr', 0)
        DllCall($dll, "ptr", "Function1", ........)
      Until True
      DllClose($dll)
      DllCallbackFree($pCallBack)
    EndFunc
     
    Func CallBack()
      ......
    EndFunc  

     
    Так вот DllClose($dll) выдает ошибку $dll - "Variable used without being declared." Таким же образом теряются другие локальные переменные DllCallbackFree($pCallBack) - $pCallBack тоже не определена. Если сделать эти переменные глобальными, проблема исчезает. В примере опущен контроль ошибок, но в реальной программе он есть и ошибок не выдает.
    Без CallBack - ошибок нет.
     
     
    Добавлено:
    ViSiToR

    Цитата:
    Известное ограничение в AutoIt - при вызове Dll, копировании файлов, выводе MsgBox и несколько других функции, осноавная работа скрипта останавливается. CallBack поможет только на уровне функционала, с графикой в этом случае будут всегда проблемы. Как вариант, вешать вызов Dll на внешний скрипт, при необходимости можно возвращать данные в родительский скрипт

     
    А может быть , что CallBack вызывается одновременно несколько раз (первый вызов до конца не отработан, а уже поступил следующий) ? Что при этом будет с графикой ?  

    Всего записей: 5365 | Зарегистр. 08-02-2006 | Отправлено: 03:48 19-02-2008 | Исправлено: NIKZZZZ, 04:31 19-02-2008
    ViSiToR



    Silver Member
    Редактировать | Профиль | Сообщение | ICQ | Цитировать | Сообщить модератору
    NIKZZZZ

    Цитата:
    DllClose($dll) выдает ошибку $dll - "Variable used without being declared."

    Это может зависеть от того, что выполняет CallBack функция. Хотя странное поведение, переменная не должна удаляться пока функция обрабатывается.
     
    Можешь привести полный (простой) пример воспроизведения бага? Если это баг, то обязательно нужно репортить, это довольно серъёзная ошибка.
     
    Добавлено:

    Цитата:
    А может быть , что CallBack вызывается одновременно несколько раз

    Может, смотря как вызывать первую инстанцию, возможно (ненарошно) рекурсивно вызываются CallBack'и.
     

    Цитата:
    Что при этом будет с графикой ?  

    Возможно незаконченная прорисовка части (или всех) элементов. Я с этим сталкивался пару раз (с GUICtrlRegisterMsg() + DllCallBackResister()).
     
    Во-первых не забываем, что CallBack в AutoIt появился недавно (он конечно присутствовал в другой форме и раньше, но не так доступен был "пользователю"), поэтому проблемы могут быть разные.
     
    Во-вторых, в AutoIt есть значительное (если юзать CallBack и т.п) ограничение на буфиризацию, поэтому при обработке функции могут быть сбои/задержки, нагружать многочисленными вызовами (под)функции не желательно, часть к примеру, можно повесить на главный цикл
     
    Добавлено:
    Тест показывающий, что переменная, объявленная локально в функции, не удаляется при её объявлении (с тем же именем) в другой (под)функции глобально/локально:
     

    Код:
     
    TestFunc()
     
    Func TestFunc()
        Local $Var = 1
     
        Local $hCallBack = DllCallbackRegister("CallBackFunc", "none", "hwnd;int;int;dword")
        Local $aDll = DllCall("user32.dll", "int", "SetTimer", "hwnd", 0, "int", 0, "int", 100, "ptr", DllCallbackGetPtr($hCallBack))
     
        Sleep(2000)
     
        DllCall("user32.dll", "int", "KillTimer", "hwnd", 0, "int", $aDll[0])
        DllCallbackFree($hCallBack)
     
        ConsoleWrite($Var)
    EndFunc
     
    Func
    CallBackFunc($hWnd, $nMsg, $wParam, $lParam)
        Global $Var = 0
        ;Dim $Var = 0
        ;Local $Var = 0

    EndFunc


    ----------
    ViSiToR a.k.a CreatoR
    CreatoR это не ник, CreatoR это стиль жизни!

    Всего записей: 3251 | Зарегистр. 01-04-2006 | Отправлено: 04:48 19-02-2008 | Исправлено: ViSiToR, 05:13 19-02-2008
    NIKZZZZ



    Gold Member
    Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
    ViSiToR

    Цитата:
    $dll - "Variable used without being declared."

    Провел тест - данная ошибка возникает только в случае, если CallBack вызван одновременно несколько раз.
       
     
     
     
    Добавлено:
    ViSiToR

    Цитата:
    Как вариант, вешать вызов Dll на внешний скрипт, при необходимости можно возвращать данные в родительский скрипт

    А как реально это сделать?

    Всего записей: 5365 | Зарегистр. 08-02-2006 | Отправлено: 05:58 19-02-2008
    ViSiToR



    Silver Member
    Редактировать | Профиль | Сообщение | ICQ | Цитировать | Сообщить модератору
    NIKZZZZ

    Цитата:
    как реально это сделать?

    Пример проверки соединения с интернетом:
     

    Код:
    #include <GuiConstants.au3>
     
    Global $AppTitle = "My App"
     
    $Main_GUI = GUICreate($AppTitle, 300, 200)
     
    $Reciever_Edit = GUICtrlCreateEdit("", -500, -500)
    GUICtrlSetState(-1, $GUI_HIDE)
     
    $CheckConnection_Button = GUICtrlCreateButton("Check Connection", 20, 160, 120, 20)
     
    GUISetState()
     
    While 1
        Switch GUIGetMsg()
            Case $GUI_EVENT_CLOSE
                Exit
            Case
    $CheckConnection_Button
                $InetIsConnected
    = _InetIsConnected() = 1
                MsgBox(64, "Results", "Inet is Connected: " & $InetIsConnected)
        EndSwitch
    WEnd
     
    Func
    _InetIsConnected()
        Local $sScript_Content = '#NoTrayIcon' & @CRLF
        $sScript_Content &= '$hWinInetDll = DllOpen("wininet.dll")' & @CRLF
        $sScript_Content &= 'If $hWinInetDll = -1 Then SendDataToParent(SetError(1, 0, -1))' & @CRLF
        $sScript_Content &= '$IsConnected = DllCall($hWinInetDll, "int", "InternetGetConnectedState", "int", 0, "int", 0)' & @CRLF
        $sScript_Content &= 'DllClose($hWinInetDll)' & @CRLF
        $sScript_Content &= 'If IsArray($IsConnected) Then' & @CRLF
        $sScript_Content &= '   SendDataToParent($IsConnected[0])' & @CRLF
        $sScript_Content &= 'Else' & @CRLF
        $sScript_Content &= '   SendDataToParent(False)' & @CRLF
        $sScript_Content &= 'EndIf' & @CRLF & @CRLF
        $sScript_Content &= 'Func SendDataToParent($sData)' & @CRLF
        $sScript_Content &= '   $iParent_WinHandle = WinGetHandle("[CLASS:AutoIt v3 GUI; TITLE:' & $AppTitle & ']")' & @CRLF
        $sScript_Content &= '   ControlSetText($iParent_WinHandle, "", "Edit1", $sData, 1)' & @CRLF
        $sScript_Content &= 'EndFunc' & @CRLF
     
        Local $sTmp_Script = @TempDir & "\AutoIt_Tmp_Script.call"
     
        Local $hOpen_Tmp_Script = FileOpen($sTmp_Script, 2)
        FileWrite($hOpen_Tmp_Script, $sScript_Content)
        FileClose($hOpen_Tmp_Script)
     
        RunWait(@AutoItExe & ' /ErrorStdOut /AutoIt3ExecuteScript "' & $sTmp_Script & '"', @ScriptDir, @SW_HIDE)
     
        Local $sRet_Data = GUICtrlRead($Reciever_Edit)
     
        GUICtrlSetData($Reciever_Edit, "")
        FileDelete($sTmp_Script)
     
        Return $sRet_Data
    EndFunc

     
    В этом конкретном случае, можно было передать сразу $Main_GUI, но оно не всегда возможно, в других случаях, проще создать фиктивное окно, задать ему уникальный идентификатор в качестве заголовка (циклом создавать строку идентификатора пока окно с таким заголовком существует), создать в нём Edit поле, и использовать его как комуникатор между двумя скриптами.

    ----------
    ViSiToR a.k.a CreatoR
    CreatoR это не ник, CreatoR это стиль жизни!

    Всего записей: 3251 | Зарегистр. 01-04-2006 | Отправлено: 08:13 19-02-2008
       

    Страницы: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138

    Компьютерный форум Ru.Board » Компьютеры » Программы » Закладки » AutoIT (Часть 1)
    Widok (12-01-2009 14:47): лимит страниц. продолжаем здесь


    Реклама на форуме Ru.Board.

    Powered by Ikonboard "v2.1.7b" © 2000 Ikonboard.com
    Modified by Ru.B0ard
    © Ru.B0ard 2000-2024

    BitCoin: 1NGG1chHtUvrtEqjeerQCKDMUi6S6CG4iC

    Рейтинг.ru