• <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>
            隨筆 - 181  文章 - 15  trackbacks - 0
            <2008年11月>
            2627282930311
            2345678
            9101112131415
            16171819202122
            23242526272829
            30123456

            常用鏈接

            留言簿(1)

            隨筆分類

            隨筆檔案

            My Tech blog

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            ???????? 目錄
            ??????? com方式調用matlab(一)
            ??????? com方式調用matlab(二)?
            ??????? com方式調用matlab(三)
            ??????? com方式調用matlab(四)?
            ??????? com方式調用matlab(五)
            ??????? com方式調用matlab(六)
            ??????? com方式調用matlab(附:運行結果及代碼)
            ??????? 在前面粗略描述了系統的設計思路和matlab生成com組件的相關知識后,從現在開始,將要討論一下具體的實現方面的問題.在本部分,我們首先討論一下配置文件的格式和內容,然后再探討一下以com方式調用matlab進行繪圖的相關技術.
            ??????? 前面曾經說到過我們將要把matlab所生成的組件的相關信息,包括組件GUID,接口RIID以及方法參數寫到一個配置文件里面去,這樣我們的vc程序就能夠以可擴充的方式使用matlab組件了.下面是我所設計的配置信息的一個例子:

            ??? 上面的配置文件里面包含三個圖像的配置,分別是圖 1 ,圖 2 和圖 3 。他們具有相同的結構。下面分別說一下配置文件各個部分的信息。

            ???????? Component 作為配置文件的根存在。

            ?????????Graph 子節點代表一個圖。仔細看一下, Graph 子節點又包含以下子節點:

            ???????? GUID :組件的全局 ID 。他用來唯一標示一個組件。

            ???????? RIID :接口相對于組件的 ID 。通過 GUID RIID 你就可以唯一找到你想構建的那個接口。

            ???????? Method :接口方法。其中的 MethodName 為接口方法的名稱; Param 為接口方法的參數。 Param Name 屬性為借口方法參數的名稱。

            ????另外, Graph 節點包含兩個屬性。其中:

            ????????PhysicalName 為組件文件的物理路徑。 vc程序 根據這個物理路徑來找到組件。其實對于組件來講,在注冊表中進行注冊以后,就在相應系統中建立了組件的全局索引。任何程序只要根據 GUID RIID 就可以找到組件,完全不需要知道物理路徑。但是在開發程序的時候,本著這樣一個宗旨,就是讓軟件綠色一些,盡量在不注冊的前提下使用組件。當然基于 Matlab 組件對于一些核心模塊的依賴,這種思路沒有成功。但是這種調用方式對于其他程序而言是可以借鑒的。所以這里還是維持了這種思路。

            ????????Name 為組件顯示名稱。 vc程序 中根據這個名稱創建下拉列表供用戶進行選擇。

            ??? 下面依照一個例子來說明配置文件是如何進行編寫的。
            ????

            ???? 在這里創建的組件的名稱為 c2 。在 c2 組件的工作目錄中(具體見com方式調用matlab(二)),進入 src 目錄,打開 c2_idl_i.c 文件。如下圖所示的信息為我們需要填入 xml 的信息。
            ???? matlabxml1.JPG

            ??? 可以看到,上面的為 RIID ,下面的為 GUID 。那么如何進行區別呢? GUID 一般是以 CLSID 為前綴的。而 RIID 是以 IID 為前綴的。值得注意的是,這里要將 GUID RIID 修改成 8-4-4 -4-12 16 進制)的形式。否則在 CM 中無法識別。在得到這兩個信息以后,我們再去找到接口方法的相關信息。打開 c2_com.cpp 文件,會看到如下信息:
            ??? matlabxml2.JPG
            ???? 這里就是接口方法了.把相關信息填入method節點,一個matlab圖的配置就寫完了.值得注意的是,matlab接口方法的參數順序和我們調用的順序剛好相反,比如對于上面的方法聲明,我們在配置里面就得這么寫:
            ???? matlabxml3.JPG
            ?????具體原因可能和參數的壓棧方法有關,這里我也沒有深究,如果有人對于具體細節了解的比較詳細,希望您能不吝賜教.
            ?????通過上面的步驟,我們就完成了配置文件的設計并完成了一個例子.下面來看一看使用matlab組件的具體方法.

            ???? 其實通過com方式調用matlab進行圖形繪制確實不難,對于稍有com組件知識的人來講,尤為如此.簡單的講,首先使用DllGetClassObject函數創建類廠,然后用類廠獲取IDispatch接口,然后用IDispatch接口通過方法的名稱調用方法.下面是具體的實現:
            ????

            bool ?CMatlabGraph::DrawGraph(CString?sGraphName) // 繪圖
            {
            ????
            if ( ! this -> m_pcfg)
            ????
            {
            ????????
            this -> m_sError = " 獲取配置文件失敗! " ;
            ????????
            return ? false ;
            ????}

            ????
            if ( ! m_pcfg -> FindGraphInfoByName( this ,sGraphName))
            ????
            {
            ????????
            this -> m_sError = m_pcfg -> m_sError;
            ????????
            return ? false ;
            ????}

            ????::CoInitialize(NULL);

            ????IDispatch? * pIDisp = NULL;
            ????
            // 指向讀入的組件文件的句柄
            ????HINSTANCE?hinstLib;
            ????
            // 指向類廠的實例化方法
            ????MYPROC?ProcAdd;
            ????BOOL?fRunTimeLinkSuccess?
            = ?FALSE;
            ????
            // int?rtn=0;
            ????
            // 讀取組件文件載入內存
            ????hinstLib? = ?LoadLibrary( this -> m_sComFileName.GetBuffer(m_sComFileName.GetLength()));
            ????
            // 如果執行成功,則hinstLib非空
            ???? if ?(hinstLib? != ?NULL)?
            ????
            {
            ????????
            // 讀取指向獲取類廠的函數的指針
            ????????ProcAdd? = (MYPROC)GetProcAddress(hinstLib,? " DllGetClassObject " );
            ????????
            // ?如果獲取成功,則創建類廠
            ???????? if ?(fRunTimeLinkSuccess? = ?(ProcAdd? != ?NULL))
            ????????
            {
            ????????????
            // 類廠接口
            ????????????IClassFactory? * pIf;
            ????????????
            // 初始類廠接口為空
            ????????????pIf = NULL;
            ????????????
            if (SUCCEEDED(ProcAdd(m_clsid,IID_IClassFactory,( void ? ** ) & pIf)) && (pIf != NULL))
            ????????????
            {
            ????????????????
            if ( ! SUCCEEDED(pIf -> CreateInstance(NULL,m_riid,( void ? ** ) & pIDisp)) || (pIDisp == NULL))
            ????????????????
            {
            ????????????????????????pIf
            -> Release();
            ????????????????????????pIf
            = NULL;
            ????????????????????????FreeLibrary(hinstLib);
            ????????????????????????::CoUninitialize();
            ????????????????????????
            return ? false ;
            ????????????????}

            ????????????????m_hinstLib
            = hinstLib;
            ????????????????
            // 因為已經取得分發接口,故釋放類廠接口
            ????????????????pIf -> Release();
            ????????????????pIf
            = NULL;
            ????????????????
            // 根據名稱查找接口方法
            ????????????????USES_CONVERSION;
            ????????????????OLECHAR?FAR
            * ?szMember? = ?T2OLE((LPCTSTR)( this -> m_sMethodName.GetBuffer( this -> m_sMethodName.GetLength())));
            ????????????????
            // 獲取方法ID
            ????????????????DISPID?MethodID;
            ????????????????
            if ( ! SUCCEEDED(pIDisp -> GetIDsOfNames(IID_NULL, & szMember, 1 ,LOCALE_SYSTEM_DEFAULT, & MethodID)))
            ????????????????
            {
            ????????????????????
            this -> m_sError = " 取接口方法ID失敗 " ;
            ????????????????????
            return ? false ;
            ????????????????}

            ????????????????
            // 填入參數
            ????????????????DISPPARAMS?dispparams? = ? {? this -> m_pvars,?NULL,? this -> m_nparacount,? 0 } ;
            ????????????????
            // 調用方法
            ????????????????HRESULT?hr = pIDisp -> Invoke(MethodID,IID_NULL,GetUserDefaultLCID(),DISPATCH_METHOD, & dispparams,NULL,NULL,NULL);
            ????????????????
            if ( ! SUCCEEDED(hr))
            ????????????????
            {
            ????????????????????
            this -> m_sError.Format( " 調用失敗!錯誤碼:%x " ,hr);? // ="調用失敗!";
            ????????????????????FreeLibrary(hinstLib);
            ????????????????????::CoUninitialize();
            ????????????????????
            return ? false ;
            ????????????????}

            ????????????????
            // 釋放文件
            ????????????????
            // FreeLibrary(hinstLib);
            ????????????????
            // ::CoUninitialize();
            ???????????????? return ? true ;????
            ????????????}

            ????????}

            ????}

            ????::CoUninitialize();
            ????
            return ? false ;
            }
            ??????? 下面是CMatlabGraph的類定義:
            class?CMatlabGraph??
            {
            public:
            ????CMatlabGraph(CGraphConfiguration?
            *cfg);
            ????
            virtual?~CMatlabGraph();
            ????
            bool?DrawGraph(CString?sGraphName);//繪圖
            ????CString?m_sError;//錯誤信息
            private:
            ????CLSID?m_clsid;
            //組件對象ID
            ????IID?m_riid;//接口ID
            ????CString?m_sMethodName;//接口方法名稱
            ????CString?m_sComFileName;//組件文件名稱
            ????CComVariant?*m_pvars;//接口方法參數
            ????CGraphConfiguration?*m_pcfg;//配置
            ????int?m_nparacount;//接口方法參數個數
            ????friend?class?CGraphConfiguration;
            ????HINSTANCE?m_hinstLib;
            }
            ;

            ??????? 當然,看上去本部分介紹的兩塊內容似乎關系不大,那么在接下去的幾篇隨筆里面將會對配置文件和具體組件調用程序的銜接方法作比較詳細的說明。

            posted on 2006-08-11 19:50 littlegai 閱讀(890) 評論(0)  編輯 收藏 引用 所屬分類: 我的代碼玩具
            亚洲AV成人无码久久精品老人| 国产精品99久久久久久人| 国产成人久久激情91| 久久精品国产亚洲av麻豆图片 | 色播久久人人爽人人爽人人片aV | 亚洲精品成人网久久久久久| 久久久久久国产精品美女| 精品久久久久一区二区三区| 999久久久无码国产精品| 亚洲精品99久久久久中文字幕| 久久综合给合久久国产免费 | 国产精品久久久久…| 久久国产精品99精品国产987| 精品午夜久久福利大片| 伊人丁香狠狠色综合久久| 久久er国产精品免费观看8| 久久中文字幕精品| 久久精品国产精品亚洲毛片| 国产精品xxxx国产喷水亚洲国产精品无码久久一区 | 人妻丰满?V无码久久不卡| 久久国产劲爆AV内射—百度| 久久男人中文字幕资源站| 久久人人爽人人爽人人片AV东京热 | 色播久久人人爽人人爽人人片aV | 精品久久久久久亚洲精品 | 中文字幕亚洲综合久久2| 亚洲中文字幕无码久久2020| 久久久久国产一区二区| 亚洲乱亚洲乱淫久久| 久久精品成人国产午夜| 99精品国产在热久久无毒不卡| 久久人做人爽一区二区三区 | 久久久久国产一级毛片高清版| 18岁日韩内射颜射午夜久久成人| 色婷婷久久久SWAG精品| 国产三级久久久精品麻豆三级| 久久久久国产成人精品亚洲午夜| 91久久精品无码一区二区毛片| 成人资源影音先锋久久资源网| 99久久人妻无码精品系列蜜桃| 蜜臀av性久久久久蜜臀aⅴ|