Stockdrv.h
上传用户:nameszq
上传日期:2014-08-12
资源大小:336k
文件大小:15k
源码类别:

金融证券系统

开发平台:

Visual C++

  1. /****************************************************************************************
  2. * WIN95 股票驱动程序 *
  3. *  西安交大数据广播研究中心 *
  4. *      1998.3.5 *
  5. *****************************************************************************************/
  6. /****************************************************************************************
  7. * 在注册库的 HKEY_LOCAL_MACHINE/SOFTWARE/StockDrv 下 * 
  8. * Driver  = "驱动DLL全路径" *
  9. * Provider= "TongShi" *
  10. ****************************************************************************************/
  11. #ifndef __STOCKDRV_H__
  12. #define __STOCKDRV_H__
  13. /////////////////////////////////////////////////////////////////////////////////////////
  14. //  以下是接口方式一,引用 DOS 方式接口,只提供行情接口,
  15. // 补充数据及消息接口按接口方式二.
  16. // 工作方式类型定义
  17. #define RCV_WORK_SENDMSG 4 // 版本 2 建议使用的方式
  18. // 其他工作方式保留
  19. // 消息类型
  20. #define RCV_REPORT 0x3f001234
  21. #define RCV_FILEDATA 0x3f001235
  22. #define TS_StockDrv_IdTxt "TongShi_StockDrv_2.00" // 通视信息卡特征串
  23. //==================================== 数据结构 =================================================
  24. // 证券市场
  25. #define SH_MARKET_EX 'HS' // 上海
  26. #define SZ_MARKET_EX 'ZS' // 深圳
  27. #define HK_MARKET_EX 'KH' // 香港
  28. // 文件数据类型
  29. // 结构数组形式的文件数据
  30. #define FILE_HISTORY_EX 2 // 补日线数据
  31. #define FILE_MINUTE_EX 4 // 补分钟线数据
  32. #define FILE_POWER_EX 6 // 补充除权数据
  33. #define FILE_BASE_EX 0x1000 // 钱龙兼容基本资料文件,m_szFileName仅包含文件名
  34. #define FILE_NEWS_EX 0x1002 // 新闻类,其类型由m_szFileName中子目录名来定
  35. #define FILE_HTML_EX 0x1004 // HTML文件,m_szFileName为URL
  36. #define FILE_SOFTWARE_EX 0x2000 // 升级软件
  37. #define FILE_SHAZQDATA_EX 0x3000 // 上海债券净价交易
  38. #define FILE_TYPE_RES -1 // 保留
  39. // 消息子类型
  40. #define News_Sha_Ex  2 // 上证消息
  41. #define News_Szn_Ex  4 // 深证消息
  42. #define News_Fin_Ex  6 // 财经报道
  43. #define News_TVSta_Ex  8 // 电视台通知
  44. #define News_Unknown_Ex  -1 // 未知提供者
  45. //Definition For nInfo of Function GetStockDrvInfo(int nInfo,void * pBuf);
  46. #define RI_IDSTRING 1 // 厂商名称,返回(LPCSTR)厂商名
  47. #define RI_IDCODE 2 // 卡号
  48. #define RI_VERSION 3 // 驱动程序版本
  49. #define RI_ERRRATE 4 // 取信道误码
  50. #define RI_STKNUM 5 // 取上市股票总家数
  51. #define RI_SUPPORTEXTHQ 6 // 是否支持JSJ格式
  52. #define RI_ENABLEDZHTRANS 7 // 支持传输大智慧文件系统
  53. #define RI_ENABLETS3FILE 8 // 支持文件传输
  54. #define STKLABEL_LEN 10 // 股号数据长度,国内市场股号编码兼容钱龙
  55. #define STKNAME_LEN 32 // 股名长度
  56. #pragma pack(1)
  57. //////////////////////////////////////////////////////////////////////////////////
  58. //国债净价交易数据
  59. typedef struct GzLxBINData {
  60. WORD m_wMarket; // 股票市场类型
  61. char m_szLabel[STKLABEL_LEN]; // 股票代码,以''结尾
  62. DWORD m_LiXiDate; //开始计算利息的日期
  63. double m_fMoney100; //每100元的利息
  64. DWORD m_DayNum;; //利息计算天数
  65. float m_fShowPrice; //票面价格
  66. }GZLXBINDATA,*PGZLXBINDATA;
  67. //////////////////////////////////////////////////////////////////////////////////
  68. //行情数据
  69. typedef struct tagRCV_REPORT_STRUCTEx
  70. {
  71. WORD m_cbSize; // 结构大小
  72. time_t m_time; // 交易时间
  73. WORD m_wMarket; // 股票市场类型
  74. char m_szLabel[STKLABEL_LEN]; // 股票代码,以''结尾
  75. char m_szName[STKNAME_LEN]; // 股票名称,以''结尾
  76. float m_fLastClose; // 昨收
  77. float m_fOpen; // 今开
  78. float m_fHigh; // 最高
  79. float m_fLow; // 最低
  80. float m_fNewPrice; // 最新
  81. float m_fVolume; // 成交量
  82. float m_fAmount; // 成交额
  83. float m_fBuyPrice[3]; // 申买价1,2,3
  84. float m_fBuyVolume[3]; // 申买量1,2,3
  85. float m_fSellPrice[3]; // 申卖价1,2,3
  86. float m_fSellVolume[3]; // 申卖量1,2,3
  87. float m_fBuyPrice4; // 申买价4
  88. float m_fBuyVolume4; // 申买量4
  89. float m_fSellPrice4; // 申卖价4
  90. float m_fSellVolume4; // 申卖量4
  91. float m_fBuyPrice5; // 申买价5
  92. float m_fBuyVolume5; // 申买量5
  93. float m_fSellPrice5; // 申卖价5
  94. float m_fSellVolume5; // 申卖量5
  95. } RCV_REPORT_STRUCTEx, *PRCV_REPORT_STRUCTEx;
  96. //////////////////////////////////////////////////////////////////////////////////
  97. //补充数据头
  98. //数据头 m_dwHeadTag == EKE_HEAD_TAG 
  99. #define EKE_HEAD_TAG 0xffffffff
  100. typedef struct tagRCV_EKE_HEADEx
  101. {
  102. DWORD m_dwHeadTag; // = EKE_HEAD_TAG
  103. WORD m_wMarket; // 市场类型
  104. char m_szLabel[STKLABEL_LEN]; // 股票代码
  105. }RCV_EKE_HEADEx,*PRCV_EKE_HEADEx;
  106. //补充日线数据
  107. typedef union tagRCV_HISTORY_STRUCTEx
  108. {
  109. struct
  110. {
  111. time_t m_time; //UCT
  112. float m_fOpen; //开盘
  113. float m_fHigh; //最高
  114. float m_fLow; //最低
  115. float m_fClose; //收盘
  116. float m_fVolume; //量
  117. float m_fAmount; //额
  118. WORD m_wAdvance; //涨数,仅大盘有效
  119. WORD m_wDecline; //跌数,仅大盘有效
  120. };
  121. RCV_EKE_HEADEx m_head;
  122. }RCV_HISTORY_STRUCTEx,*PRCV_HISTORY_STRUCTEx;
  123. //补充分时线数据
  124. typedef union tagRCV_MINUTE_STRUCTEx
  125. {
  126. struct{
  127. time_t m_time; // UCT
  128. float m_fPrice;
  129. float m_fVolume;
  130. float m_fAmount;
  131. };
  132. RCV_EKE_HEADEx m_head; 
  133. }RCV_MINUTE_STRUCTEx,*PRCV_MINUTE_STRUCTEx;
  134. //补充除权数据
  135. typedef union tagRCV_POWER_STRUCTEx
  136. {
  137. struct
  138. {
  139. time_t m_time; // UCT
  140. float m_fGive; // 每股送
  141. float m_fPei; // 每股配
  142. float m_fPeiPrice; // 配股价,仅当 m_fPei!=0.0f 时有效
  143. float m_fProfit; // 每股红利
  144. };
  145. RCV_EKE_HEADEx m_head;
  146. }RCV_POWER_STRUCTEx,*PRCV_POWER_STRUCTEx;
  147. typedef struct tagRCV_SHAGZ_STRUCTEx
  148. {
  149. WORD m_wMarket; // 市场类型
  150. char m_szLabel[STKLABEL_LEN]; // 股票代码
  151. DWORD m_StartDate; //开始计算利息的日期 YYMMDD format
  152. double m_fLiXi100RMB; //票面100员的
  153. DWORD m_DayNum;
  154. float m_fPrice;
  155. }RCV_SHAGZ,*PRCV_SHAGZ;
  156. //////////////////////////////////////////////////////////////////////////////////
  157. // 文件类型数据包头
  158. //  注一:
  159. // m_wDataType == FILE_BASE_EX
  160. // m_dwAttrib = 股票证券市场,m_szFileName仅包含文件名
  161. // m_FileTime = 基本面资料文件创建日期
  162. //  m_wDataType == FILE_NEWS_EX
  163. // m_dwAttrib = 消息来源,m_szFileName 包含目录的文件名,目录名为消息来源
  164. // m_dwSerialNo = 序列号
  165. // 如:  "上交所消息\0501Z012.TXT","新兰德\XLD0001.TXT"
  166. //  m_wDataType == FILE_HTML_EX
  167. // m_dwAttrib 保留, m_szFileName为URL
  168. // m_wDataType == FILE_SOFTWARE_EX
  169. // m_dwAttrib 分析软件类型, 用于初步判断
  170. // m_szFileName 分析软件 ID 特征字符串 + '\' + 文件名
  171. // 如 "TongShi\TS\RECEIVE\RECEIVE.EXE",
  172. // ID 特征字符串为 "TongShi", "TS\RECEIVE\RECEIVE.EXE" 为文件名
  173. // 特征字符串 和 文件名及其含义由分析软件商定义
  174. //  注二:
  175. // 数据文件循环播出,每个文件有唯一的序列号,以避免重复接收
  176. typedef struct tagRCV_FILE_HEADEx
  177. {
  178. DWORD m_dwAttrib; // 文件子类型
  179. DWORD m_dwLen; // 文件长度
  180. union 
  181. {
  182. DWORD m_dwSerialNo; // 序列号,对股评
  183. time_t m_FileTime; // 文件创建时间
  184. };
  185. char m_szFileName[MAX_PATH]; // 文件名 or URL
  186. } RCV_FILE_HEADEx,*PRCV_FILE_HEADEx;
  187. //综合排名
  188. typedef struct tagMULTISORT_ITEM_STRUCTEx {
  189. BYTE m_type; // stock's type
  190. char m_code[6]; // stock code
  191. long m_data1;
  192. long m_data2;
  193. } MULTISORT_ITEM_STRUCTEx;
  194. typedef struct tagRCV_MULTISORT_STRUCTEx
  195. {
  196. DWORD m_class; // 1-涨幅 2-跌幅 4-5分钟涨幅 8-5分钟跌幅 16-委比前六 32-委比后六
  197. // 64-震幅 128-量比 256-总金额
  198. WORD m_tag1; // 0xf0 00
  199. WORD m_tag2; // 0x06 00
  200. MULTISORT_ITEM_STRUCTEx m_stocks[6];
  201. }RCV_MULTISORT_STRUCTEx,*PRCV_MULTISORT_STRUCTEx;
  202. //////////////////////////////////////////////////////////////////////////////////
  203. //  数据通知消息
  204. //查询方式通知消息
  205. // wParam = MsgPara_StkData 有股票数据
  206. // wParam = MsgPara_File 有文件数据文件
  207. //直接数据引用通知消息
  208. // wParam = RCV_WPARAM;
  209. //  lParam 指向 RCV_DATA结构;
  210. // 返回 1 已经处理, 0 未处理或不能处理,目前该返回值被忽略
  211. // 注一:
  212. //   记录数表示行情数据和补充数据(包括 Header)的数据包数,对文件类型数据, = 1
  213. // 注二:
  214. //   若 m_bDISK = FALSE, m_pData 为数据缓冲区指针
  215. //  ******** 数据共享,不能修改数据 **********
  216. //  m_bDISK = TRUE,  m_pData 为该文件的存盘文件名,一般情况只有
  217. //  升级软件等大文件用存盘方式
  218. typedef struct tagRCV_DATA
  219. {
  220. int m_wDataType; // 文件类型
  221. int m_nPacketNum; // 记录数,参见注一
  222. RCV_FILE_HEADEx m_File; // 文件接口
  223. BOOL m_bDISK; // 文件是否已存盘的文件
  224. union
  225. {
  226. RCV_REPORT_STRUCTEx  * m_pReport;
  227. RCV_HISTORY_STRUCTEx * m_pDay;
  228. RCV_MINUTE_STRUCTEx  * m_pMinute;
  229. RCV_POWER_STRUCTEx  * m_pPower;
  230. RCV_MULTISORT_STRUCTEx * m_pMultisort;
  231. void  * m_pData; // 参见注二
  232. };
  233. } RCV_DATA,*PRCV_DATA;
  234. #pragma pack()
  235. /* 消息处理程序 DEMO
  236. LONG OnStkDataOK(UINT wParam,LONG lParam)
  237. {
  238. union tagSrcStock DOS_StkBuf;
  239. RCV_REPORT_STRUCTEx NEW_StkBuf;
  240. PBYTE pDataBuf;
  241. RCV_DATA Header;
  242. RCV_DATA * pHeader;
  243. DWORD dwFileLen;
  244. int ok;
  245. pHeader = (RCV_DATA *)lParam;
  246. switch( wParam )
  247. {
  248. case RCV_REPORT: // 共享数据引用方式,股票行情
  249. for(i=0; i<pHeader->m_nPacketNum; i++)
  250. {
  251. pHeader->m_pReport[i] ...
  252. // 数据处理
  253. }
  254. break;
  255. case RCV_FILEDATA: // 共享数据引用方式,文件
  256. switch(pHeader->m_wDataType)
  257. {
  258. case FILE_HISTORY_EX: // 补日线数据
  259. break;
  260. case FILE_MINUTE_EX: // 补分钟线数据
  261. break;
  262. case FILE_POWER_EX: // 补充除权数据
  263. break;
  264. case FILE_BASE_EX: // 钱龙兼容基本资料文件,m_szFileName仅包含文件名
  265. break;
  266. case FILE_NEWS_EX: // 新闻类,其类型由m_szFileName中子目录名来定
  267. break;
  268. case FILE_HTML_EX: // HTML文件,m_szFileName为URL
  269. break;
  270. case FILE_SOFTWARE_EX: // 升级软件
  271. break;
  272. }
  273. break;
  274. default:
  275. return 0; // unknown data
  276. }
  277. return 1;
  278. }
  279. */
  280. //////////////////////////////////////////////////////////////////////////////////
  281. //APIs
  282. #ifdef __cplusplus
  283. extern "C"{
  284. #endif
  285. //////////////////////////////////////////////////////////////////////////////////
  286. // 注册函数
  287. // 股票初始化
  288. // 入口参数:
  289. // hWnd 处理消息的窗口句柄
  290. // Msg 用户自定义消息
  291. // nWorkMode 接口工作方式, 应等于 RCV_WORK_SENDMSG
  292. // 返回参数:
  293. //  1 成功
  294. // -1 失败
  295. int WINAPI Stock_Init(HWND hWnd,UINT Msg,int nWorkMode);
  296. int WINAPI Stock_Init_Nodialog(HWND hWnd,UINT Msg,int nWorkMode,
  297. const char * szAddress, UINT nPort, const char * szUser, const char * szPasswd );
  298. // 退出,停止发送消息
  299. // 入口参数:
  300. // hWnd 处理消息的窗口句柄,同 Stock_Init 的调用入口参数
  301. // 返回参数:
  302. //  1 成功
  303. // -1 失败
  304. int WINAPI  Stock_Quit(HWND hWnd);
  305. //////////////////////////////////////////////////////////////////////////////////
  306. // 行情接口       
  307.       
  308. // 取已接收到的股票总数
  309. int WINAPI  GetTotalNumber();
  310. // 由序号取股票数据(扩展)
  311. // 入口参数:
  312. // nNo 序号
  313. // pBuf 存放股票数据的缓冲区
  314. // 返回参数:
  315. //     NoStockData 无股票数据
  316. // 注:
  317. // 该函数提供股票数据的主要数据;分析软件刚运行时,可以快速建立数据框架
  318. int WINAPI  GetStockByNoEx(int nNo,RCV_REPORT_STRUCTEx * pBuf);
  319. // 由股号取股票数据(扩展)
  320. // 入口参数:
  321. // pszStockCode股票代号
  322. // nMarket 证券市场
  323. // pBuf 存放股票数据的缓冲区
  324. // 返回参数:
  325. //     NoStockData 无股票数据
  326. // 注:
  327. // 该函数提供股票数据的主要数据;分析软件刚运行时,可以快速建立数据框架
  328. int WINAPI  GetStockByCodeEx(char * pszStockCode,int nMarket,RCV_REPORT_STRUCTEx * pBuf);
  329. // 激活接收程序,进行设置
  330. // 入口参数:
  331. // bShowWindow TRUE 显示窗口,进行设置
  332. // FALSE 隐含窗口
  333. // 返回参数:
  334. //  1 成功
  335. // -1 失败
  336. int WINAPI  SetupReceiver(BOOL bShowWindow);
  337. // 取得股票驱动信息
  338. // 入口参数:
  339. // nInfo 索引
  340. // pBuf 缓冲区
  341. // 出口参数:
  342. // nInfo == RI_IDSTRING, 返回特征字符串长度, pBuf 为特征字符串
  343. // 如: "TongShi_StockDrv_1.00"
  344. // nInfo == RI_IDCODE, 返回信息卡 ID 号, pBuf 为字符串形式的 ID 号
  345. // 如: 0x78001234   "78001234"
  346. // nInfo == RI_VERSION, 返回信息卡版本号, pBuf 为字符串版本
  347. // 如:  1.00   "1.00"
  348. // nInfo == RI_ERRRATE, 取信道误码,
  349. // nInfo == RI_STKNUM, 取上市股票总家数
  350. DWORD WINAPI  GetStockDrvInfo(int nInfo,void * pBuf);
  351. /////////////////////////////////////////////////////////////////////////////////////
  352. // NetTS 支持新加接口,可主动请求数据
  353. // 接收引擎是否已经启动工作
  354. // 返回参数:
  355. // 1 已启动
  356. // 0 未启动
  357. int WINAPI  IsEngineWorking( );
  358. // 设置接收引擎是否自动定期刷新RCV_REPORT信息,缺省为TRUE
  359. // 入口参数:
  360. // bAutoReport 是否自动刷新,如果不是自动刷新,用户需要主动调用
  361. // RequestStockData( RCV_REPORT, ... )
  362. // 返回参数:
  363. // 1 以前为自动刷新
  364. // 0 以前不是自动刷新
  365. int WINAPI  SetAutoReport( int bAutoReport );
  366. // 由股号请求股票数据
  367. // 入口参数:
  368. // nDataType 数据类型,
  369. // 如 FILE_HISTORY_EX, FILE_MINUTE_EX, FILE_POWER_EX,
  370. // RCV_REPORT, FILE_MULTISORT_EX, FILE_DETAIL_EX,
  371. // FILE_BASE_EX, FILE_NEWS_EX, FILE_HTML_EX
  372. // FILE_SOFTWARE_EX, FILE_SHAZQDATA_EX
  373. // pStocks     股票数据指针, 对于FILE_NEWS_EX,FILE_HTML_EX,FILE_SOFTWARE_EX,FILE_SHAZQDATA_EX,该值无效
  374. // nSize 股票数据个数,同pStocks一样,某些类型该值无效
  375. // nKType 历史数据类型,该参数仅对FILE_HISTORY_EX数据类型有效
  376. // nDataCount 需要数据个数,该参数仅对FILE_HISTORY_EX数据类型有效,表示需要获取的历史数据个数,从当前日期往前数
  377. // 返回参数:
  378. // 1 请求发送成功
  379. // -1 请求发送失败
  380. // 注:
  381. // 该函数提供股票数据的主动请求,向Internet服务器发送请求,请求发送结束
  382. // 后,立即返回. 当请求的数据从Internet服务器传回时,向窗口发送消息
  383. #define FILE_MULTISORT_EX 0x708 // 综合排名
  384. #define FILE_DETAIL_EX 0x709 // 成交明细
  385. #pragma pack(1)
  386. typedef struct tagSTOCK_STRUCTEx {
  387. BYTE m_type; // stock's type, see enum StockType
  388. char m_code[6]; // stock code
  389. } STOCK_STRUCTEx,*pSTOCK_STRUCTEx;
  390. #pragma pack()
  391. enum StockType {
  392. typeNone = 0x00,
  393. typeshIndex = 0x10, // 上海指数
  394. typeshA = 0x11, // 上海A股
  395. typeshB = 0x12, // 上海B股
  396. typeshBond = 0x13, // 上海债券
  397. typeshRight = 0x14, // 上海权证
  398. typeshBonus = 0x15, // 上海红利
  399. typeshAdmeasure = 0x16, // 上海配股
  400. typeshInfo = 0x1F, // 上海证交所信息
  401. typeszIndex = 0x20, // 深圳指数 0x20 
  402. typeszA = 0x21, // 深圳A股 0x21 
  403. typeszB = 0x22, // 深圳B股 0x22 
  404. typeszBond = 0x23, // 深圳债券 0x23 
  405. typeszRight = 0x24, // 深圳权证 0x24 
  406. typeszBonus = 0x25, // 深圳红利 0x25 
  407. typeszAdmeasure = 0x26, // 深圳配股 0x26 
  408. typeszInfo = 0x2F, // 深圳证交所信息 0x2f 
  409. typeGeneralInfo = 0x05, // 综合财经信息 0x05 
  410. };
  411. enum KTypes {
  412. ktypeNone = 0x00,
  413. ktypeMin = 0x01, // enum KTypes 的最小值
  414. ktypeMin5 = 0x01, // 五分钟线
  415. ktypeMin15 = 0x02, // 十五分钟线
  416. ktypeMin30 = 0x03, // 三十分钟线
  417. ktypeMin60 = 0x04, // 六十分钟线
  418. ktypeDay = 0x05, // 日线
  419. ktypeWeek = 0x06, // 周线
  420. ktypeMonth = 0x07, // 月线
  421. ktypeMax = 0x07, // enum KTypes 的最大值
  422. };
  423. int WINAPI RequestStockData( int nDataType, STOCK_STRUCTEx * pStocks, int nSize, int nKType, int nDataCount );
  424. #ifdef __cplusplus
  425. }
  426. #endif
  427. #endif // __STOCKDRV_H__