index.html 47 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162
  1. <!DOCTYPE html>
  2. <html>
  3. <head lang="en">
  4. <meta charset="UTF-8">
  5. <title></title>
  6. <link href="css/index.css" rel="stylesheet" />
  7. </head>
  8. <body>
  9. <div class="content">
  10. <div class="left">
  11. <!--气压-->
  12. <div class="air">
  13. <div class="air-title title numfont">AIR PRESSURE</div>
  14. <div class="air-relative">
  15. <div class="air-val">
  16. <span class="air-icon"></span>
  17. <div class="numfont">
  18. <p class="hpa-rel"></p>
  19. <p class="hpa-nam">Relative pressure</p>
  20. </div>
  21. </div>
  22. <div class="gray">
  23. </div>
  24. <div class="light">
  25. </div>
  26. <div class="unit">HPA</div>
  27. </div>
  28. <div class="air-absolutely">
  29. <div class="air-val">
  30. <span class="air-icon"></span>
  31. <div class="numfont">
  32. <p class="hpa-abs"></p>
  33. <p class="hpa-nam">Absolute pressure</p>
  34. </div>
  35. </div>
  36. <div class="gray">
  37. </div>
  38. <div class="light">
  39. </div>
  40. <div class="unit">HPA</div>
  41. </div>
  42. </div>
  43. <!--气压 end-->
  44. <!--温度和湿度-->
  45. <div class="tem-hum">
  46. <div class="temperature">
  47. <div class="tem-hum-title numfont">THE TEMPERATURE</div>
  48. <div class="tem-hum-chart" id="temChart">
  49. </div>
  50. <div class="tem-val">
  51. <span class="indoor">22℃</span>
  52. <span class="outdoor">33℃</span>
  53. </div>
  54. </div>
  55. <div class="humidity">
  56. <div class="tem-hum-title numfont">HUMIDITY</div>
  57. <div class="tem-hum-chart" id="humChart">
  58. </div>
  59. <div class="hum-val">
  60. <span class="indoor">22%</span>
  61. <span class="outdoor">33%</span>
  62. </div>
  63. </div>
  64. </div>
  65. <!--温度和湿度 end-->
  66. <!--温度一周k线图-->
  67. <div class="temp-k">
  68. <div class="title numfont">TEMPERATURE CHART</div>
  69. <div id="tempKChart">
  70. </div>
  71. </div>
  72. <!--温度一周k线图 end-->
  73. <!--湿度一走k线图-->
  74. <div class="dity-k">
  75. <div class="title numfont">HUMIDITY CHART</div>
  76. <div id="dityKChart">
  77. </div>
  78. </div>
  79. <!--湿度一走k线图 end-->
  80. </div>
  81. <div class="middle">
  82. <div class="headTitle">WEATHER STATION</div>
  83. <!--地图-->
  84. <div class="chinaMap" style="color: white;">
  85. <div class="circle0"></div>
  86. <div id="btn" style="display: none;">
  87. <div style="position: relative;">
  88. <div class="btn0"></div>
  89. <div class="btn1"></div>
  90. <div class="btn2"></div>
  91. </div>
  92. </div>
  93. <div class="mapBox">
  94. <div id="map">
  95. </div>
  96. </div>
  97. <div class="circle1"></div>
  98. </div>
  99. <!--地图 end-->
  100. <!--动画-->
  101. <div class="lineRun">
  102. </div>
  103. <!--动画 end-->
  104. </div>
  105. <div class="right">
  106. <div class="information">
  107. <!--基本信息-->
  108. <div class="baseInfo">
  109. <p class="infoTitle">TEST SITE</p>
  110. <p class="area">LP-COUNTY</p>
  111. <p class="infoTitle">
  112. TEST DATE
  113. <span class="date">2017-08-06</span>
  114. </p>
  115. <p class="infoTitle">
  116. SITE ID
  117. <span class="idNum">1921210001</span>
  118. </p>
  119. <p class="infoTitle">
  120. <span class="infoTitle" style="display: inline-block;margin-right: 40px;">TESTING<br>TIME</span>
  121. <span class="days">70</span>
  122. <span class="infoTitle">DAY</span>
  123. </p>
  124. </div>
  125. <!--基本信息 end-->
  126. <!--温度/露点/风寒/热指数-->
  127. <div class="temData">
  128. <p class="infoTitle" style="margin-bottom: 0;font-size: 12px;">INDOOR MAXIMUM</p>
  129. <p class="temTitle">TEMPERATURE</p>
  130. <p class="indoorTem"><span class="temperatureN">70</span>℃</p>
  131. <p class="infoTitle point">
  132. DEW POINT
  133. <span class="dewpoint">21℃</span>
  134. </p>
  135. <p class="infoTitle point">
  136. WIND CHILL
  137. <span class="windchill">21℃</span>
  138. </p>
  139. <p class="infoTitle point">
  140. HEAT NUMBER
  141. <span class="heatnumber">21℃</span>
  142. </p>
  143. </div>
  144. <!--温度/露点/风寒/热指数 end-->
  145. </div>
  146. <!--风-->
  147. <div class="wind">
  148. <div class="air-title title numfont">THE WIND INDEX</div>
  149. <div id="windChart">
  150. </div>
  151. <div class="windData">
  152. <div class="windSpeed">
  153. <div class="windTitle numfont">THE WIND SPEED</div>
  154. <div class="windBox">
  155. <div style="width: 33%;margin-left: 4%;">
  156. <p>CURRENT WIND SPEED</p>
  157. <p><span class="currentSpeed" id="nowWind">23</span>M/S</p>
  158. </div>
  159. <div style="width: 33%;">
  160. <p>CURRENT WIND SPEED</p>
  161. <p><span class="highestSpeed" id="highWind">46</span>M/S</p>
  162. </div>
  163. <div style="width: 30%">
  164. <div class="windWrap">
  165. <img src="img/wind1.png" class="windFan">
  166. </div>
  167. </div>
  168. </div>
  169. </div>
  170. <div class="gust">
  171. <div class="windTitle numfont">GUST</div>
  172. <div class="windBox">
  173. <div style="width: 33%;margin-left: 4%;">
  174. <p>CURRENT WIND SPEED</p>
  175. <p><span class="currentSpeed" id="nowGust">28</span>M/S</p>
  176. </div>
  177. <div style="width: 33%;">
  178. <p>CURRENT WIND SPEED</p>
  179. <p><span class="highestSpeed" id="highGust">43</span>M/S</p>
  180. </div>
  181. <div style="width: 30%">
  182. <div class="windWrap">
  183. <img src="img/wind1.png" class="windFan">
  184. </div>
  185. </div>
  186. </div>
  187. </div>
  188. </div>
  189. </div>
  190. <!--风 end-->
  191. <!--降雨量-->
  192. <div class="rainfall">
  193. <div class="air-title title numfont">RAINFALL</div>
  194. <div class="windData">
  195. <div class="windSpeed">
  196. <div class="windTitle numfont">ONE DAY OF DATA</div>
  197. <div class="windBox">
  198. <div style="width: 33%;margin-left: 4%;">
  199. <p>THE CURRENT PARAMETER</p>
  200. <p><span class="currentSpeed" id="nowDay">23</span>MM</p>
  201. </div>
  202. <div style="width: 31%;margin-left: 2%">
  203. <p>THE HIGHEST PARAMETERS</p>
  204. <p><span class="highestSpeed" id="highDay">46</span>MM</p>
  205. </div>
  206. <div style="width: 30%">
  207. <div class="rainWrap" style="margin: 10px auto;text-align: center;">
  208. <canvas id="rainfallOne" ></canvas>
  209. </div>
  210. </div>
  211. </div>
  212. </div>
  213. <div class="gust">
  214. <div class="windTitle numfont">WEEKLY DATA</div>
  215. <div class="windBox">
  216. <div style="width: 33%;margin-left: 4%;">
  217. <p>THE CURRENT PARAMETER</p>
  218. <p><span class="currentSpeed" id="nowWeek">28</span>MM</p>
  219. </div>
  220. <div style="width: 31%;margin-left: 2%">
  221. <p>THE HIGHEST PARAMETERS</p>
  222. <p><span class="highestSpeed" id="highWeek">43</span>MM</p>
  223. </div>
  224. <div style="width: 30%">
  225. <div class="rainWrap" style="margin: 10px auto;text-align: center;">
  226. <canvas id="rainfallTwo"></canvas>
  227. </div>
  228. </div>
  229. </div>
  230. </div>
  231. </div>
  232. <div class="windData">
  233. <div class="windSpeed">
  234. <div class="windTitle numfont">ONE MONTH OF DATA</div>
  235. <div class="windBox">
  236. <div style="width: 33%;margin-left: 4%;">
  237. <p>THE CURRENT PARAMETER</p>
  238. <p><span class="currentSpeed" id="nowMonth">23</span>MM</p>
  239. </div>
  240. <div style="width: 31%;margin-left: 2%">
  241. <p>THE HIGHEST PARAMETERS</p>
  242. <p><span class="highestSpeed" id="highMonth">46</span>MM</p>
  243. </div>
  244. <div style="width: 30%">
  245. <div class="rainWrap" style="margin: 10px auto;text-align: center;">
  246. <canvas id="rainfallThree"></canvas>
  247. </div>
  248. </div>
  249. </div>
  250. </div>
  251. <div class="gust">
  252. <div class="windTitle numfont">ANNUAL DATA</div>
  253. <div class="windBox">
  254. <div style="width: 33%;margin-left: 4%;">
  255. <p>THE CURRENT PARAMETER</p>
  256. <p><span class="currentSpeed" id="nowYear">28</span>MM</p>
  257. </div>
  258. <div style="width: 31%;margin-left: 2%">
  259. <p>THE HIGHEST PARAMETERS</p>
  260. <p><span class="highestSpeed" id="highYear">43</span>MM</p>
  261. </div>
  262. <div style="width: 30%">
  263. <div class="rainWrap" style="margin: 10px auto;text-align: center;">
  264. <canvas id="rainfallFour"></canvas>
  265. </div>
  266. </div>
  267. </div>
  268. </div>
  269. </div>
  270. </div>
  271. <!--降雨量 end-->
  272. </div>
  273. </div>
  274. <script src="js/jquery-3.2.1.min.js"></script>
  275. <script src="js/echarts.js"></script>
  276. <script src="js/china.js"></script>
  277. <script src="js/render.js"></script>
  278. <script>
  279. $(function(){
  280. for(var i=0;i<50;i++){
  281. $('.air-relative').find('.gray').append('<span></span>');
  282. $('.air-absolutely').find('.gray').append('<span></span>')
  283. }
  284. var pressureValRel=0;//初始气压(相对)
  285. var pressureValNowRel=32;//当前气压(相对)
  286. function airPreRel(now,old,par){
  287. if(now>old){
  288. par.find('.light').append('<span></span>');
  289. pressureValRel++;
  290. }else if(now<old){
  291. par.find('.light').children('span:last-child').remove();
  292. pressureValRel--;
  293. }else{
  294. clearInterval(pressureRunRel);
  295. return
  296. }
  297. $('.hpa-rel').text(pressureValRel*2);
  298. }
  299. var pressureRunRel=setInterval(function(){
  300. airPreRel(pressureValNowRel,pressureValRel,$('.air-relative'));
  301. },50);
  302. var pressureValAbs=0;//初始气压(绝对)
  303. var pressureValNowAbs=21;//当前气压(绝对)
  304. function airPreAbs(now,old,par){
  305. if(now>old){
  306. par.find('.light').append('<span></span>');
  307. pressureValAbs++;
  308. }else if(now<old){
  309. par.find('.light').children('span:last-child').remove();
  310. pressureValAbs--;
  311. }else{
  312. clearInterval(pressureRunAbs);
  313. return
  314. }
  315. $('.hpa-abs').text(pressureValAbs*2);
  316. }
  317. var pressureRunAbs=setInterval(function(){
  318. airPreAbs(pressureValNowAbs,pressureValAbs,$('.air-absolutely'));
  319. },50);
  320. //温度和湿度
  321. var temChart=echarts.init(document.getElementById('temChart'));
  322. var humChart=echarts.init(document.getElementById('humChart'));
  323. var temOption={
  324. tooltip:{
  325. formatter:'{a}<br/>当前:{c}℃'
  326. },
  327. series:[
  328. //内圈
  329. {
  330. type:'gauge',
  331. center : ['50%', '60%'], // 默认全局居中
  332. radius : '30%',
  333. min:0,
  334. max:10,
  335. startAngle: 270,
  336. endAngle: -89.99999,
  337. splitNumber:10,
  338. axisLine: { // 仪表盘轴线
  339. lineStyle: { // 属性lineStyle控制线条样式
  340. color: [[1, '#ff4500']],
  341. width: 0,
  342. shadowColor : '#fff', //默认透明
  343. shadowBlur: 10
  344. }
  345. },
  346. axisLabel: { // 刻度标签
  347. show:false
  348. },
  349. axisTick: { // 刻度
  350. length :4, // 属性length控制线长
  351. lineStyle: { // 属性lineStyle控制线条样式
  352. color: 'rgba(176,204,53,.5)'
  353. }
  354. },
  355. splitLine: { // 分隔线
  356. show:false
  357. },
  358. pointer: {
  359. width:0,
  360. shadowColor : '#fff', //默认透明
  361. shadowBlur: 5
  362. },
  363. detail : {
  364. show : false
  365. }
  366. },
  367. //中圈
  368. {
  369. name:'转速',
  370. type:'gauge',
  371. center : ['50%', '60%'], // 默认全局居中
  372. radius : '60%',
  373. min:0,
  374. max:10,
  375. splitNumber:10,
  376. axisLine: { // 坐标轴线
  377. lineStyle: { // 属性lineStyle控制线条样式
  378. color: [[1,'#6E6560' ]],
  379. width: 8,
  380. shadowBlur: 10
  381. }
  382. },
  383. axisLabel: { // 刻度
  384. textStyle: { // 属性lineStyle控制线条样式
  385. fontWeight:'' ,
  386. color: 'rgba(30,144,255,0)',
  387. shadowColor : '#fff', //默认透明
  388. shadowBlur: 10
  389. }
  390. },
  391. axisTick: { // 坐标轴小标记
  392. length :2, // 属性length控制线长
  393. lineStyle: { // 属性lineStyle控制线条样式
  394. color: 'auto'
  395. /*shadowColor : '#fff', //默认透明
  396. shadowBlur: 10*/
  397. }
  398. },
  399. splitLine: { // 分隔线
  400. length :0, // 属性length控制线长
  401. lineStyle: { // 属性lineStyle(详见lineStyle)控制线条样式
  402. width:0,
  403. color: '#fff',
  404. shadowColor : '#fff', //默认透明
  405. shadowBlur: 10
  406. }
  407. },
  408. pointer: {
  409. width:0,
  410. shadowColor : '#fff', //默认透明
  411. shadowBlur: 5
  412. },
  413. detail : {
  414. show : false
  415. }
  416. },
  417. //外圈室内
  418. {
  419. type:'gauge',
  420. center : ['50%', '60%'], // 默认全局居中
  421. radius:'100%',
  422. min:0,
  423. max:100,
  424. name:'室内',
  425. axisLine: { // 坐标轴线
  426. lineStyle: {
  427. color: [[1, '#C7C5C3']],// 属性lineStyle控制线条样式
  428. width: 1
  429. }
  430. },
  431. itemStyle:{
  432. normal:{
  433. color:'#FF0000'
  434. }
  435. },
  436. axisTick:{
  437. length:3
  438. },
  439. axisLabel: { // 坐标轴小标记
  440. textStyle: { // 属性lineStyle控制线条样式
  441. fontWeight: 'bolder',
  442. fontSize : 10,
  443. fontFamily:'numfont'
  444. }
  445. },
  446. splitLine: { // 分隔线
  447. length : 5, // 属性length控制线长
  448. lineStyle: { // 属性lineStyle(详见lineStyle)控制线条样式
  449. width:1
  450. }
  451. },
  452. pointer:{
  453. width:3,
  454. length:'90%'
  455. },
  456. detail : {
  457. show : false
  458. },
  459. data:[{value: 40}]
  460. },
  461. //外圈室外
  462. {
  463. type:'gauge',
  464. center : ['50%', '60%'], // 默认全局居中
  465. radius : '100%',
  466. min:0,
  467. max:100,
  468. name:'室外',
  469. axisTick:{
  470. length:3
  471. },
  472. axisLine: { // 坐标轴线
  473. lineStyle: {
  474. color: [[1, '#C7C5C3']],// 属性lineStyle控制线条样式
  475. width: 1
  476. }
  477. },
  478. pointer:{
  479. width:3,
  480. length:'90%'
  481. },
  482. itemStyle:{
  483. normal:{
  484. color:'#B0CC35'
  485. }
  486. },
  487. axisLabel: {
  488. textStyle: {
  489. fontWeight: 'bolder',
  490. fontSize : 16,
  491. color: 'rgba(30,144,255,0)'
  492. }
  493. },
  494. splitLine: { // 分隔线
  495. length : 5, // 属性length控制线长
  496. lineStyle: { // 属性lineStyle(详见lineStyle)控制线条样式
  497. width:1
  498. }
  499. },
  500. detail : {
  501. show : false
  502. },
  503. data:[{value: 58}],
  504. title:{
  505. show:false
  506. }
  507. }
  508. ]
  509. };
  510. var humOption={
  511. tooltip:{
  512. formatter:'{a}<br/>当前:{c}%'
  513. },
  514. series : [
  515. //内圈
  516. {
  517. type:'gauge',
  518. center : ['50%', '60%'], // 默认全局居中
  519. radius : '30%',
  520. min:0,
  521. max:10,
  522. startAngle: 270,
  523. endAngle: -89.99999,
  524. splitNumber:10,
  525. axisLine: { // 仪表盘轴线
  526. lineStyle: { // 属性lineStyle控制线条样式
  527. color: [[1, '#ff4500']],
  528. width: 0,
  529. shadowColor : '#fff', //默认透明
  530. shadowBlur: 10
  531. }
  532. },
  533. axisLabel: { // 刻度标签
  534. show:false
  535. },
  536. axisTick: { // 刻度
  537. length :4, // 属性length控制线长
  538. lineStyle: { // 属性lineStyle控制线条样式
  539. color: 'rgba(176,204,53,.5)'
  540. }
  541. },
  542. splitLine: { // 分隔线
  543. show:false
  544. },
  545. pointer: {
  546. width:0,
  547. shadowColor : '#fff', //默认透明
  548. shadowBlur: 5
  549. },
  550. detail : {
  551. show : false
  552. }
  553. },
  554. //中圈
  555. {
  556. name:'转速',
  557. type:'gauge',
  558. center : ['50%', '60%'], // 默认全局居中
  559. radius : '60%',
  560. min:0,
  561. max:10,
  562. splitNumber:10,
  563. axisLine: { // 坐标轴线
  564. lineStyle: { // 属性lineStyle控制线条样式
  565. color: [[1,'#6E6560' ]],
  566. width: 8,
  567. shadowBlur: 10
  568. }
  569. },
  570. axisLabel: { // 刻度
  571. textStyle: { // 属性lineStyle控制线条样式
  572. fontWeight:'' ,
  573. color: 'rgba(30,144,255,0)',
  574. shadowColor : '#fff', //默认透明
  575. shadowBlur: 10
  576. }
  577. },
  578. axisTick: { // 坐标轴小标记
  579. length :2, // 属性length控制线长
  580. lineStyle: { // 属性lineStyle控制线条样式
  581. color: 'auto'
  582. /*shadowColor : '#fff', //默认透明
  583. shadowBlur: 10*/
  584. }
  585. },
  586. splitLine: { // 分隔线
  587. length :0, // 属性length控制线长
  588. lineStyle: { // 属性lineStyle(详见lineStyle)控制线条样式
  589. width:0,
  590. color: '#fff',
  591. shadowColor : '#fff', //默认透明
  592. shadowBlur: 10
  593. }
  594. },
  595. pointer: {
  596. width:0,
  597. shadowColor : '#fff', //默认透明
  598. shadowBlur: 5
  599. },
  600. detail : {
  601. show : false
  602. }
  603. },
  604. //外圈室内
  605. {
  606. type:'gauge',
  607. center : ['50%', '60%'], // 默认全局居中
  608. radius:'100%',
  609. min:0,
  610. max:100,
  611. name:'室内',
  612. axisLine: { // 坐标轴线
  613. lineStyle: {
  614. color: [[1, '#C7C5C3']],// 属性lineStyle控制线条样式
  615. width: 1
  616. }
  617. },
  618. itemStyle:{
  619. normal:{
  620. color:'#FF0000'
  621. }
  622. },
  623. axisTick:{
  624. length:3
  625. },
  626. axisLabel: { // 坐标轴小标记
  627. textStyle: { // 属性lineStyle控制线条样式
  628. fontWeight: 'bolder',
  629. fontSize : 10,
  630. fontFamily:'numfont'
  631. }
  632. },
  633. splitLine: { // 分隔线
  634. length : 5, // 属性length控制线长
  635. lineStyle: { // 属性lineStyle(详见lineStyle)控制线条样式
  636. width:1
  637. }
  638. },
  639. pointer:{
  640. width:3,
  641. length:'90%'
  642. },
  643. detail : {
  644. show : false
  645. },
  646. data:[{value: 40}]
  647. },
  648. //外圈室外
  649. {
  650. type:'gauge',
  651. center : ['50%', '60%'], // 默认全局居中
  652. radius : '100%',
  653. min:0,
  654. max:100,
  655. name:'室外',
  656. axisTick:{
  657. length:3
  658. },
  659. axisLine: { // 坐标轴线
  660. lineStyle: {
  661. color: [[1, '#C7C5C3']],// 属性lineStyle控制线条样式
  662. width: 1
  663. }
  664. },
  665. pointer:{
  666. width:3,
  667. length:'90%'
  668. },
  669. itemStyle:{
  670. normal:{
  671. color:'#B0CC35'
  672. }
  673. },
  674. axisLabel: {
  675. textStyle: {
  676. fontWeight: 'bolder',
  677. fontSize : 16,
  678. color: 'rgba(30,144,255,0)'
  679. }
  680. },
  681. splitLine: { // 分隔线
  682. length : 5, // 属性length控制线长
  683. lineStyle: { // 属性lineStyle(详见lineStyle)控制线条样式
  684. width:1
  685. }
  686. },
  687. detail : {
  688. show : false
  689. },
  690. data:[{value: 58}],
  691. title:{
  692. show:false
  693. }
  694. }
  695. ]
  696. };
  697. temChart.setOption(temOption);
  698. humChart.setOption(humOption);
  699. var temVal=[25,36];
  700. var humVal=[21,30];
  701. function temHum(tem,hum){
  702. temOption.series[2].data[0].value=tem[0];
  703. temOption.series[3].data[0].value=tem[1];
  704. temChart.setOption(temOption);
  705. $('.tem-val').find('.indoor').text(tem[0]+'℃');
  706. $('.tem-val').find('.outdoor').text(tem[1]+'℃');
  707. humOption.series[2].data[0].value=hum[0];
  708. humOption.series[3].data[0].value=hum[1];
  709. humChart.setOption(humOption);
  710. $('.hum-val').find('.indoor').text(hum[0]+"%");
  711. $('.hum-val').find('.outdoor').text(hum[1]+"%");
  712. }
  713. setInterval(function(){
  714. temVal[0]=Math.round(Math.random()*100);
  715. temVal[1]=Math.round(Math.random()*100);
  716. humVal[0]=Math.round(Math.random()*100);
  717. humVal[1]=Math.round(Math.random()*100);
  718. temHum(temVal,humVal);
  719. },1000);
  720. //温度k线值
  721. //温度数据:最低温度,最高温度
  722. var data = [
  723. ['2013/1/24', 23,28,23,28],
  724. ['2013/1/25', 21,24,21,24],
  725. ['2013/1/26', 28,24,28,24],
  726. ['2013/1/27', 21,24,21,24],
  727. ['2013/1/28', 27,21,27,21],
  728. ['2013/1/29', 20,23,20,23],
  729. ['2013/1/30', 22,27,22,27],
  730. ['2013/1/31', 23,28,23,28],
  731. ['2013/2/1', 22,24,22,24],
  732. ['2013/2/2', 26,24,26,24],
  733. ['2013/2/3', 21,24,21,24],
  734. ['2013/2/4', 29,22,29,22],
  735. ['2013/2/5', 24,33,24,33],
  736. ['2013/2/6', 23,29,27,29],
  737. ['2013/2/7', 30,27,30,27],
  738. ['2013/2/8', 21,32,21,32],
  739. ['2013/2/9', 31,24,31,24],
  740. ['2013/2/10', 27,24,27,24],
  741. ['2013/2/11', 22,34,22,34],
  742. ['2013/2/12', 20,22,20,22],
  743. ['2013/2/13', 21,24,21,24],
  744. ['2013/2/14', 25,33,25,33]
  745. ];
  746. //数据序列化
  747. function splitData(rawData) {
  748. var categoryData = [];
  749. var values = [];
  750. for (var i = 0; i < rawData.length; i++) {
  751. categoryData.push(rawData[i].splice(0, 1)[0]);
  752. values.push(rawData[i])
  753. }
  754. return {
  755. categoryData: categoryData,
  756. values: values
  757. };
  758. }
  759. var data0=splitData(data);
  760. function calculateMA(dayCount, data) {
  761. var result = [];
  762. for (var i = 0, len = data.length; i < len; i++) {
  763. if (i < dayCount) {
  764. result.push('-');
  765. continue;
  766. }
  767. var sum = 0;
  768. for (var j = 0; j < dayCount; j++) {
  769. sum += data[i - j][1];
  770. }
  771. result.push((sum / dayCount).toFixed(2));
  772. }
  773. return result;
  774. }
  775. var dataMA5 = calculateMA(5, data0.values);
  776. var dataMA10 = calculateMA(10, data0.values);
  777. var dataMA20 = calculateMA(20, data0.values);
  778. var temKOption={
  779. tooltip:{//提示框组件
  780. trigger: 'axis',//坐标轴触发
  781. axisPointer: {
  782. type: 'cross'
  783. },
  784. width:2
  785. },
  786. legend:{
  787. data:['日K','MA5','MA10'],
  788. top:0,
  789. textStyle:{
  790. color:'#fff'
  791. }
  792. },
  793. xAxis: {
  794. type: 'category',
  795. data: data0.categoryData,
  796. boundaryGap : false,
  797. axisLine: { lineStyle: { color: '#777' } }
  798. },
  799. yAxis: {
  800. scale: true,
  801. splitNumber: 4,//坐标轴的分割段数
  802. axisLine: { lineStyle: { color: '#777' } },
  803. splitLine: {
  804. show: true,
  805. lineStyle:{
  806. color:'#777'
  807. }
  808. },//坐标轴在 ((grid)) 区域中的分隔线。
  809. axisTick: {
  810. show: false
  811. },//刻度
  812. axisLabel: {//标签
  813. formatter: '{value}℃'
  814. }
  815. },
  816. dataZoom: [
  817. {
  818. type: 'inside',
  819. start: 50,
  820. end: 100
  821. }
  822. ],
  823. grid: [{//直角坐标系内绘图网格
  824. height:'60%',
  825. top: 25
  826. }],
  827. series:[
  828. {
  829. type: 'candlestick',
  830. name: '日K',
  831. data: data0.values,
  832. barWidth:'15%',
  833. //barMinWidth:'10%',
  834. itemStyle: {
  835. normal: {
  836. color: 'red',
  837. color0: '#B0CC35',
  838. borderColor: 'red',
  839. borderColor0: '#B0CC35'
  840. }
  841. }
  842. },
  843. {
  844. name: 'MA5',
  845. type: 'line',
  846. data: calculateMA(5,data0.values),
  847. smooth: true
  848. },
  849. {
  850. name: 'MA10',
  851. type: 'line',
  852. data: calculateMA(10,data0.values),
  853. smooth: true,
  854. itemStyle:{
  855. normal:{
  856. color:'#B0CC35'
  857. }
  858. }
  859. }
  860. ]
  861. };
  862. //温度k线图
  863. var tempKChart=echarts.init(document.getElementById('tempKChart'));
  864. tempKChart.setOption(temKOption);
  865. //湿度K线图
  866. var dityKChart=echarts.init(document.getElementById('dityKChart'));
  867. var humKOption=temKOption;
  868. humKOption.yAxis.axisLabel.formatter='{value}%';
  869. dityKChart.setOption(humKOption);
  870. //地图
  871. var mapChart=echarts.init(document.getElementById('map'));
  872. var series=[];
  873. //获取数据
  874. var geoData=[
  875. {name:'成都',value:[103.9526,30.7617]},
  876. {name:'金华',value:[120.0037,29.1028]},
  877. {name:'上海',value:[121.4648,31.2891]},
  878. {name:'梁平',value:[107.8109,30.6810]},
  879. {name:'简阳',value:[104.5525,30.4179]}
  880. ];
  881. //配置气泡点
  882. geoData.forEach(function (item, i) {
  883. series.push(
  884. {
  885. //name: ' Top10',
  886. type: 'effectScatter',//带有涟漪特效动画的散点(气泡)图
  887. coordinateSystem: 'geo',//系列使用的坐标系,geo为地理坐标系
  888. zlevel: 2,
  889. rippleEffect: {//涟漪特效相关配置
  890. brushType: 'stroke'//波纹的绘制方式,可选 'stroke' 和 'fill'。
  891. },
  892. /* label: {//标签相关配置
  893. normal: {
  894. show: true,
  895. position: 'right',
  896. formatter: '{b}'//{a}、{b}、{c},分别表示系列名,数据名,数据值
  897. }
  898. },*/
  899. symbolSize: 10,
  900. itemStyle: {
  901. normal: {
  902. color: '#B0CC35'
  903. }
  904. },
  905. data: [item],
  906. tooltip:{
  907. formatter:'{b}观测点'
  908. }
  909. }
  910. );
  911. });
  912. var option={
  913. tooltip:{
  914. trigger:'item',
  915. formatter: '{b}'
  916. },
  917. geo: {
  918. map: 'china',
  919. itemStyle:{
  920. normal:{
  921. areaColor:'rgba(0,0,0,1)',
  922. borderColor:'rgb(176,203,37)'
  923. },
  924. emphasis:{
  925. areaColor:'rgba(176,203,37,.8)'
  926. }
  927. },
  928. selectedMode:'single',
  929. roam: true,
  930. silent: false,
  931. label: {
  932. emphasis: {
  933. show: true,
  934. textStyle:{
  935. color:'#B0CC35'
  936. }
  937. }
  938. }
  939. },
  940. series:series
  941. };
  942. mapChart.setOption(option);
  943. //var mychartdata= echarts.getMap();
  944. var btn=$('#btn');
  945. var areaData=[
  946. {name: '北京', selected:false,jsonname:'beijing'},
  947. {name: '天津', selected:false,jsonname:'tianjin'},
  948. {name: '上海', selected:false,jsonname:'shanghai'},
  949. {name: '重庆', selected:false,jsonname:'chongqing'},
  950. {name: '河北', selected:false,jsonname:'hebei'},
  951. {name: '河南', selected:false,jsonname:'henan'},
  952. {name: '云南', selected:false,jsonname:'yunnan'},
  953. {name: '辽宁', selected:false,jsonname:'liaoning'},
  954. {name: '黑龙江', selected:false,jsonname:'heilongjiang'},
  955. {name: '湖南', selected:false,jsonname:'hunan'},
  956. {name: '安徽', selected:false,jsonname:'anhui'},
  957. {name: '山东', selected:false,jsonname:'shandong'},
  958. {name: '新疆', selected:false,jsonname:'xinjiang'},
  959. {name: '江苏', selected:false,jsonname:'jiangsu'},
  960. {name: '浙江', selected:false,jsonname:'zhejiang'},
  961. {name: '江西', selected:false,jsonname:'jiangxi'},
  962. {name: '湖北', selected:false,jsonname:'hubei'},
  963. {name: '广西', selected:false,jsonname:'guangxi'},
  964. {name: '甘肃', selected:false,jsonname:'gansu'},
  965. {name: '山西', selected:false,jsonname:'shanxi'},
  966. {name: '内蒙古', selected:false,jsonname:'neimenggu'},
  967. {name: '陕西', selected:false,jsonname:'shanxi'},
  968. {name: '吉林', selected:false,jsonname:'jilin'},
  969. {name: '福建', selected:false,jsonname:'fujian'},
  970. {name: '贵州', selected:false,jsonname:'guizhou'},
  971. {name: '广东', selected:false,jsonname:'guangdong'},
  972. {name: '青海', selected:false,jsonname:'qinghai'},
  973. {name: '西藏', selected:false,jsonname:'xizang'},
  974. {name: '四川', selected:false,jsonname:'sichuan'},
  975. {name: '宁夏', selected:false,jsonname:'ningxia'},
  976. {name: '海南', selected:false,jsonname:'hainan'},
  977. {name: '台湾', selected:false,jsonname:'taiwan'},
  978. {name: '香港', selected:false,jsonname:'xianggang'},
  979. {name: '澳门', selected:false,jsonname:'aomen'},
  980. {name: '成都市', selected:false,jsonname:'chengdu'}
  981. ];
  982. mapChart.on('geoselectchanged',function(param){
  983. var areaName=param.batch[0].name;
  984. for(var i=0;i<areaData.length;i++){
  985. if(areaName == areaData[i].name){
  986. btn.show();
  987. var jsonName=areaData[i].jsonname;
  988. $.getJSON('geojson/'+jsonName+'.json', function (data) {
  989. mapChart.clear();
  990. mapChart.setOption(option);
  991. echarts.registerMap(jsonName, data);
  992. option.geo.map=jsonName;
  993. mapChart.setOption(option);
  994. });
  995. }
  996. }
  997. });
  998. document.getElementById('btn').onclick=function(){
  999. btn.hide();
  1000. mapChart.clear();
  1001. mapChart.setOption(option);
  1002. option.geo.map='china';
  1003. mapChart.setOption(option);
  1004. };
  1005. //风向图
  1006. var windOption={
  1007. tooltip:{},
  1008. radar:{
  1009. indicator:[
  1010. {name:'N',max:12},
  1011. {name:'NNW',max:12},
  1012. {name:'NW',max:12},
  1013. {name:'WNW',max:12},
  1014. {name:'W',max:12},
  1015. {name:'WSW',max:12},
  1016. {name:'SW',max:12},
  1017. {name:'SSW',max:12},
  1018. {name:'S',max:12},
  1019. {name:'SSE',max:12},
  1020. {name:'SE',max:12},
  1021. {name:'ESE',max:12},
  1022. {name:'E',max:12},
  1023. {name:'ENE',max:12},
  1024. {name:'NE',max:12},
  1025. {name:'NNE',max:12}
  1026. ],
  1027. name:{
  1028. textStyle:{
  1029. color:'rgba(176,204,53,1)'
  1030. }
  1031. },
  1032. axisLine: {
  1033. lineStyle: {
  1034. color: 'rgba(255, 255, 255, 0.4)'
  1035. }
  1036. },
  1037. splitLine: {
  1038. lineStyle: {
  1039. color: 'rgba(255, 255, 255, 0.4)'
  1040. }
  1041. },
  1042. splitArea:{
  1043. areaStyle:{
  1044. color:'rgba(255,255,255,0)'
  1045. }
  1046. }
  1047. },
  1048. series:[{
  1049. type:'radar',
  1050. data:[
  1051. {
  1052. value:[2.8,5.3,7.1,5.4,10.6,8.5,5.1,2.1,2.9,4.0,9.4,6.3,3.5,0.9,1,0.9],
  1053. name:'2016'
  1054. }
  1055. ],
  1056. areaStyle:{
  1057. normal:{
  1058. color:'rgba(176,204,53,.5)'
  1059. }
  1060. },
  1061. lineStyle:{
  1062. normal:{
  1063. color:'rgba(176,204,53,.7)'
  1064. }
  1065. },
  1066. symbol:'circle',
  1067. symbolSize:6,
  1068. itemStyle:{
  1069. normal:{
  1070. color:'#A9C33B'
  1071. }
  1072. }
  1073. }]
  1074. };
  1075. var windChart=echarts.init(document.getElementById('windChart'));
  1076. windChart.setOption(windOption);
  1077. //风速与阵风数据
  1078. var speed={
  1079. wind:[12.2,12.8],
  1080. gust:[2.8,4.3]
  1081. };
  1082. function getData(){
  1083. $('#nowWind').text(speed.wind[0]);
  1084. $('#highWind').text(speed.wind[1]);
  1085. var windSpeed=(50-speed.wind[0])*10;
  1086. $('.windSpeed .windFan').css('animation-duration', windSpeed+'ms');
  1087. $('#nowGust').text(speed.gust[0]);
  1088. $('#highGust').text(speed.gust[1]);
  1089. var gustSpeed=(50-speed.gust[0])*10;
  1090. $('.gust .windFan').css('animation-duration', gustSpeed+'ms');
  1091. }
  1092. getData();
  1093. //降雨量
  1094. function creatBall(ele,data){
  1095. new WaterPolo(ele,{
  1096. cW:55,
  1097. cH:55,
  1098. baseY:data
  1099. })
  1100. }
  1101. creatBall('rainfallOne',80);
  1102. creatBall('rainfallTwo',60);
  1103. creatBall('rainfallThree',30);
  1104. creatBall('rainfallFour',20);
  1105. });
  1106. </script>
  1107. </body>
  1108. </html>