Форум программистов, компьютерный форум, киберфорум
Visual Basic
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/15: Рейтинг темы: голосов - 15, средняя оценка - 4.80
1 / 1 / 0
Регистрация: 09.12.2013
Сообщений: 16

Прочитать параметры запуска чужого процесса

09.12.2013, 13:25. Показов 3085. Ответов 18
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте, коллеги!
Требуется подсказка вот в каком вопросе. Запускается процесс с именем "msaccess.exe" и ему при запуске передаются параметры типа : "C:\Program Files\PIMSlider\Start_SI.vbs" "C:\Program Files\TTT\ttt.mde" /bla_bla_bla

Необходимо из другой программы найти этот процесс и прочитать путь к файлу ttt.mde. Процесс нахожу, далее :
Visual Basic
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
Dim ntStatus As Long
Dim objBasic As PROCESS_BASIC_INFORMATION 
Dim objFlink As Long
Dim objPEB As Long, objLdr As Long
Dim objBaseAddress   As   Long
Dim bytName(260 * 2 - 1) As Byte
Dim strModuleName As String, objName As Long
Dim objCid As CLIENT_ID 
Dim objOa As OBJECT_ATTRIBUTES 
Dim hProcess As Long
Dim lngRet As Long, lngReturn As Long
 
    objOa.Length = Len(objOa) 
    objCid.UniqueProcess = dwProcessId ' здесь pid процесса access.exe
    ntStatus = NtOpenProcess(hProcess, PROCESS_QUERY_INFORMATION Or PROCESS_VM_READ, objOa, objCid) 
    If hProcess = 0 Then
       GetProcessCommandLine = ""
       Exit Function
    End If
    ntStatus = NtQueryInformationProcess(hProcess, ProcessBasicInformation, VarPtr(objBasic), Len(objBasic), ByVal 0&) 
    If (NT_SUCCESS(ntStatus)) Then
       objPEB = objBasic.PebBaseAddress 
       lngRet = ReadProcessMemory(hProcess, ByVal objPEB + &H10, objLdr, 4, ByVal 0&) 
       If lngRet <> 1 Then Exit   Function
       lngRet = ReadProcessMemory(hProcess, ByVal objLdr + &H44, objName, 4, ByVal 0&) 
       If lngRet <> 1 Then Exit   Function
          lngRet = ReadProcessMemory(hProcess, ByVal objName, bytName(0), 260 * 2, ByVal 0&) 
          If lngRet <> 1 Then Exit Function
          strModuleName = bytName 
          If InStr(strModuleName, """") = 0 Then
             strModuleName = Mid(strModuleName, InStr(strModuleName, Chr(0)) + 1, Len(strModuleName) - InStr(strModuleName, Chr(0))) 
          Else
             strModuleName = Mid(strModuleName, InStr(strModuleName, """"), Len(strModuleName) - InStr(strModuleName, """")) 
          End If
          strModuleName   =   Left(strModuleName   &   Chr(0),   InStr(strModuleName   &   Chr(0),   Chr(0))   -   1) 
          GetProcessCommandLine   =   strModuleName 
       End   If
       CloseHandle   hProcess 
End   Function
В результате возвращается такая строка :
"C:\Program Files\Microsoft Office\OFFICE11\MSACCESS.EXE" -Embedding "C:\Program Files\Microsoft Office\OFFICE11\MSACCESS.EXE" WinSta0\Default ????C:\Windows\SYSTEM32\ntdll.dll ????C:\Windows\system32 ?????#???#?? ????gnp?#?#? ? ?&?????# ?#?#?#?
Где ж запрятана ссылка на базу ttt.mde, путь к которой передается процессу "msaccess.exe" как параметр? Прошу помощи
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
09.12.2013, 13:25
Ответы с готовыми решениями:

Заполнить control в окне чужого процесса?
Есть скомпилированное приложение, написанное на Дельфи, которое позволяет настроить команды для запуска другого, совершенно постороннего...

Позиционирование размера/положения окна чужого процесса
Всем привет! Постоянно администрирую маленький сервер.. При загрузке сервера на рабочем столе присутсвуют порядка 7-8 окон. из которых...

Найти некое значение в памяти чужого процесса
Здраствуйте! Возникла проблема: Хочу найти некое значение в памяти чужого процесса. пример: в памяти чужого процесса записано текстовое...

18
Модератор
10048 / 3894 / 883
Регистрация: 22.02.2013
Сообщений: 5,847
Записей в блоге: 79
09.12.2013, 14:37
Лучший ответ Сообщение было отмечено как решение

Решение

Visual Basic
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
Option Explicit
Private Type PROCESS_BASIC_INFORMATION
    ExitStatus As Long
    PebBaseAddress As Long
    AffinityMask As Long
    BasePriority As Long
    UniqueProcessId As Long
    InheritedFromUniqueProcessId As Long
End Type
Private Type UNICODE_STRING
    Length As Integer
    MaxLength As Integer
    lpBuffer As Long
End Type
Private Declare Function OpenProcess Lib "kernel32" (ByVal dwDesiredAccess As Long, ByVal bInheritHandle As Long, ByVal dwProcessId As Long) As Long
Private Declare Function CloseHandle Lib "kernel32" (ByVal hObject As Long) As Long
Private Declare Function NtQueryInformationProcess Lib "ntdll" (ByVal ProcessHandle As Long, ByVal InformationClass As Long, ByRef ProcessInformation As Any, ByVal ProcessInformationLength As Long, ByRef ReturnLength As Any) As Long
Private Declare Function ReadProcessMemory Lib "kernel32" (ByVal hProcess As Long, lpBaseAddress As Any, lpBuffer As Any, ByVal nSize As Long, lpNumberOfBytesWritten As Long) As Long
 
 
Private Const PROCESS_QUERY_INFORMATION As Long = &H400&
Private Const PROCESS_VM_READ As Long = &H10&
 
Private Sub Form_Load()
    MsgBox GetCommandLineFromPID(2956)
End Sub
Private Function GetCommandLineFromPID(PID As Long) As String
    Dim hProcess As Long
    Dim pbi As PROCESS_BASIC_INFORMATION
    Dim lpPP As Long                ' Óêàçàòåëü íà ïàðàìåòðû ïðîöåññà
    Dim cmd As UNICODE_STRING       ' Ñòðóêòóðà äëÿ õðàíåíèÿ þíèêîäíîé ñòðîêè
 
    ' Ïîëó÷àåì õåíäë
    hProcess = OpenProcess(PROCESS_QUERY_INFORMATION Or PROCESS_VM_READ, False, PID)
    If hProcess Then
        ' Ïîëó÷àåì óêàçàòåëü íà PEB
        If NtQueryInformationProcess(hProcess, 0, pbi, Len(pbi), ByVal 0) Then Exit Function
        ' Ïîëó÷àåì óêàçàòåëü íà ïàðàìåòðû ïðîöåññà
        If ReadProcessMemory(hProcess, ByVal pbi.PebBaseAddress + &H10, lpPP, 4, 0) = 0 Then Exit Function
        ' Ïîëó÷àåì ñòðóêòóðó UNICODE_STRING ñîäåðæàùóþ êîììàíäíóþ ñòðîêó
        If ReadProcessMemory(hProcess, ByVal lpPP + &H40, cmd, Len(cmd), 0) = 0 Then Exit Function
        ' ×èòàåì ñòðîêó
        GetCommandLineFromPID = Space(cmd.Length \ 2) ' Âûäåëÿåì áóôåð äîñòàòî÷íîé äëèíû
        If ReadProcessMemory(hProcess, ByVal cmd.lpBuffer, ByVal StrPtr(GetCommandLineFromPID), cmd.Length, 0) = 0 Then Exit Function
        CloseHandle hProcess
    End If
End Function
3
1 / 1 / 0
Регистрация: 09.12.2013
Сообщений: 16
09.12.2013, 15:36  [ТС]
Попробовал ваш вариант.
На выходе получается такая строка :
"C:\Program Files\Microsoft Office\OFFICE11\MSACCESS.EXE" -Embedding

Если сразу открыть файл ttt.mdb, ваш код дает строку : "C:\Program Files\Microsoft Office\OFFICE11\MSACCESS.EXE"

Может быть найденный параметр "-Embedding" говорит о том, что искомый путь лежит чуток глубже? т.е. продолжить еще одним ReadProcessMemory? это предположение
0
Модератор
10048 / 3894 / 883
Регистрация: 22.02.2013
Сообщений: 5,847
Записей в блоге: 79
09.12.2013, 16:04
Параметры командной строки получаются как я написал выше. Если в окне проводника открыть двойным кликом базу, то все должно работать (при условии что ACCESS не был запущен). Надо понимать что мы получаем параметры командной строки при запуске процесса, если ты его открыл, а потом уже в нем выбрал в меню открытие базы, или в проводнике выбрал БД, когда ACCESS уже был открыт, то получишь данные на момент запуска ACCESS'а.
Миниатюры
Прочитать параметры запуска чужого процесса  
1
1 / 1 / 0
Регистрация: 09.12.2013
Сообщений: 16
09.12.2013, 16:59  [ТС]
Да, если база открывается именно таким способом, как ты написал, я получил такой же результат.
Спасибо.
А чтобы всю командную строку прочитать, тож надо структуру peb использовать? Вопрос задаю такой, потому что есть еще другой способ запуска локальной access-базы - через ярлык. В нем указана ссылка на скрипт vbs ("C:\Program Files\Slid\Start_SI.vbs" "C:\Program Files\PIMSlider\Slid\ttt.mde"), а там оказывается, создается объект "Access.Application" и ему как раз и передается путь в виде параметра. Так что я неправильно сформулировал суть проблемы. Видать надо искать процесс "msaccess.exe", читать pid его родителя и по этому pid определять строку параметров. Так?
0
Модератор
10048 / 3894 / 883
Регистрация: 22.02.2013
Сообщений: 5,847
Записей в блоге: 79
09.12.2013, 17:10
Цитата Сообщение от vlad_07 Посмотреть сообщение
В нем указана ссылка на скрипт vbs
Для чего?
Цитата Сообщение от vlad_07 Посмотреть сообщение
А чтобы всю командную строку прочитать
Это и есть вся командная строка. Я создал ярлык базы и запустил, все тоже самое.
0
1 / 1 / 0
Регистрация: 09.12.2013
Сообщений: 16
09.12.2013, 17:50  [ТС]
Вопрос про ComandLine задал потому, что как выснилось, локальная база ttt.mde запускается непростым путем (мне приходится иметь дело с данностью, которую не изменить. Так сделано у заказчика на данный момент и не мной).
Запуск access-приложения происходит сейчас таким образом : пользователь запускает ярлык, в свойствах которого указана ссылка ("C:\Program Files\Slid\Start_SI.vbs" "C:\Program Files\Slid\ttt.mde" /xExp_main) на скрипт vbs (служит для запуска одного из 2-х access-ных приложений)
В скрипте :
Visual Basic
1
2
3
4
5
6
Set ArgObj = WScript.Arguments 
Set AccApp = CreateObject("Access.Application")
AccApp.OpenCurrentDatabase argobj(0), False
sArg = argobj(1) 
if InStr(1, sArg, "/x", 1) = 1 then sArg = Right(sArg, Len(sArg) - 2)
AccApp.DoCmd.RunMacro sArg
Надо искать строку параметров для процесса-родителя msaccess?
0
Модератор
10048 / 3894 / 883
Регистрация: 22.02.2013
Сообщений: 5,847
Записей в блоге: 79
09.12.2013, 18:13
Цитата Сообщение от vlad_07 Посмотреть сообщение
Надо искать строку параметров для процесса-родителя msaccess?
Скорее всего, т.к. из ACCESS'a ты не получешь.
1
1 / 1 / 0
Регистрация: 09.12.2013
Сообщений: 16
09.12.2013, 19:26  [ТС]
Обнаружил, что родителем, в описанной ситуации (скрипт vbs->access.exe /ttt.mde) служит программа svchost.exe, а когда подставляю ее pid в вызов процедуры для определения коммандной строки, то последняя не определяет хэндл процесса. Как такое может быть?
0
Модератор
10048 / 3894 / 883
Регистрация: 22.02.2013
Сообщений: 5,847
Записей в блоге: 79
09.12.2013, 19:45
Цитата Сообщение от vlad_07 Посмотреть сообщение
Обнаружил, что родителем, в описанной ситуации (скрипт vbs->access.exe /ttt.mde) служит программа svchost.exe, а когда подставляю ее pid в вызов процедуры для определения коммандной строки, то последняя не определяет хэндл процесса. Как такое может быть?
Вообще-то vbs скрипты выполняет WScript.exe
0
1 / 1 / 0
Регистрация: 09.12.2013
Сообщений: 16
09.12.2013, 20:50  [ТС]
Я набросал небольшую прогу, в которой с использованием CreateToolhelpSnapshot в цикле перебираются все запущенные процессы. Для каждого из них я "в лоб" запускаю твою процедуру для определения командной строки, WScript.exe в том списке нет. Для процесса msaccess.exe посмотрел th32ParentProcessID, он указывает на svchost.exe.
Как говорится, утро вечера мудренее. Мож, завтра какая-нить свежая мысль придет.
Спасибо за советы.
0
Эксперт WindowsАвтор FAQ
 Аватар для Dragokas
18031 / 7734 / 892
Регистрация: 25.12.2011
Сообщений: 11,502
Записей в блоге: 16
10.12.2013, 00:10
Process Monitor - VBScript version
0
2619 / 549 / 109
Регистрация: 21.03.2012
Сообщений: 1,051
10.12.2013, 22:48
Лучший ответ Сообщение было отмечено The trick как решение

Решение

vlad_07, если процесс запущен в единственном экземпляре, то можно воспользоваться объектной моделью самого приложения. Примерно так (ACCESS у меня отсутствует, поэтому в примере указан EXCEL):
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
Sub Test()
Dim objWMI As Object, objCollection  As Object, objApp  As Object
Set objWMI = GetObject("winmgmts:\\.\root\cimv2")
Set objCollection = objWMI.ExecQuery("SELECT * FROM Win32_Process WHERE Name='excel.exe'")
Select Case objCollection.Count
    Case 1
        Set objApp = GetObject(, "Excel.Application")
        MsgBox objApp.ActiveWorkbook.Path & "\" & objApp.ActiveWorkbook.Name
        Set objApp = Nothing
    Case 0: MsgBox "Не найдено ни одного процесса."
    Case Else: MsgBox "Найдено более одного процесса."
End Select
Set objCollection = Nothing
Set objWMI = Nothing
End Sub
1
1 / 1 / 0
Регистрация: 09.12.2013
Сообщений: 16
11.12.2013, 13:29  [ТС]
Dmitrii, спасибо. Пожалуй, для меня это как раз то, что надо. Мне ведь из комадной строки access-процесса был нужен путь к локальной базе.
А по тексту процедуры Test хочу сказать, что в запросе можно в условии выборки применять не только Name, но и имя процесса:
Visual Basic
1
2
3
4
5
    For Each Obj In GetObject("winmgmts:\\.\root\cimv2").ExecQuery _
        ("SELECT * FROM Win32_Process WHERE ProcessID=" & pid)
'       ...
'       ...
    Next
Это я дописал, мож кому-нить пригодится.
0
2619 / 549 / 109
Регистрация: 21.03.2012
Сообщений: 1,051
13.12.2013, 20:34
Цитата Сообщение от vlad_07 Посмотреть сообщение
... в запросе можно в условии выборки применять не только Name...
В контексте Вашей задачи применять можно лишь те критерии выборки, которые позволяют узнать верное количество искомых экземпляров класса. Нужно это потому, что предложенный мной способ даёт корректный результат только тогда, когда искомый процесс имеется в единственном экземпляре.
0
1 / 1 / 0
Регистрация: 09.12.2013
Сообщений: 16
14.12.2013, 23:55  [ТС]
Пробовал разные варианты получения командной строки процесса, результат таков: если приложение запускается через кнопку "Пуск", через ярлык (прямая ссылка на приложение+параметры), через командную строку+параметры, то вариант, который предложил Dmitrii 10.12.2013 в 23:51, дает ожидаемое значение командной строки. Я попробовал вариант, который также предложил Dmitrii с помощью GetObject(, "Access.Application"), вариант представлялся приемлемым, но, объект создается, а многие свойства недоступны (я ожидал, что метод CurrendDb.Name дасть путь с локальной базе, ан нет. мож в vb-скрипте че-нить изначально закрыто? я его править пока не имею права). Временно сделал так: договорился с разработчиками access-приложений, чтобы в определенный момент их приложения записывали в реестр путь к локальной базе, ну, а как его оттуда прочитать, я знаю.
Может быть в дальнейшем найдется вариант через функции работы с процессами, как сейчас сделал для exe-шников - использую api-шную фунцию GetModuleFileNameExA, с этим проблем нет.
Всем, кто присылал свои советы, спасибо!
0
Эксперт WindowsАвтор FAQ
 Аватар для Dragokas
18031 / 7734 / 892
Регистрация: 25.12.2011
Сообщений: 11,502
Записей в блоге: 16
15.12.2013, 01:28
vlad_07, ну а мой монитор что показывает?

Там используется свойство .CommandLine класса Win32_Process (WMI) - аналог конструкции тов. Dmitrii,
0
1 / 1 / 0
Регистрация: 09.12.2013
Сообщений: 16
15.12.2013, 21:01  [ТС]
Цитата Сообщение от Dragokas Посмотреть сообщение
vlad_07, ну а мой монитор что показывает?

Там используется свойство .CommandLine класса Win32_Process (WMI) - аналог конструкции тов. Dmitrii,
Честно говорю - не пробовал. Причина - глянул на вложенную картинку, и бросилась в глаза строка с Excel, для которого в командной строке написано : -e. А у меня остались еще ассоциации от аналогичной строки от access : -Embedding, ну я че-то решил, что результат будет такой же. Завтра попробую твой вариант. У нас окончательное решение еще по этой проблеме не принято, я написал в своем предыдущем посте слово "пока". У всех моих коллег по работе единодушное мнение - искать путь к файлу через процесс. Ну, а вариант с реестром, пока он будет рабочим до того момента, когда не будет найдено решение через процесс.
0
1 / 1 / 0
Регистрация: 09.12.2013
Сообщений: 16
17.12.2013, 12:40  [ТС]
Цитата Сообщение от Dragokas Посмотреть сообщение
vlad_07, ну а мой монитор что показывает?

Там используется свойство .CommandLine класса Win32_Process (WMI) - аналог конструкции тов. Dmitrii,
Из вашего скрипта создал такую программку:
Visual Basic
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
Set objWMIService = GetObject("winmgmts:\\.\root\cimv2")
Set colMonitoredEvents = objWMIService.ExecNotificationQuery("SELECT * FROM __InstanceOperationEvent WITHIN 1 WHERE TargetInstance ISA 'Win32_Process'")
Do
    Set objLatestEvent = colMonitoredEvents.NextEvent()
    Set oProc = objLatestEvent.TargetInstance
    With oProc
      ParentPID = .ParentProcessId
      If ParentPID <> 0 Then
         Set oParentProcesses = objWMIService.ExecQuery("SELECT * FROM Win32_Process WHERE ProcessId = '" & ParentPID & "'")
         If Not oParentProcesses Is Nothing Then
            For Each oParentProc In oParentProcesses
              ParentName = oParentProc.Name
            Next
            Set oParentProcesses = Nothing: Set oParentProc = Nothing
         End If
         Set oParentProc = Nothing
      End If
      ProcInfo = vbTab & Now & vbTab & .ProcessId & vbTab & .Name & vbTab & .ParentProcessId & vbTab & ParentName & vbTab & .CommandLine
If InStr(1, ProcInfo, "ttt.mde") <> 0 Then
Debug.Print ProcInfo
Exit Do
End If
      DoEvents
    End With
Loop
Set objWMIService = Nothing
Set colMonitoredEvents = Nothing
Далее:

Если сначала запустить скрипт, в котором создается "Access.Application", далее запускается access и в нем открывается ttt.mde, а потом вышеприведенную программу, то debug.print выводит такую строку:
17.12.2013 10:33:43 1892 MSACCESS.EXE 672 svchost.exe "C:\Program Files\Microsoft Office\OFFICE11\MSACCESS.EXE" -Embedding

Если сначала запустить программу, а потом скрипт msaccess.exe ...ttt.mde,
то debug.print выводит такую строку:
17.12.2013 11:05:02 2556 wscript.exe 2684 explorer.exe "C:\Windows\System32\WScript.exe" "C:\Program Files\PIMS\Start.vbs" "C:\Program Files\PIMS\ttt.mde" /xExp_main

Похоже, когда запускается скрипт на запуск access-приложений, после запуска access процесс "wscript.exe" удаляется, поэтому он и не виден в списке процессов. Надо будет править первоначальный скрипт, чтоб процесс "wscript.exe" жил, пока открыта база ttt.mde.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
17.12.2013, 12:40
Помогаю со студенческими работами здесь

Как получить параметры запуска процесса?
Просто меня заинтересовало как такое делать, т.к. прога T@sk_inspect0r умеет это получать. В инете так и не нашёл ничего путного. Заранее...

Опции, Аргументы, Ключи, Параметры, Входные данные запуска процесса. Как узнать?
Здравствуйте!!! Возможно ли в windows какими- либо способами (типа tasklist!!!) в командной строке как-нибудь получить...

Как разделить строку запуска на путь файла и параметры запуска?
Казалось бы очень странный вопрос, но тем не менее. Даже не знаю как правильно сформулировать, что бы гугл спросить. Есть массив строк...

Внедряемся в память чужого процесса
Сорри, пока писал, разобрался сам... Удалите тему плз.

Скрытие окон чужого процесса
Подскажите пожалуйста, буду благодарен.. как можно скрыть чужой процесс при запуске (например notepad) Просто скрыть, и что бы его...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
19
Ответ Создать тему
Новые блоги и статьи
Установка Emscripten SDK (emsdk) и CMake на Windows для сборки C и C++ приложений в WebAssembly (Wasm)
8Observer8 30.01.2026
Чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. Система контроля версиями Git. . .
Подключение Box2D v3 к SDL3 для Android: физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
Влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru