DOCUMENT:Q153570 11-JAN-2001 [vbwin] TITLE :How to Pass One OLE Control to Another PRODUCT :Microsoft Visual Basic for Windows PROD/VER:4.00 | 4.00 OPER/SYS: KEYWORDS: ====================================================================== ------------------------------------------------------------------------------- The information in this article applies to: - Microsoft Visual Basic Standard Edition, 32-bit, for Windows, version 4.0 - Microsoft Visual Basic Professional Edition, 16-bit, for Windows, version 4.0 - Microsoft Visual Basic Professional Edition, 32-bit, for Windows, version 4.0 - Microsoft Visual Basic Enterprise Edition, 16-bit, for Windows, version 4.0 - Microsoft Visual Basic Enterprise Edition, 32-bit, for Windows, version 4.0 ------------------------------------------------------------------------------- SUMMARY ======= It is possible to pass an OLE Automation Object as a parameter to a method of a custom OLE control (.OCX). To do this, declare the OCX method to take a parameter of type IDispatch *. An OLE control is essentially an OLE Automation Object, so you can then pass one OLE Control to another using this technique. MORE INFORMATION ================ In Visual Basic 4.0, all OLE controls except the intrinsic controls (TextBox, PictureBox, Label, and so on) implement an Object Property. Except for the OLE container control, this Object property refers to the primary IDispatch interface of that OLE control. So, if you pass the object property of any OLE control except the OLE container control to a method of another custom OLE control, a pointer to the primary IDispatch interface (LPDISPATCH) of the source OLE control is what is passed, so you can then access the methods and properties of the source OLE control through this LPDISPATCH inside your custom OLE control method. If you have a method declared in your custom OLE control source code: void CTestCtrl::PassObject(LPDISPATCH lpDisp) { // TODO: Add your dispatch handler code here ... } You can call this from Visual Basic as follows: Test1.PassObject DbGrid1.Object 'Pass the DBGrid control's primary 'dispatch interface to your custom 'control, Test1 Additional query words: 4.00 vb4win vb4all vbctrl ====================================================================== Keywords : Technology : kbVBSearch kbAudDeveloper kbVB400Search kbVB400 kbVB16bitSearch Version : 4.00 | 4.00 ============================================================================= THE INFORMATION PROVIDED IN THE MICROSOFT KNOWLEDGE BASE IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY KIND. MICROSOFT DISCLAIMS ALL WARRANTIES, EITHER EXPRESS OR IMPLIED, INCLUDING THE WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT SHALL MICROSOFT CORPORATION OR ITS SUPPLIERS BE LIABLE FOR ANY DAMAGES WHATSOEVER INCLUDING DIRECT, INDIRECT, INCIDENTAL, CONSEQUENTIAL, LOSS OF BUSINESS PROFITS OR SPECIAL DAMAGES, EVEN IF MICROSOFT CORPORATION OR ITS SUPPLIERS HAVE BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. SOME STATES DO NOT ALLOW THE EXCLUSION OR LIMITATION OF LIABILITY FOR CONSEQUENTIAL OR INCIDENTAL DAMAGES SO THE FOREGOING LIMITATION MAY NOT APPLY. Copyright Microsoft Corporation 2001.