• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            旅途

            如果想飛得高,就該把地平線忘掉

            Internet Explorer編程簡述(七)

            1、概述

            Internet Explorer有實在太多沒有公布的東西。上一篇文章《Internet Explorer 編程簡述(六)自定義瀏覽器上下文菜單》提到的獲取“編碼”菜單的方法就是利用了瀏覽器的上層窗口“Shell DocObject View”的未公布的命令ID。本文將要介紹的是如何用這個ID把“編碼”菜單放到我們自己的菜單中來(如工具條上的“編碼”按鈕的下拉菜單)。

            #define SHDVID_GETMIMECSETMENU 27
            ......
            CComPtr spCT;

            hr = pcmdTarget->QueryInterface(IID_IOleCommandTarget, (void**)&spCT);
            ......
            // Get the language submenu
            hr = spCT->Exec(&CGID_ShellDocView, SHDVID_GETMIMECSETMENU, 0, NULL, &var);

            2、原理

            上面指向IOleCommandTarget接口的智能指針spCT是從IDocHostUIHandler::ShowContextMenu的參數pcmdTarget得到的,它其實也可以從HTML文檔接口得到,這就是實現的關鍵。

            3、實現

            下面的代碼演示了如何將“編碼”菜單放置到我們自己的編碼菜單上去。

            void CMainFrame::OnDropDown( NMHDR* pNotifyStruct, LRESULT* pResult )

            {

             const UINT CmdID_GetMimeSubMenu = 27;

             // Command ID for getting the Encoding submenu

             NMTOOLBAR* pNMToolBar = ( NMTOOLBAR* )pNotifyStruct;

             CMenu menu;

             CMenu* pPopup = 0;

             CMyHtmlView *pView = NULL;

             m_bIsEncodMenuPopup = false;//標志變量,用以在WM_INITMENUPOPUP消息處理函數中檢查“編碼”菜單

             switch ( pNMToolBar->iItem )

             {

             ......
             case ID_VIEW_ENCODE://按下“編碼”按鈕

             {

              m_bIsEncodMenuPopup = true;

              VERIFY( menu.LoadMenu( IDR_ENCODE ) );//IDR_ENCODE是預置的“編碼”菜單資源,內含任意一項占位用的菜單

              CMyHtmlView = GetActiveMyHtmlView();//檢查當前是否存在活動的瀏覽器視圖窗口

              if ( pView != NULL )

              {

               LPDISPATCH lpDispatch =pView->GetHtmlDocument();//獲得文檔指針

               if ( lpDispatch != NULL )

               {

                // Get an IDispatch pointer for the IOleCommandTarget interface.

                IOleCommandTarget * pCmdTarget = NULL;

                HRESULT hr = lpDispatch->QueryInterface(IID_IOleCommandTarget, (void**)&pCmdTarget);

                if ( SUCCEEDED( hr ) )

                {

                 VARIANT varEncSubMenu;

                 ::VariantInit( &varEncSubMenu );

                 hr = pCmdTarget->Exec( &::CGID_ShellDocView, CmdID_GetMimeSubMenu, OLECMDEXECOPT_DODEFAULT, NULL, &varEncSubMenu );

                 if ( SUCCEEDED( hr ) )

                 {

                  // 添加“編碼”菜單

                  MENUITEMINFO miiEncoding;

                  ::memset( &miiEncoding, 0, sizeof(MENUITEMINFO) );

                  miiEncoding.cbSize = sizeof(MENUITEMINFO);

                  miiEncoding.fMask = MIIM_SUBMENU;

                  miiEncoding.hSubMenu = reinterpret_cast< HMENU > (varEncSubMenu.byref);

                  menu.SetMenuItemInfo(0, &miiEncoding, TRUE);//丟掉設計時占位用的菜單,替換為“編碼”菜單

                  }

                }

               }

              }

              pPopup = menu.GetSubMenu( 0 );

              break;

             }

             ......

             }

             

             if ( pPopup != 0 )

             {

              CRect rc;

              ::SendMessage( pNMToolBar->hdr.hwndFrom, TB_GETRECT, pNMToolBar->iItem, ( LPARAM )&rc );

              rc.top = rc.bottom;

              ::ClientToScreen( pNMToolBar->hdr.hwndFrom, &rc.TopLeft() );

              long lResult = pPopup->TrackPopupMenu( TPM_LEFTALIGN | TPM_LEFTBUTTON | TPM_RETURNCMD, rc.left, rc.top, this );

              m_bIsEncodMenuPopup = false;

              if ( pNMToolBar->iItem == ID_VIEW_ENCODE )

              {

               //其余的事教給瀏覽器去做,參考《Internet Explorer 編程簡述(五)調用IE隱藏的命令(中文版)

                CFindIEWnd FindIEWnd( pView->m_wndBrowser.m_hWnd, "Internet Explorer_Server");

               ::SendMessage( FindIEWnd.m_hWnd, WM_COMMAND, MAKEWPARAM(LOWORD(lResult), 0x0), 0 );

              }

              else

              {

               SendMessage( WM_COMMAND, MAKEWPARAM(LOWORD(lResult), 0x0), 0 );

              }

             }

             *pResult = TBDDRET_DEFAULT;

            }


            void CMainFrame::OnInitMenuPopup(CMenu* pPopupMenu, UINT nIndex, BOOL bSysMenu)

            {

             CMDIFrameWndEx::OnInitMenuPopup(pPopupMenu, nIndex, bSysMenu);

             if ( m_bIsEncodMenuPopup )

             {

              //默認情況下“編碼”的所有菜單項都是Disabled的,在此修改其狀態為Enabled

              for ( UINT i=0; i GetMenuItemCount(); i++ )

              {

               pPopupMenu->EnableMenuItem( pPopupMenu->GetMenuItemID( i ), MF_ENABLED | MF_BYCOMMAND );

              }

             }

            }

            這樣一來,原本只在瀏覽器上下文菜單中出現的“編碼”菜單就出現在了我們自己的工具條按鈕下拉菜單上,無需更多的處理,菜單狀態的改變,編碼的設置等,一切都教給瀏覽器自己去完成了。


            posted on 2007-07-29 15:18 旅途 閱讀(506) 評論(0)  編輯 收藏 引用 所屬分類: BHO

            亚洲国产精品无码久久一线| 久久精品视频网| 青青草国产成人久久91网| 99久久国产亚洲高清观看2024 | 久久午夜福利无码1000合集| 国产精品久久久久久久app| 少妇无套内谢久久久久| 国产精品久久久久久久| 久久久久久国产a免费观看不卡| 一本久久精品一区二区| 久久久久久亚洲AV无码专区| 亚洲午夜精品久久久久久app| 2021国内久久精品| 色偷偷888欧美精品久久久| 亚洲国产成人乱码精品女人久久久不卡 | 综合久久一区二区三区 | www亚洲欲色成人久久精品| 亚洲熟妇无码另类久久久| 热久久视久久精品18| 国产午夜精品理论片久久| 久久综合九色综合久99| 亚洲国产成人精品91久久久| 国产精品成人久久久久三级午夜电影| 久久久久久国产a免费观看不卡| 国产精品久久久久久久| 午夜人妻久久久久久久久| 久久性生大片免费观看性| 久久伊人影视| 99久久婷婷国产一区二区| 97久久国产亚洲精品超碰热| 久久久久久久久久久精品尤物| 伊人久久国产免费观看视频| 久久久久久久综合日本| 久久AAAA片一区二区| 亚洲国产精品久久| 中文字幕成人精品久久不卡| 色噜噜狠狠先锋影音久久| 国产精品久久久久一区二区三区| 久久精品国产91久久综合麻豆自制 | 久久av高潮av无码av喷吹| 99久久精品无码一区二区毛片 |