IByteTransform.cs 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. /*********************************************************************************************************
  6. *
  7. * 说明:
  8. *
  9. * 统一的数据转换中心,共有3种转换的机制
  10. * 1. 对等转换,字节不需要颠倒,比如三菱PLC,Hsl通信协议
  11. * 2. 颠倒转换,字节需要完全颠倒,比如西门子PLC
  12. * 3. 以2字节为单位颠倒转换,比如Modbus协议
  13. *
  14. *********************************************************************************************************/
  15. namespace MECF.Framework.Common.Net
  16. {
  17. /// <summary>
  18. /// 支持转换器的基础接口
  19. /// </summary>
  20. public interface IByteTransform
  21. {
  22. #region Get Value From Bytes
  23. /// <summary>
  24. /// 从缓存中提取出bool结果
  25. /// </summary>
  26. /// <param name="buffer">缓存数据</param>
  27. /// <param name="index">位的索引</param>
  28. /// <returns>bool对象</returns>
  29. bool TransBool( byte[] buffer, int index );
  30. /// <summary>
  31. /// 从缓存中提取出bool数组结果
  32. /// </summary>
  33. /// <param name="buffer">缓存数据</param>
  34. /// <param name="index">位的索引</param>
  35. /// <param name="length">bool长度</param>
  36. /// <returns>bool数组</returns>
  37. bool[] TransBool( byte[] buffer, int index, int length );
  38. /// <summary>
  39. /// 从缓存中提取byte结果
  40. /// </summary>
  41. /// <param name="buffer">缓存数据</param>
  42. /// <param name="index">索引位置</param>
  43. /// <returns>byte对象</returns>
  44. byte TransByte( byte[] buffer, int index );
  45. /// <summary>
  46. /// 从缓存中提取byte数组结果
  47. /// </summary>
  48. /// <param name="buffer">缓存数据</param>
  49. /// <param name="index">索引位置</param>
  50. /// <param name="length">读取的数组长度</param>
  51. /// <returns></returns>
  52. byte[] TransByte( byte[] buffer, int index, int length );
  53. /// <summary>
  54. /// 从缓存中提取short结果
  55. /// </summary>
  56. /// <param name="buffer">缓存数据</param>
  57. /// <param name="index">索引位置</param>
  58. /// <returns>short对象</returns>
  59. short TransInt16( byte[] buffer, int index );
  60. /// <summary>
  61. /// 从缓存中提取short数组结果
  62. /// </summary>
  63. /// <param name="buffer">缓存数据</param>
  64. /// <param name="index">索引位置</param>
  65. /// <param name="length">读取的数组长度</param>
  66. /// <returns>short数组对象</returns>
  67. short[] TransInt16( byte[] buffer, int index, int length );
  68. /// <summary>
  69. /// 从缓存中提取ushort结果
  70. /// </summary>
  71. /// <param name="buffer">缓存数据</param>
  72. /// <param name="index">索引位置</param>
  73. /// <returns>ushort对象</returns>
  74. ushort TransUInt16( byte[] buffer, int index );
  75. /// <summary>
  76. /// 从缓存中提取ushort数组结果
  77. /// </summary>
  78. /// <param name="buffer">缓存数据</param>
  79. /// <param name="index">索引位置</param>
  80. /// <param name="length">读取的数组长度</param>
  81. /// <returns>ushort数组对象</returns>
  82. ushort[] TransUInt16( byte[] buffer, int index, int length );
  83. /// <summary>
  84. /// 从缓存中提取int结果
  85. /// </summary>
  86. /// <param name="buffer">缓存数据</param>
  87. /// <param name="index">索引位置</param>
  88. /// <returns>int对象</returns>
  89. int TransInt32( byte[] buffer, int index );
  90. /// <summary>
  91. /// 从缓存中提取int数组结果
  92. /// </summary>
  93. /// <param name="buffer">缓存数据</param>
  94. /// <param name="index">索引位置</param>
  95. /// <param name="length">读取的数组长度</param>
  96. /// <returns>int数组对象</returns>
  97. int[] TransInt32( byte[] buffer, int index, int length );
  98. /// <summary>
  99. /// 从缓存中提取uint结果
  100. /// </summary>
  101. /// <param name="buffer">缓存数据</param>
  102. /// <param name="index">索引位置</param>
  103. /// <returns>uint对象</returns>
  104. uint TransUInt32( byte[] buffer, int index );
  105. /// <summary>
  106. /// 从缓存中提取uint数组结果
  107. /// </summary>
  108. /// <param name="buffer">缓存数据</param>
  109. /// <param name="index">索引位置</param>
  110. /// <param name="length">读取的数组长度</param>
  111. /// <returns>uint数组对象</returns>
  112. uint[] TransUInt32( byte[] buffer, int index, int length );
  113. /// <summary>
  114. /// 从缓存中提取long结果
  115. /// </summary>
  116. /// <param name="buffer">缓存数据</param>
  117. /// <param name="index">索引位置</param>
  118. /// <returns>long对象</returns>
  119. long TransInt64( byte[] buffer, int index );
  120. /// <summary>
  121. /// 从缓存中提取long数组结果
  122. /// </summary>
  123. /// <param name="buffer">缓存数据</param>
  124. /// <param name="index">索引位置</param>
  125. /// <param name="length">读取的数组长度</param>
  126. /// <returns>long数组对象</returns>
  127. long[] TransInt64( byte[] buffer, int index, int length );
  128. /// <summary>
  129. /// 从缓存中提取ulong结果
  130. /// </summary>
  131. /// <param name="buffer">缓存数据</param>
  132. /// <param name="index">索引位置</param>
  133. /// <returns>ulong对象</returns>
  134. ulong TransUInt64( byte[] buffer, int index );
  135. /// <summary>
  136. /// 从缓存中提取ulong数组结果
  137. /// </summary>
  138. /// <param name="buffer">缓存数据</param>
  139. /// <param name="index">索引位置</param>
  140. /// <param name="length">读取的数组长度</param>
  141. /// <returns>ulong数组对象</returns>
  142. ulong[] TransUInt64( byte[] buffer, int index, int length );
  143. /// <summary>
  144. /// 从缓存中提取float结果
  145. /// </summary>
  146. /// <param name="buffer">缓存对象</param>
  147. /// <param name="index">索引位置</param>
  148. /// <returns>float对象</returns>
  149. float TransSingle( byte[] buffer, int index );
  150. /// <summary>
  151. /// 从缓存中提取float数组结果
  152. /// </summary>
  153. /// <param name="buffer">缓存数据</param>
  154. /// <param name="index">索引位置</param>
  155. /// <param name="length">读取的数组长度</param>
  156. /// <returns></returns>
  157. float[] TransSingle( byte[] buffer, int index, int length );
  158. /// <summary>
  159. /// 从缓存中提取double结果
  160. /// </summary>
  161. /// <param name="buffer">缓存对象</param>
  162. /// <param name="index">索引位置</param>
  163. /// <returns>double对象</returns>
  164. double TransDouble( byte[] buffer, int index );
  165. /// <summary>
  166. /// 从缓存中提取double数组结果
  167. /// </summary>
  168. /// <param name="buffer">缓存对象</param>
  169. /// <param name="index">索引位置</param>
  170. /// <param name="length">读取的数组长度</param>
  171. /// <returns></returns>
  172. double[] TransDouble( byte[] buffer, int index, int length );
  173. /// <summary>
  174. /// 从缓存中提取string结果,使用指定的编码
  175. /// </summary>
  176. /// <param name="buffer">缓存对象</param>
  177. /// <param name="index">索引位置</param>
  178. /// <param name="length">byte数组长度</param>
  179. /// <param name="encoding">字符串的编码</param>
  180. /// <returns>string对象</returns>
  181. string TransString( byte[] buffer, int index, int length, Encoding encoding );
  182. #endregion
  183. #region Get Bytes From Value
  184. /// <summary>
  185. /// bool变量转化缓存数据
  186. /// </summary>
  187. /// <param name="value">等待转化的数据</param>
  188. /// <returns>buffer数据</returns>
  189. byte[] GetBytes( bool value );
  190. /// <summary>
  191. /// bool数组变量转化缓存数据
  192. /// </summary>
  193. /// <param name="values">等待转化的数组</param>
  194. /// <returns>buffer数据</returns>
  195. byte[] GetBytes( bool[] values );
  196. /// <summary>
  197. /// byte变量转化缓存数据
  198. /// </summary>
  199. /// <param name="value">等待转化的数据</param>
  200. /// <returns>buffer数据</returns>
  201. byte[] GetBytes( byte value );
  202. /// <summary>
  203. /// short变量转化缓存数据
  204. /// </summary>
  205. /// <param name="value">等待转化的数据</param>
  206. /// <returns>buffer数据</returns>
  207. byte[] GetBytes( short value );
  208. /// <summary>
  209. /// short数组变量转化缓存数据
  210. /// </summary>
  211. /// <param name="values">等待转化的数组</param>
  212. /// <returns>buffer数据</returns>
  213. byte[] GetBytes( short[] values );
  214. /// <summary>
  215. /// ushort变量转化缓存数据
  216. /// </summary>
  217. /// <param name="value">等待转化的数据</param>
  218. /// <returns>buffer数据</returns>
  219. byte[] GetBytes( ushort value );
  220. /// <summary>
  221. /// ushort数组变量转化缓存数据
  222. /// </summary>
  223. /// <param name="values">等待转化的数组</param>
  224. /// <returns>buffer数据</returns>
  225. byte[] GetBytes( ushort[] values );
  226. /// <summary>
  227. /// int变量转化缓存数据
  228. /// </summary>
  229. /// <param name="value">等待转化的数据</param>
  230. /// <returns>buffer数据</returns>
  231. byte[] GetBytes( int value );
  232. /// <summary>
  233. /// int数组变量转化缓存数据
  234. /// </summary>
  235. /// <param name="values">等待转化的数组</param>
  236. /// <returns>buffer数据</returns>
  237. byte[] GetBytes( int[] values );
  238. /// <summary>
  239. /// uint变量转化缓存数据
  240. /// </summary>
  241. /// <param name="value">等待转化的数据</param>
  242. /// <returns>buffer数据</returns>
  243. byte[] GetBytes( uint value );
  244. /// <summary>
  245. /// uint数组变量转化缓存数据
  246. /// </summary>
  247. /// <param name="values">等待转化的数组</param>
  248. /// <returns>buffer数据</returns>
  249. byte[] GetBytes( uint[] values );
  250. /// <summary>
  251. /// long变量转化缓存数据
  252. /// </summary>
  253. /// <param name="value">等待转化的数据</param>
  254. /// <returns>buffer数据</returns>
  255. byte[] GetBytes( long value );
  256. /// <summary>
  257. /// long数组变量转化缓存数据
  258. /// </summary>
  259. /// <param name="values">等待转化的数组</param>
  260. /// <returns>buffer数据</returns>
  261. byte[] GetBytes( long[] values );
  262. /// <summary>
  263. /// ulong变量转化缓存数据
  264. /// </summary>
  265. /// <param name="value">等待转化的数据</param>
  266. /// <returns>buffer数据</returns>
  267. byte[] GetBytes( ulong value );
  268. /// <summary>
  269. /// ulong数组变量转化缓存数据
  270. /// </summary>
  271. /// <param name="values">等待转化的数组</param>
  272. /// <returns>buffer数据</returns>
  273. byte[] GetBytes( ulong[] values );
  274. /// <summary>
  275. /// float变量转化缓存数据
  276. /// </summary>
  277. /// <param name="value">等待转化的数据</param>
  278. /// <returns>buffer数据</returns>
  279. byte[] GetBytes( float value );
  280. /// <summary>
  281. /// float数组变量转化缓存数据
  282. /// </summary>
  283. /// <param name="values">等待转化的数组</param>
  284. /// <returns>buffer数据</returns>
  285. byte[] GetBytes( float[] values );
  286. /// <summary>
  287. /// double变量转化缓存数据
  288. /// </summary>
  289. /// <param name="value">等待转化的数据</param>
  290. /// <returns>buffer数据</returns>
  291. byte[] GetBytes( double value );
  292. /// <summary>
  293. /// double数组变量转化缓存数据
  294. /// </summary>
  295. /// <param name="values">等待转化的数组</param>
  296. /// <returns>buffer数据</returns>
  297. byte[] GetBytes( double[] values );
  298. /// <summary>
  299. /// 使用指定的编码字符串转化缓存数据
  300. /// </summary>
  301. /// <param name="value">等待转化的数据</param>
  302. /// <param name="encoding">字符串的编码方式</param>
  303. /// <returns>buffer数据</returns>
  304. byte[] GetBytes( string value, Encoding encoding );
  305. #endregion
  306. #region Public Properties
  307. /// <summary>
  308. /// 获取或设置数据解析的格式,默认ABCD,可选BADC,CDAB,DCBA格式
  309. /// </summary>
  310. DataFormat DataFormat { get; set; }
  311. #endregion
  312. }
  313. }