|
|
|
функция SetWindowPos
|
|||
|---|---|---|---|
|
#18+
подскажите, пожалуйста, как работает функция SetWindowPos. какие бы я ей координаты не давал, окно растягивается на весь экран. почему? ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 19.04.2006, 16:39 |
|
||
|
функция SetWindowPos
|
|||
|---|---|---|---|
|
#18+
Код: plaintext 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 19.04.2006, 16:58 |
|
||
|
функция SetWindowPos
|
|||
|---|---|---|---|
|
#18+
да, теперь не на весь экран. но все равно не так, какие координаты указаны, если не сказать честно, вообще никак не меняется при их изменении. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 19.04.2006, 17:08 |
|
||
|
функция SetWindowPos
|
|||
|---|---|---|---|
|
#18+
kb_nn, ну нельзя же быть таким ленивым! SWP_NOSIZE уберите. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 19.04.2006, 17:21 |
|
||
|
функция SetWindowPos
|
|||
|---|---|---|---|
|
#18+
не помогло.... ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 20.04.2006, 10:17 |
|
||
|
функция SetWindowPos
|
|||
|---|---|---|---|
|
#18+
Что значит не помогло? Код приведите. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 20.04.2006, 10:33 |
|
||
|
функция SetWindowPos
|
|||
|---|---|---|---|
|
#18+
слушайте, я вот что обнаружил. перед SetWindowPos у меня стоял msgbox с дескриптором окна. он оказывается портил все дело. если его выкинуть, у меня вырезается кусок в окне, (меняющемся в зависимости от параметра hWndInsertAfter в SetWindowPos), как раз по размеру и положению равный параметрам SetWindowPos и в нем виден рабочий стол. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 20.04.2006, 11:36 |
|
||
|
функция SetWindowPos
|
|||
|---|---|---|---|
|
#18+
такое чувство, что это дескриптор совершенно другого окна Option Explicit Public Declare Function MoveWindow Lib "user32" (ByVal hwnd As Long, ByVal x As Long, ByVal y As Long, ByVal nWidth As Long, ByVal nHeight As Long, ByVal bRepaint As Long) As Long Public Declare Function SetWindowPos Lib "user32" (ByVal hwnd As Long, ByVal hWndInsertAfter As Long, ByVal x As Long, ByVal y As Long, ByVal cx As Long, ByVal cy As Long, ByVal wFlags As Long) As Long Public Declare Function GetWindow Lib "user32" (ByVal hwnd As Long, ByVal wCmd As Long) As Long Public Declare Function GetWindowThreadProcessId Lib "user32" (ByVal hwnd As Long, lpdwProcessId As Long) As Long Public Declare Function GetDesktopWindow Lib "user32" () As Long Public Const GW_HWNDFIRST = 0 Public Const GW_HWNDNEXT = 2 Public Const GW_CHILD = 5 Public Function fnGetWindowHwndByProcessID(lngProcessID As Long) As Long Dim lngCurProcessID As Long Dim lngRetVal As Long Dim hwndTemp As Long On Error GoTo HandleErr hwndTemp = GetDesktopWindow() hwndTemp = GetWindow(hwndTemp, GW_CHILD) Do While hwndTemp <> 0 lngRetVal = GetWindowThreadProcessId(hwndTemp, lngCurProcessID) If lngCurProcessID = lngProcessID Then fnGetWindowHwndByProcessID = hwndTemp Exit Do End If hwndTemp = GetWindow(hwndTemp, GW_HWNDNEXT) Loop Exit Function HandleErr: fnGetWindowHwndByProcessID = 0 End Function Sub Main() Dim lngProcessID As Long Dim AppName As String Dim hwnd As Long Const SWP_FRAMECHANGED = &H20 ' The frame changed: send WM_NCCALCSIZE Const SWP_DRAWFRAME = SWP_FRAMECHANGED Const SWP_HIDEWINDOW = &H80 Const SWP_NOACTIVATE = &H10 Const SWP_NOCOPYBITS = &H100 Const SWP_NOMOVE = &H2 Const SWP_NOOWNERZORDER = &H200 ' Don't do owner Z ordering Const SWP_NOREDRAW = &H8 Const SWP_NOREPOSITION = SWP_NOOWNERZORDER Const SWP_NOSIZE = &H1 Const SWP_NOZORDER = &H4 Const SWP_SHOWWINDOW = &H40 Const HWND_BOTTOM = 1 Const HWND_BROADCAST = &HFFFF& Const HWND_DESKTOP = 0 Const HWND_NOTOPMOST = -2 Const HWND_TOP = 0 Const HWND_TOPMOST = -1 AppName = "C:\WINDOWS\explorer.exe" lngProcessID = Shell(AppName, vbNormalFocus) hwnd = fnGetWindowHwndByProcessID(lngProcessID) SetWindowPos hwnd, HWND_TOP, 0, 0, 500, 380, SWP_SHOWWINDOW 'Or SWP_NOACTIVATE Or SWP_NOMOVE Or SWP_NOSIZE End Sub пс, простите, не нашел как выделить код. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 21.04.2006, 12:51 |
|
||
|
функция SetWindowPos
|
|||
|---|---|---|---|
|
#18+
У меня ваша fnGetWindowHwndByProcessID возвращает ноль. Попробуйте через FindWindow. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 21.04.2006, 13:20 |
|
||
|
функция SetWindowPos
|
|||
|---|---|---|---|
|
#18+
нет, у меня не 0. а нормальное 6-7 значное число. 0 у меня вылазит в том случае, если это окно уже открыто, а я его хочу открыть второй раз. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 21.04.2006, 13:58 |
|
||
|
функция SetWindowPos
|
|||
|---|---|---|---|
|
#18+
такое чувство, что это дескриптор совершенно другого окна Option Explicit Public Declare Function MoveWindow Lib "user32" (ByVal hwnd As Long, ByVal x As Long, ByVal y As Long, ByVal nWidth As Long, ByVal nHeight As Long, ByVal bRepaint As Long) As Long Public Declare Function SetWindowPos Lib "user32" (ByVal hwnd As Long, ByVal hWndInsertAfter As Long, ByVal x As Long, ByVal y As Long, ByVal cx As Long, ByVal cy As Long, ByVal wFlags As Long) As Long Public Declare Function GetWindow Lib "user32" (ByVal hwnd As Long, ByVal wCmd As Long) As Long Public Declare Function GetWindowThreadProcessId Lib "user32" (ByVal hwnd As Long, lpdwProcessId As Long) As Long Public Declare Function GetDesktopWindow Lib "user32" () As Long Public Const GW_HWNDFIRST = 0 Public Const GW_HWNDNEXT = 2 Public Const GW_CHILD = 5 Public Function fnGetWindowHwndByProcessID(lngProcessID As Long) As Long Dim lngCurProcessID As Long Dim lngRetVal As Long Dim hwndTemp As Long On Error GoTo HandleErr hwndTemp = GetDesktopWindow() hwndTemp = GetWindow(hwndTemp, GW_CHILD) Do While hwndTemp <> 0 lngRetVal = GetWindowThreadProcessId(hwndTemp, lngCurProcessID) If lngCurProcessID = lngProcessID Then fnGetWindowHwndByProcessID = hwndTemp Exit Do End If hwndTemp = GetWindow(hwndTemp, GW_HWNDNEXT) Loop Exit Function HandleErr: fnGetWindowHwndByProcessID = 0 End Function Sub Main() Dim lngProcessID As Long Dim AppName As String Dim hwnd As Long Const SWP_FRAMECHANGED = &H20 ' The frame changed: send WM_NCCALCSIZE Const SWP_DRAWFRAME = SWP_FRAMECHANGED Const SWP_HIDEWINDOW = &H80 Const SWP_NOACTIVATE = &H10 Const SWP_NOCOPYBITS = &H100 Const SWP_NOMOVE = &H2 Const SWP_NOOWNERZORDER = &H200 ' Don't do owner Z ordering Const SWP_NOREDRAW = &H8 Const SWP_NOREPOSITION = SWP_NOOWNERZORDER Const SWP_NOSIZE = &H1 Const SWP_NOZORDER = &H4 Const SWP_SHOWWINDOW = &H40 Const HWND_BOTTOM = 1 Const HWND_BROADCAST = &HFFFF& Const HWND_DESKTOP = 0 Const HWND_NOTOPMOST = -2 Const HWND_TOP = 0 Const HWND_TOPMOST = -1 AppName = "C:\WINDOWS\explorer.exe" lngProcessID = Shell(AppName, vbNormalFocus) hwnd = fnGetWindowHwndByProcessID(lngProcessID) SetWindowPos hwnd, HWND_TOP, 0, 0, 500, 380, SWP_SHOWWINDOW 'Or SWP_NOACTIVATE Or SWP_NOMOVE Or SWP_NOSIZE End Sub пс, простите, не нашел как выделить код. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 21.04.2006, 13:59 |
|
||
|
функция SetWindowPos
|
|||
|---|---|---|---|
|
#18+
Еще раз повторяю: ваша функция фозвращает что-то не то - используйте FindWindow, например. Кстати, если поменять в вашем коде "explorer" на "notepad", все прекрасно работает. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 21.04.2006, 14:40 |
|
||
|
функция SetWindowPos
|
|||
|---|---|---|---|
|
#18+
Findwindow - это же надо знать заголовок окна. как мне его узнать? я уже с ней изрядно помучился. кстати, что касается NOTEPAD, то единственное, в чем разница - при повторном открытии дескриптор ненулевой. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 21.04.2006, 15:07 |
|
||
|
функция SetWindowPos
|
|||
|---|---|---|---|
|
#18+
мне известен только путь к файлу. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 21.04.2006, 15:09 |
|
||
|
функция SetWindowPos
|
|||
|---|---|---|---|
|
#18+
у меня заработало, большое вам спасибо! Option Explicit Public Declare Function SetWindowPos Lib "user32" (ByVal hwnd As Long, ByVal hWndInsertAfter As Long, ByVal x As Long, ByVal y As Long, ByVal cx As Long, ByVal cy As Long, ByVal wFlags As Long) As Long Private Declare Function FindWindow Lib "user32" Alias "FindWindowA" (ByVal lpClassName As Long, ByVal lpWindowName As Long) As Long Private Declare Function GetParent Lib "user32" (ByVal hwnd As Long) As Long Private Declare Function GetWindowThreadProcessId Lib "user32" (ByVal hwnd As Long, lpdwProcessId As Long) As Long Private Declare Function GetWindow Lib "user32" (ByVal hwnd As Long, ByVal wCmd As Long) As Long Private Declare Function LockWindowUpdate Lib "user32" (ByVal hwndLock As Long) As Long Private Declare Function GetDesktopWindow Lib "user32" () As Long Private Declare Function Putfocus Lib "user32" Alias "SetFocus" (ByVal hwnd As Long) As Long Const GW_HWNDNEXT = 2 Dim hWnd As Long Function InstanceToWnd(ByVal target_pid As Long) As Long Dim test_hwnd As Long, test_pid As Long, test_thread_id As Long 'Find the first window test_hwnd = FindWindow(ByVal 0&, ByVal 0&) Do While test_hwnd <> 0 'Check if the window isn't a child If GetParent(test_hwnd) = 0 Then 'Get the window's thread test_thread_id = GetWindowThreadProcessId(test_hwnd, test_pid) If test_pid = target_pid Then InstanceToWnd = test_hwnd Exit Do End If End If 'retrieve the next window test_hwnd = GetWindow(test_hwnd, GW_HWNDNEXT) Loop End Function Private Sub Main() Const HWND_TOPMOST = -1 Const SWP_SHOWWINDOW = &H40 Dim Pid As Long Dim i As Integer LockWindowUpdate GetDesktopWindow Pid = Shell("c:\windows\notepad.exe", vbNormalFocus) If Pid = 0 Then MsgBox "Error starting the app" hWnd = InstanceToWnd(Pid) SetWindowPos hWnd, HWND_TOPMOST, 0, 0, 512, 384, SWP_SHOWWINDOW Putfocus hWnd LockWindowUpdate False End Sub ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 24.04.2006, 11:22 |
|
||
|
функция SetWindowPos
|
|||
|---|---|---|---|
|
#18+
слушайте. у меня опять проблемы. функция Shell что, работает только с exe- шниками? что-то для некоторых (например txt,doc) у меня возникает ошибка Invalid procedure Call or Argument и SetWindowPos работает не для всех запущенных приложений. от чего это может зависеть? ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 24.04.2006, 13:45 |
|
||
|
функция SetWindowPos
|
|||
|---|---|---|---|
|
#18+
kb_nnслушайте. у меня опять проблемы. функция Shell что, работает только с exe- шниками? Вы совершенно правы. Если хотите открывать другие типы файлов - вам сюда. kb_nn и SetWindowPos работает не для всех запущенных приложений. от чего это может зависеть? А хэндлы точно правильные берете? Может, ресайз в этих приложениях вообще не предусмотрен? ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 24.04.2006, 13:50 |
|
||
|
функция SetWindowPos
|
|||
|---|---|---|---|
|
#18+
насчет Shell спасибо, буду пробовать. а насчет ресайза - ну вручную-то я могу его изменить, отсюда следует, что это может сделать SetWindowPos ? что касается хендлов, то для некоторых файлов это работает прекрасно. а для каких-то нет. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 24.04.2006, 16:18 |
|
||
|
функция SetWindowPos
|
|||
|---|---|---|---|
|
#18+
авторПричем здесь процесс? AllApi The GetExitCodeProcess function retrieves the termination status of the specified process. If the function succeeds, the return value is nonzero. If the function fails, the return value is zero. kb_nn например notepad.exe она мне открыла в текстовом виде, а explorer.exe предложила сохранить из с:\windows. Скорее всего это связано с политиками безопаности Windows. Когда вы а командной строке выполняете "explorer.exe", что происходит? Не стоило ради этого старый топик поднимать, у вас уже есть один такой же. нет, если я запускаю их через командную строку, то все нормально. что- то я совем запутался. как мне иметь возможность открыть совершенно произвольный файл, чтобы иметь возможность работать с его окном.?? ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 25.04.2006, 13:01 |
|
||
|
функция SetWindowPos
|
|||
|---|---|---|---|
|
#18+
Код: plaintext 1. 2. 3. 4. 5. 6. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 25.04.2006, 13:18 |
|
||
|
функция SetWindowPos
|
|||
|---|---|---|---|
|
#18+
kb_nn что- то я совем запутался. как мне иметь возможность открыть совершенно произвольный файл, чтобы иметь возможность работать с его окном.?? Что-то вы меня совсем запутали. Ссылку на то, как вам открыть произвольный файл, я вам дал. Но объясните, что вы собрались открывать с помощью explorer.exe? Какое вообще отношение ко всему этому имеет explorer? ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 25.04.2006, 13:42 |
|
||
|
функция SetWindowPos
|
|||
|---|---|---|---|
|
#18+
explorer.exe был примером открываемого окна. ладно, файлы у меня открываются теперь, любого типа, спасибо. но вот SetWindowPos на получаемый дескриптор не реагирует... ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 25.04.2006, 15:38 |
|
||
|
функция SetWindowPos
|
|||
|---|---|---|---|
|
#18+
всё таки проблема изменения размеров функцией SetWindowPos остается. дескриптор получается ненулевой. в каких-то случаях все работает нормально., в каких-то нет вручную размеры я могу задать не могу понять от чего это может зависеть. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 26.04.2006, 17:56 |
|
||
|
функция SetWindowPos
|
|||
|---|---|---|---|
|
#18+
я обнаружил такую вещь- SetWindowPos у меня работает только для Вордовских файлов. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 27.04.2006, 12:20 |
|
||
|
|

start [/forum/topic.php?fid=60&msg=33688673&tid=2165892]: |
0ms |
get settings: |
8ms |
get forum list: |
19ms |
check forum access: |
3ms |
check topic access: |
3ms |
track hit: |
171ms |
get topic data: |
7ms |
get forum data: |
2ms |
get page messages: |
43ms |
get tp. blocked users: |
1ms |
| others: | 254ms |
| total: | 511ms |

| 0 / 0 |
