OLE SDK——框架界面(二):IOleInPlaceFrame::SetStatusText

王朝vc·作者佚名  2006-01-08
窄屏简体版  字體: |||超大  

IOleInPlaceFrame::SetStatusText

在容器的框架窗口状态行设置和显示关于在位(in-place)对象的状态文本。

HRESULT SetStatusText(

LPCOLESTR pszStatusText //指向显示消息的指针

);

参数

pszStatusText

包含要显示消息的以空字符结束的字符串的地址。

返回值

这个方法支持标准返回值E_FAIL,E_INVALIDARG和E_UNEXPECTED,也支持下列的:

S_OK

文本被显示了。

S_TRUNCATED

一些文本被显示,但消息太长有一些被删去了。

注释

调用者注意

如果容器框架窗口有状态行,当你需要告诉容器在它的框架状态行显示对象文本时,你应该调用SetStatusText。因为窗口的框架窗口自己拥有状态行,调用IOleInPlaceFrame::SetStatusText只是让一个对象可以在窗口的框架窗口中显示状态信息的方法。如果容器拒绝了对象的请求,对应应用仍然可以协商取得边框空间来显示它自己的状态栏。

注意 当在容器所拥有的菜单和在位(in-place)对象所拥有的菜单之间切换时,如果对象没有调用容器的IOleInPlaceFrame::SetStatusText方法,状态栏文本不会被适当的反映。例如,如果在一个在位(in-place)会话期间,用户选择了File菜单,状态栏将反映用户选择的这个菜单将发生的动作。如果用户选择了Edit菜单(被在位对象所拥有的),状态栏将不会改变,除非IOleInPlaceFrame::SetStatusText发生了调用。这是因为容器没有办法分辨一个对象的菜单已经被激活,因为所有容器想捕获的消息现在都发给对象了。

实现注意

要避免潜在的问题,所有对象被在位激活都应该处理WM_MENUSELECT消息和调用IOleInPlaceFrame::SetStatusText,即使对象不提供状态信息(这样的话,对象可以刚好为请求状态文本提供一个NULL字符串。)

注意 当执行IOleInPlaceFrame::SetStatusText的时候,不可以调用Windows的PeekMessage和GetMessage函数,或一个对话框。这样做可能引起系统的死机。OLE界面的方法和函数被在GetBorder中调用,有更近一步的约束。

快速信息

Windows NT: 3.1或更高版本。

Windows: Windows 95或更高版本。

Windows CE: 不支持。

Header: oleidl.h。

参见

Win32中的PeekMessage,GetMessage

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航