草庐IT

type_id_with_cv

全部标签

c++ - 如何从 HMENU 获取菜单 ID?

当用户按下F1键时,我正在尝试为我的对话窗口覆盖WM_HELP消息。该窗口有几个按钮,可通过TrackPopupMenu显示上下文菜单,以及主菜单(在顶部)。因此,此窗口中的菜单不止一个。我可以在处理WM_HELP时捕获菜单消息,但我需要知道哪个上下文菜单发送了这条消息:BOOLCMyDialog::OnHelpInfo(HELPINFO*pHelpInfo){if(pHelpInfo->iContextType==HELPINFO_MENUITEM){HMENUhMenu=(HMENU)pHelpInfo->hItemHandle;//HowtogetmenuIDfromHMENU?

windows - 使用从命令行传递给批处理文件的变量替换字符串 *./* : with nothing,

我正在扯头发。为什么没有可用于批处理脚本的调试器?我当前批处理脚本的第一步(它必须使用这种“语言”,因为我没有可以使用的c/wscript)只是删除小时部分(最初是格式为1:10的参数,最近已更改为尝试一个小时+分钟分隔符,该分隔符与set替换部分字符串的分隔符不同),因此我也可以获得参数的微小部分。到目前为止,我已经尝试过:延迟扩展-setShutdownMinute2762=!ShutdownTime2762:*.=!各种版本的标准扩展(作为一些内存中的例子):我。设置ShutdownMinute2762=%ShutdownTime2762:*.=%二.设置ShutdownMinu

Windows 内核驱动程序 : Does the "HANDLE UniqueThread" in "CLIENT_ID CreatingThreadId" is the same during the process loading?

我正在尝试编写一个APCdll注入(inject)驱动程序,我找到了this示例并考虑根据我的需要对其进行修改。在我理解了代码之后,我想到了如何修改它(我的问题由此而来)。在code,作者使用了PsLookupThreadByThreadId接收指向目标进程的ETHREAD结构的引用指针。PsLookupThreadByThreadId(pSpi->Threads[0].ClientId.UniqueThread,&Thread)但要得到SYSTEM_THREAD_INFORMATION对于UniqueThreadhandle,他用过ZwQuerySystemInformation我想

c - Detecting if stdout is a console with MS Visual compilation, mingw64提供的console

我维护一个生成二进制数据的命令行实用程序。请求时,数据可以重定向到stdout。这在stdout被重定向到管道或文件时有效,但当stdout是一个控制台时,情况就不太一样了,因为它会垃圾控制台。为了保护用户免受此类错误,程序必须检测stdout是否是控制台,并在是时退出。现在,这并不是什么新鲜事,快速浏览一下Internet就会发现多种解决方案。主要缺点是没有“通用”方法,VisualStudio需要自己的风格。我用于Visual的控制台检测器有一个缺陷:它没有检测到stdout是一个控制台当控制台由mingw提供时,我认为这意味着它是mintty。这里是相关的代码部分:#ifdefi

windows - 获取当前事件窗口的线程 ID

我需要获取事件窗口的线程ID。是否有WindowsAPI函数可以让我获取此信息?有GetCurrentThreadId函数,但它会返回调用线程的ID,而不是事件窗口线程,因此它对这个目的没有用。编辑:按照建议编辑我的问题以提供有关我为什么需要这个的额外信息,这里是:我正在实现LowLevelKeyboardProc捕获键盘输入,并且由于键盘布局因程序而异,我想确保为处理键盘的事件窗口获取布局:代码片段:HWNDactive_window=GetForegroundWindow();DWORDthread_id=GetWindowThreadProcessId(active_window

c++ - Windows/C++ : How do I determine the share name associated with a shared drive?

假设我有一个驱动器,如C:\,我想知道它是否共享以及它的共享名称(例如C$)是什么。要查明它是否共享,我可以使用NetShareCheck.然后如何将驱动器映射到它的共享名?我以为NetShareGetInfo会这样做,但看起来它采用共享名称而不是本地驱动器名称作为输入。 最佳答案 如果一切都失败了,你总是可以使用NetShareEnum并调用NetShareGetInfo在每个。 关于c++-Windows/C++:HowdoIdeterminethesharenameassociat

windows - 在 Windows XP 上 : How to create a user with read access to only one certain directory?

首先让我声明:我知道任何想要运行程序(甚至登录)的用户都必须有权访问(可能至少)Windows系统目录和%ProgramFiles中的共享库%,但我希望能够访问Skype,例如,通过与非特权用户一起运行它并确保它无法访问任何不必要的文件。p>我担心这样做的唯一方法是识别我存储我不希望该用户访问的文件的所有gazillion目录,然后创建一个可以访问这些目录的新用户组,或者运行VM中的Skype和Azureus。有没有更好的办法? 最佳答案 通常,帐户至少是Users组的成员,它确实可以访问很多东西。您可以使该帐户成为任何组的成员,或

windows - 如果我为我的程序创建一个新的文件类型,我该如何正确使用 "Open With"?

我做了一个程序。我还制作了自己的文件类型,程序可以创建、打开和编辑它。在资源管理器中,我右键单击这个新文件类型并选择“打开方式”并选择我的程序。当然,它只是打开程序而不加载文件。如何让我的程序知道它被要求在启动时打开文件?是否有“打开方式”发送的一些命令行参数? 最佳答案 是的,Windows资源管理器将文件路径作为命令行参数发送给您的应用程序的可执行文件。您可以在C#中使用args[0]或在C++中使用argv[1]来读取它。 关于windows-如果我为我的程序创建一个新的文件类型,

objective-c - Objective-C - 如何使用给定的窗口 ID 以编程方式调整窗口大小?

如何使用objective-c/cocoa以编程方式调整任何应用程序的窗口大小?到目前为止,我已经获得了应用程序名称和窗口编号,但不知道如何访问该窗口。我可以用AppleScript完成,但想用objective-c来学习它。AppleScript示例:tellapplication"SystemEvents"setfrontApptonameoffirstapplicationprocesswhosefrontmostistrueendtelltellapplicationfrontAppsetboundsofwindow1to{(screenWidth/2),0,screenWid

windows - 从登录 ID (LUID) 获取 UserToken (C++)

我正在努力更好地理解Windowssession的工作原理,所以如果我在问题中有一些奇怪的错误,请告诉我。我使用LsaEnumerateLogonSessions()获取系统中所有已登录的session。现在我有代表登录的LUID,如果我理解正确的话,它代表登录的用户或构建它的用户,如SYSTEM。现在,如果用户X启动了一个进程,Windows会为该进程提供一个代表X的token。有没有办法(在Windows服务中)从LUID获取用户的token?我知道我可以从进程HANDLE中获取它,但这不是我想要的。 最佳答案 您可以使用Lsa