Как программно установить сообщение о статусе Live Messenger?
Я хочу иметь возможность изменить статусное сообщение для Live Messenger, но все, что я нашел, работает только для музыкального сообщения (см. Этот снимок экрана, чтобы увидеть разницу между ними).
Это можно сделать, поскольку есть программы, которые могут изменить его, и некоторые альтернативные клиенты для Live Messenger также могут сами устанавливать сообщение о состоянии. Мне просто нужно знать, как сделать это самому.
Пояснение: решение должно работать с последними версиями Live Messenger (т.е. бета-версия wave 3). Работать со старыми версиями тоже хорошо, но я работаю с версиями 14.x.
5 ответов
Не существует программного способа установки сообщения о состоянии Live Messenger, который работает с версиями, включая Live Wave 3.
Конечно, из любого окна разговора все просто/psm new message
msgstr "обновить поле статуса сообщения.
Но программно:
Здесь вы найдете исходный файл VB, который отправил новое сообщение в PSM (Personal Satus Message) ваших окон Live Messenger. Может быть, это поможет.
экстракт:
Attribute VB_Name = "Form1"
Attribute VB_GlobalNameSpace = False
Attribute VB_Creatable = False
Attribute VB_PredeclaredId = True
Attribute VB_Exposed = False
Private Declare Function FindWindow Lib "user32" Alias "FindWindowA" (ByVal lpClassName As String, ByVal lpWindowName As String) As Long
Private Declare Function FindWindowEx Lib "user32" Alias "FindWindowExA" (ByVal hWnd1 As Long, ByVal hWnd2 As Long, ByVal lpsz1 As String, ByVal lpsz2 As String) As Long
Private Declare Function PostMessage Lib "user32" Alias "PostMessageA" (ByVal hwnd As Long, ByVal wMsg As Long, ByVal wParam As Long, ByVal lParam As Long) As Long
Private Const WM_COMMAND = &H111
Private Const WM_CHAR = &H102
Private Const VK_RETURN = &HD
Private Function SetPSM(ByVal text As String) As Boolean
Dim hParentWnd, hChildWnd As Long
SetPSM = False
hParentWnd = FindWindow("MSBLWindowClass", vbNullString)
If hParentWnd <> 0 Then
hChildWnd = FindWindowEx(hParentWnd, 0, "DirectUIHWND", vbNullString)
If hChildWnd <> 0 Then
PostMessage hParentWnd, WM_COMMAND, 56606, 0
Dim i As Integer
For i = 1 To Len(text)
Call PostMessage(hChildWnd, WM_CHAR, Asc(Mid$(text, i, 1)), 0)
Next i
PostMessage hChildWnd, WM_CHAR, VK_RETURN, 0
SetPSM = True
End If
End If
End Function
Private Sub cmdSetPSM_Click()
SetPSM txtPSM.text
End Sub
Вы можете установить поверх MSN MsgPlus, который даст вам API для программирования через MSN. Затем вы можете создать скрипт, который вызывает вашу программу или программу, которая вызывает MSN.
Вы могли бы пойти на грязный обходной путь, используя функции Windows API для имитации пользовательского ввода.