Страницы: 1
RSS
список всех открытых окон
 
Добрый день!
Пытаюсь сделать скрипт, запускающий приложение, делающий окно активным и имитирующий в нем нажатие ^r. Определять полный путь к .exe приложения сделал. А как получить точное имя окна?
Заранее спасибо
 
Для посыла сочетания клавиш в запущенное приложение не обязателно искать имя окна. Его можно присвоить переменной при запуске, или же просто, если не подразумевается периодическое к нему обращение, запустить напрямую (если запускаете через shell, то, при указании параметра vbNormalFocus, окно приложения становится активно). Можете добавить Wait на какое-то время для загрузки приложения, и дальше через SendKeys мучаете его.
Читайте справку по функции Shell
F1 творит чудеса
 
в сети есть код, но дебагер ругается на Private Declare Function ProcessFirst Lib
система W8.1 64, MSO 365
код здесь:
http://www.vbstreets.ru/VB/Articles/65502.aspx
Код
'Объявляем используемые функции
Private Declare Function CreateToolhelpSnapshot Lib "Kernel32" Alias "CreateToolhelp32Snapshot" (ByVal lFlags As Long, ByVal lProcessID As Long) As Long
Private Declare Function ProcessFirst Lib "Kernel32" Alias "Process32First" (ByVal hSnapShot As Long, uProcess As PROC_INFO) As Long
Private Declare Function ProcessNext Lib "Kernel32" Alias "Process32Next" (ByVal hSnapShot As Long, uProcess As PROC_INFO) As Long
'Теперь объявим процедуру. Именно процедуру, а не функцию!!!
Private Declare Sub CloseHandle Lib "Kernel32" (ByVal hPass As Long)
'Теперь константы
Private Const TH32CS_SNAPPROCESS As Long = 2&
Private Const MAX_PATH As Integer = 260
'Теперь наши типы данных
Public Type PROC_INFO
dwordSize As Long
Usage As Long
ProcessID As Long
DefaultHeapID As Long
ModuleID As Long
Threads As Long
ParentProcessID As Long
ClassBase As Long
dwordFlags As Long
FileSize As String * MAX_PATH
End Type
'Public, т.к. в формах и т.д. будет использован этот же тип. Его будем возвращать.
'Теперь функция
Public Function GetProcInfo(mInfo As PROC_INFO) As Boolean
' mInfo мы возвращаем
' Это локальные переменные
Dim LH_SS As Long
Dim currProcess As PROC_INFO
Dim RetVal As Long
LH_SS = CreateToolhelpSnapshot(TH32CS_SNAPPROCESS, 0&)
If LH_SS = 0 Then
GetProcInfo = False 'если ошибка, то выдаем негативное значение функции
Exit Function
End If
currProcess.dwordSize = Len(currProcess) 'меряем длину 
RetVal = ProcessFirst(LH_SS, currProcess)
Do While RetVal
RetVal = ProcessNext(LH_SS, currProcess) ' заполняем остальные данные
Loop
CloseHandle LH_SS
mInfo = currProcess 'присваиваем значение переменной
GetProcInfo = True ' сообщаем о результатах выполнения функции
End Function

Вот и все. Наверное можно было бы и проще. Да вот не придумал еще. Ах, да. Использование:
Dim MyResult as Proc_Info
call GetProcInfo(MyResult)
  
Изменено: dude - 14.10.2014 21:38:18
 
в результате основной вопрос решился с помощью Autohotkey: готовая среда для разработки с большими возможностями и меньше 10 строк кода. Если будут желающие, загружу на обменник
Страницы: 1
Наверх