利用金字塔的VBA與C++的混合編程來實(shí)現(xiàn)復(fù)雜的二次開發(fā)及交易功能 [金字塔]
- 咨詢內(nèi)容:
金字塔的除了提供基礎(chǔ)的PEL語(yǔ)言外,基于VBA和C++二次開發(fā)功能無(wú)疑是所有程序化交易軟件中最強(qiáng)的一個(gè)了,VBA金字塔完全兼容OFFICE的VBA開發(fā)習(xí)慣,C++也是很多專業(yè)用戶的開發(fā)語(yǔ)言,能將這2點(diǎn)融合成一體,無(wú)疑是金字塔用戶的最高境界了。
金字塔幾乎將所有內(nèi)部的對(duì)象接口都暴露給了VBA對(duì)象,包括數(shù)據(jù),界面操作,下單管理等,用戶可以用VBA做大部分的事情,但是VBA也有其不完美的一面,包括不能向C++那樣使用指針,金字塔VBA對(duì)網(wǎng)絡(luò)的操作支持力度有限,及VBA是解析性的語(yǔ)言腳本系統(tǒng),對(duì)安全性沒有C++哪種編譯性的高等等,因此很多專業(yè)的程序化大都會(huì)選擇C++語(yǔ)言做為編寫對(duì)象,但是C++除了給我們的編程便利性帶來好處外,也帶來了學(xué)習(xí)困難,編寫專業(yè)要求程度高等缺點(diǎn),由于金字塔未能將所有內(nèi)部操作接口對(duì)象完全暴露給C++接口,因此做為用戶來說,使用VBA與C++進(jìn)行混合編程無(wú)疑是很好的一種解決方案。利用系統(tǒng)暴露給VBA的接口進(jìn)行通訊,VBA再將其參數(shù)傳遞給C++接口,內(nèi)部的復(fù)雜運(yùn)算通過C++來實(shí)現(xiàn),最后將計(jì)算結(jié)果返回給VBA進(jìn)行界面上的處理。
金字塔暴露給VBA主要有下面幾個(gè)對(duì)象
Application 對(duì)象
代表 金字塔證券分析系統(tǒng) 應(yīng)用程序。整個(gè)應(yīng)用程序運(yùn)行過程中,只有一個(gè)Application對(duì)象存在。利用該對(duì)象可以對(duì)整個(gè)金字塔程序進(jìn)行控制。
ReportData 對(duì)象
證券行情數(shù)據(jù)對(duì)象,該對(duì)象用于表示該證券最新行情數(shù)據(jù)。
MarketData 對(duì)象
該對(duì)象描述了市場(chǎng)行情數(shù)據(jù)。可以通過這個(gè)對(duì)象來訪問指定的品種的各種數(shù)據(jù),也可以維護(hù)接收數(shù)據(jù)的設(shè)置。
Frame 對(duì)象
表示一個(gè)“框架”對(duì)像。每個(gè)框架都有一個(gè)這樣的對(duì)象與之相對(duì)應(yīng)。
你可以橫向或者縱向切分一個(gè)窗格,還可以在當(dāng)前窗格位置處添加一個(gè)窗格,此時(shí)兩個(gè)窗格將會(huì)自動(dòng)分頁(yè)顯示。
Order 對(duì)象
Order 對(duì)象負(fù)責(zé)定單管理和查詢等操作,接收委托服務(wù)器發(fā)送來的各種帳戶持倉(cāng)信息。該Order對(duì)象還支持多帳戶的下單模式,用戶可以在閃電下單時(shí)截獲該事件,并處理成自己的操作方式以達(dá)到可以實(shí)現(xiàn)比如贏損下單的目的。除此之外,該對(duì)象還支持多帳戶操作。
事件處理
上述對(duì)象除了可以直接控制金字塔軟件外,還可以被動(dòng)的接收來自軟件的各種事件,比如用戶下單后,Order 對(duì)象 就可以接收來自這個(gè)對(duì)象的事件,有了事件功能后,用戶可以就可以不用總是去不斷查詢是否有最新行情數(shù)據(jù)過來,是否下單了等等,完全可以在程序中設(shè)立條件來主動(dòng)接收事件,提高了軟件的運(yùn)行效率。
使用VISUAL C++開發(fā)ACTIVEX自動(dòng)化接口,與VBA進(jìn)行通信
我們要寫一個(gè)能與VBA通信的接口程序,通過ACTIVEX無(wú)疑是最好的方案,使用VISUAL C++開發(fā)ACTIVEX是件非常簡(jiǎn)單的事情,本教程就以此為范例制作一個(gè)可以與VBA交互使用的ACTIVEX,步驟如下:
我們以VC6.0為例。
第一步我們需要用VISUAL C++創(chuàng)建一個(gè)DLL工程,工程名稱為MyActiveXDemo
此主題相關(guān)圖片如下:qq截圖未命名1.jpg
第二步我們需要選擇是MFC標(biāo)準(zhǔn)DLL程序,并要勾選“Automation” 也就是ACTIVEX自動(dòng)化的接口選項(xiàng)。
此主題相關(guān)圖片如下:qq截圖未命名2.jpg
然后我們點(diǎn)“Finish” 按鈕后完成項(xiàng)目的初建
項(xiàng)目框架創(chuàng)建完畢后,我們就要建立一個(gè)可以與VBA通信的ACTIVEX接口,步驟如下:
Inster -> New Class 彈出新建類窗口,我們選擇MFC接口
此主題相關(guān)圖片如下:qq截圖未命名3.jpg
我們將接口類起名為VBSAddin,并指定基類是CCmdTarget,并在下方選擇類接口的創(chuàng)建方式為 type id 方式接口類創(chuàng)建好了后,剩下的就是我們通過 Class Wizard類添加屬性和方法了
比如我們創(chuàng)建一個(gè)方法函數(shù),名稱為“MyTest”,返回值可以根據(jù)項(xiàng)目的要求來任意指定,參數(shù)我們輸入一個(gè)數(shù)值參數(shù),并且在ActiveX中通過MSG打印出來
此主題相關(guān)圖片如下:qq截圖未命名5.jpg
項(xiàng)目創(chuàng)建完畢后,系統(tǒng)會(huì)自動(dòng)為我們添加代碼,加上我們的打印輸出后代碼如下:
float VBSAddin::MyTest(double Value)
{
CString strValue;
strValue.Format("%f",Value);
AfxMessageBox(strValue);return 0.0f;
}最后編譯我們的ActiveX,編譯完畢后一定注意需要注冊(cè)這個(gè)ActiveX我們才能在本地電腦中使用,比如我們將其拷貝到C盤根目錄后,通過命令行做如下注冊(cè)即可: regsvr32 c:\MyActiveXDemo.dll
最后,我們?cè)赩BA中來調(diào)用我們剛才所建立的ActiveX控件
例如我們?cè)赥est宏中輸入如下代碼
Sub Test()
Dim MyAddin '創(chuàng)建一個(gè)變量Set MyAddin = CreateObject("MyActiveXDemo.VBSAddin")
MyAddin.MyTest(400)End Sub
注意MyActiveXDemo.VBSAddin是我們?cè)趧偛艅?chuàng)建時(shí)所指定的標(biāo)識(shí)符,通過這個(gè)標(biāo)識(shí)符系統(tǒng)才能找到我們所建立的Activex
指定宏后,看看效果吧。
附帶C++演示示例工程點(diǎn)擊瀏覽該文件:myactivexdemo.rar
[此貼子已經(jīng)被作者于2012-5-6 23:08:36編輯過] - 金字塔客服:
最后說明一點(diǎn),金字塔的進(jìn)程是不允許被調(diào)試加載的,這對(duì)C++開發(fā)者來說增加調(diào)試難度,但是可以通過附加進(jìn)程調(diào)試的方法來解決問題,比如VS2008等都有很好的這種支持,詳情請(qǐng)GOOGLE搜索。
[此貼子已經(jīng)被作者于2012-5-13 9:28:11編輯過] - 用戶回復(fù):
占位
- 網(wǎng)友回復(fù):
完全贊同樓主的意見,這是金字塔區(qū)別于其他交易軟件的最強(qiáng)大的武器。
- 網(wǎng)友回復(fù): 哈哈,我就是這樣做的。
如果以上指標(biāo)公式不適用于您常用的行情軟件
或者您想改編成選股公式,以便快速選出某種形態(tài)個(gè)股的話,
相關(guān)文章
-
沒有相關(guān)內(nèi)容