- 版本 v1.1.15.01
- 指南和概述
- 常见问题(FAQ)
- 按字母排序的命令和函数索引
- AutoHotkey 脚本展示
- 变更和新功能
- 基本用法和语法
- 迁移到 AutoHotkey 1.1(AutoHotkey_L)
- 环境管理
- 本机代码互操作
- 文件、目录和磁盘管理
- Drive
- DriveGet
- DriveSpaceFree
- FileAppend
- FileCopy
- FileCopyDir
- FileCreateDir
- FileCreateShortcut
- FileDelete
- FileEncoding [AHK_L 42+]
- FileGetAttrib
- FileGetShortcut
- FileGetSize
- FileGetTime
- FileGetVersion
- FileInstall
- FileMove
- FileMoveDir
- FileOpen [AHK_L 42+]
- FileReadLine
- FileRead
- FileRecycle
- FileRecycleEmpty
- FileRemoveDir
- FileSelectFile
- FileSelectFolder
- FileSetAttrib
- FileSetTime
- IfExist / IfNotExist
- IniDelete
- IniRead
- IniWrite
- Loop(文件和文件夹)
- Loop(读取文件内容)
- SetWorkingDir
- SplitPath
- 流程控制
- 内置函数
- GUI、MsgBox、InputBox 及其他对话框
- 鼠标和键盘
- 鼠标和键盘
- #InstallKeybdHook
- #InstallMouseHook
- #KeyHistory
- BlockInput
- Click [v1.0.43+]
- ControlClick
- ControlSend / ControlSendRaw
- CoordMode
- GetKeyState
- KeyHistory
- KeyWait
- Input
- MouseClick
- MouseClickDrag
- MouseGetPos
- MouseMove
- Send / SendRaw / SendInput / SendPlay / SendEvent: 发送按键和点击
- SendLevel [v1.1.06+]
- SendMode [v1.0.43+]
- SetDefaultMouseSpeed
- SetKeyDelay
- SetMouseDelay
- SetCapsLockState/SetNumLockState/SetScrollLockState
- SetStoreCapslockMode
- 数学相关
- 屏幕管理
- 杂项命令
- 进程管理
- 注册表管理
- 声音命令
- 字符串管理
- 窗口管理
- 控件
- 窗口组
- #WinActivateForce
- DetectHiddenText
- DetectHiddenWindows
- SetTitleMatchMode
- SetWinDelay
- StatusBarGetText
- StatusBarWait
- WinActivate
- WinActivateBottom
- WinClose
- WinGet
- WinGetActiveStats
- WinGetActiveTitle
- WinGetClass
- WinGetPos
- WinGetText
- WinGetTitle
- WinHide
- WinKill
- WinMaximize
- WinMinimize
- WinMinimizeAll / WinMinimizeAllUndo
- WinMove
- WinRestore
- WinSet
- WinSetTitle
- WinShow
- WinWait
- WinWaitActive / WinWaitNotActive
- WinWaitClose
- #指令
ComObjActive() [AHK_L 53+]
检索已注册到 OLE 的正在运行的对象.
ComObject := ComObjActive(CLSID)
创建表示作为参数或返回值传递的类型化值的对象.
ParamObj := ComObjParameter(VarType, Value [, Flags])
创建在调用 COM 对象的方法时可以用来代替可选参数默认值的对象.
ParamObj := ComObjMissing()
高级
包装或解开可用对象中的原始 IDispatch 指针.
ComObject := ComObjEnwrap(DispPtr) DispPtr := ComObjUnwrap(ComObject)
参数
- CLSID
要检索的 COM 对象的 CLSID 或可读 Prog ID.
- ComObject
可以使用 对象语法 的 COM 对象.
- VarType
表示值类型的整数. 请参阅 ComObjType() 了解类型列表.
- 值
要包装的值. 当前仅支持整数值和指针值.
- Flags
影响此函数和包装器对象行为的标志,请参阅后面。
- DispPtr
原始的 IDispatch 指针.
Flags
0 | 默认行为. 为 IUnknown 和 IDispatch 指针自动调用 AddRef, 所以调用者应该在适当时使用 ObjRelease 释放这些指针副本. |
1 | 取得 IUnknown, IDispatch 或 SAFEARRAY 指针的所有权. 不调用 AddRef. 如果包装器对象包含 SAFEARRAY (VT_BYREF 除外), 那么当包装器对象被释放时会自动调用 SafeArrayDestroy. |
一般说明
ComObjActive 是 多态的; 即任何名称以 "ComObj" 开始且不匹配其他某个 COM 函数的函数调用实际在调用 ComObjActive. 例如, ComObj(9, DispPtr)
和 ComObjActive(DispPtr)
都等同于 ComObjEnwrap(DispPtr)
. 然而, 在未来的版本中此特性可能发生变化 (或实现了新的函数), 所以最好仅显示此页面中演示的形式, 此外 "ComObject" 可以用来代替 ComObjEnwrap 或 ComObjParameter.
当使用此函数包装或检索 IDispatch 或 IUnknown 接口指针时, 默认的行为会增加 COM 对象的引用数. 一般而言, 脚本中指针的原始副本被视为独立的引用, 当不再需要时必须在脚本中对其进行 手动释放. 释放包装器对象时, 也会同时释放其到 COM 对象的引用.
已知限制: 每次包装 COM 对象时, 都会创建新的包装器对象. 比较和赋值运算中, 例如 obj1 == obj2
和 array[obj1] := value
, 会把两个包装器对象视为唯一的, 即使它们包含相同的 COM 对象.
相关
ComObjCreate, ComObjGet, ComObjConnect, ComObjError, ComObjFlags, ObjAddRef/ObjRelease, ComObjQuery, GetActiveObject (MSDN)
示例
ComObjUnwrap: 请参阅 ComObjConnect.
; 示例: 传递 VARIANT ByRef 到 COM 函数. code = ( Sub Example(Var) MsgBox Var Var = "out value!" End Sub ) sc := ComObjCreate("ScriptControl"), sc.Language := "VBScript", sc.AddCode(code) var := ComVar() var[] := "in value" sc.Run("Example", var.ref) MsgBox % var[] ; ComVar: 创建用来传递 ByRef 值的对象. ; ComVar[] 检索值. ; ComVar[] := Val 设置值. ; ComVar.ref 检索 ByRef 对象用于传递到 COM 函数. ComVar(Type=0xC) { static base := { __Get: "ComVarGet", __Set: "ComVarSet", __Delete: "ComVarDel" } ; 创建含 1 个 VARIANT 类型变量的数组. 此方法可以让内部代码处理 ; 在 VARIANT 和 AutoHotkey 内部类型之间的所有转换. arr := ComObjArray(Type, 1) ; 锁定数组并检索到 VARIANT 的指针. DllCall("oleaut32\SafeArrayAccessData", "ptr", ComObjValue(arr), "ptr*", arr_data) ; 保存可用于传递 VARIANT ByRef 的数组和对象. return { ref: ComObjParameter(0x4000|Type, arr_data), _: arr, base: base } } ComVarGet(cv, p*) { ; 当脚本访问未知字段时调用. if p.MaxIndex() = "" ; 没有名称/参数, 即 cv[] return cv._[0] } ComVarSet(cv, v, p*) { ; 当脚本设置未知字段时调用. if p.MaxIndex() = "" ; 没有名称/参数, 即 cv[]:=v return cv._[0] := v } ComVarDel(cv) { ; 当对象被释放时调用. ; 必须进行这样的处理以释放内部数组. DllCall("oleaut32\SafeArrayUnaccessData", "ptr", ComObjValue(cv._)) }
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论