graphicOption.html 44 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876
  1. <!DOCTYPE>
  2. <html>
  3. <head>
  4. <meta charset="utf-8">
  5. <script src="esl.js"></script>
  6. <script src="config.js"></script>
  7. <script src="lib/jquery.min.js"></script>
  8. <script src="lib/facePrint.js"></script>
  9. <script src="lib/draggable.js"></script>
  10. <meta name="viewport" content="width=device-width, initial-scale=1" />
  11. <link rel="stylesheet" href="reset.css">
  12. </head>
  13. <body>
  14. <style>
  15. body {
  16. }
  17. .block {
  18. overflow: hidden;
  19. height: 200px;
  20. margin-bottom: 20px;
  21. background: #eee;
  22. }
  23. .chart {
  24. height: 100%;
  25. width: 400px;
  26. float: left;
  27. margin-left: 20px;
  28. }
  29. textarea {
  30. margin: 0;
  31. padding: 0;
  32. float: right;
  33. width: 140px;
  34. height: 100%;
  35. }
  36. h3 {
  37. font-size: 16px;
  38. text-align: center;
  39. }
  40. </style>
  41. <script>
  42. function getMain(id) {
  43. var options = [];
  44. $('#' + id + ' textarea').each(function (idx, textarea) {
  45. options.push((new Function('return (' + $(textarea).val() + ')'))());
  46. });
  47. return {
  48. dom: $('#' + id + ' .chart')[0],
  49. option: options[0],
  50. options: options,
  51. buttons: $('#' + id + ' button')
  52. };
  53. }
  54. var imageURI = '';
  55. </script>
  56. <h3>Test group setOption(getOption) mapping.</h3>
  57. <h3>Test left/right/top/bottom in group.</h3>
  58. <h3>Test resize.</h3>
  59. <div class="block" id="main4" style="height: 300px">
  60. <div class="chart"></div>
  61. <textarea>
  62. {
  63. backgroundColor: '#bba',
  64. graphic: [{
  65. id: 'img',
  66. type: 'image',
  67. right: 20,
  68. top: 'center',
  69. style: {
  70. image: 'http://echarts.baidu.com/images/favicon.png',
  71. width: 50,
  72. height: 50,
  73. opacity: 0.5
  74. }
  75. }, {
  76. id: 'uriimg',
  77. type: 'image',
  78. origin: [20, 20],
  79. left: 10,
  80. top: 10,
  81. style: {
  82. image: imageURI,
  83. width: 80,
  84. height: 80,
  85. opacity: 0.5
  86. }
  87. }, {
  88. type: 'text',
  89. bottom: 0,
  90. right: 0,
  91. rotation: Math.PI / 4,
  92. style: {
  93. font: '24px Microsoft YaHei',
  94. text: '全屏右下角'
  95. },
  96. z: 100
  97. }, {
  98. type: 'text',
  99. bottom: 0,
  100. left: 'center',
  101. style: {
  102. font: '18px sans-serif',
  103. text: '全屏最下中间\n这是多行文字\n这是第三行'
  104. },
  105. z: 100
  106. }, {
  107. type: 'group',
  108. id: 'ggggg',
  109. right: 0,
  110. top: 0,
  111. bounding: 'raw',
  112. children: [{
  113. type: 'rect',
  114. left: 'center',
  115. top: 'middle',
  116. shape: {
  117. width: 80,
  118. height: 60
  119. },
  120. style: {
  121. fill: 'green'
  122. },
  123. z: 99
  124. }, {
  125. type: 'text',
  126. left: 'center',
  127. top: 'middle',
  128. style: {
  129. font: '14px Microsoft YaHei',
  130. text: '居中定位\n文字居中\n应超出屏幕'
  131. },
  132. z: 100
  133. }]
  134. }, {
  135. type: 'group',
  136. id: 'gr',
  137. width: 230,
  138. height: 110,
  139. position: [70, 90],
  140. children: [{
  141. type: 'rect',
  142. shape: {
  143. width: 230,
  144. height: 80
  145. },
  146. style: {
  147. stroke: 'red',
  148. fill: 'transparent',
  149. lineWidth: 2
  150. },
  151. z: 100
  152. }, {
  153. type: 'rect',
  154. shape: {
  155. width: 60,
  156. height: 110
  157. },
  158. style: {
  159. stroke: 'red',
  160. fill: 'transparent',
  161. lineWidth: 2
  162. },
  163. z: 100
  164. }, {
  165. id: 'grouptext',
  166. type: 'text',
  167. bottom: 0,
  168. right: 0,
  169. rotation: 0.5,
  170. style: {
  171. font: '14px Microsoft YaHei',
  172. text: 'group最右下角'
  173. },
  174. z: 100
  175. }]
  176. }]
  177. }
  178. </textarea>
  179. <textarea>
  180. {
  181. graphic: [{
  182. id: 'img',
  183. left: 'center',
  184. top: 'middle'
  185. }]
  186. }
  187. </textarea>
  188. <script>
  189. require([
  190. 'echarts',
  191. 'echarts/chart/line',
  192. 'echarts/component/graphic',
  193. 'echarts/component/grid',
  194. 'echarts/component/legend',
  195. 'echarts/component/tooltip'
  196. ], function (echarts) {
  197. var main = getMain('main4');
  198. if (!main.dom) {
  199. return;
  200. }
  201. var chart = echarts.init(main.dom);
  202. draggable.init(main.dom, chart, {throttle: 70});
  203. chart.setOption(main.option);
  204. setTimeout(function () {
  205. chart.setOption(chart.getOption());
  206. setTimeout(function () {
  207. chart.setOption(main.options[1]);
  208. }, 1200);
  209. }, 1200);
  210. var rotation = 0;
  211. setInterval(function () {
  212. rotation += Math.PI / 360;
  213. chart.setOption({
  214. graphic: [{
  215. id: 'img',
  216. rotation: rotation
  217. }, {
  218. id: 'uriimg',
  219. rotation: rotation
  220. }]
  221. });
  222. }, 17);
  223. });
  224. </script>
  225. </div>
  226. <h3>bounding</h3>
  227. <div class="block" id="main5" style="height: 400px">
  228. <div class="chart"></div>
  229. <textarea>
  230. {
  231. backgroundColor: 'rgba(0,0,255,0.08)',
  232. legend: {
  233. data:['高度(km)与气温(°C)变化关系']
  234. },
  235. tooltip: {
  236. trigger: 'axis'
  237. },
  238. xAxis: {
  239. },
  240. yAxis: {
  241. type: 'category',
  242. data: ['0', '10', '20', '30', '40', '50', '60', '70', '80']
  243. },
  244. graphic: [{
  245. type: 'image',
  246. id: 'img',
  247. z: -10,
  248. right: 0,
  249. top: 0,
  250. bounding: 'raw',
  251. origin: [75, 75],
  252. style: {
  253. fill: '#000',
  254. image: 'http://echarts.baidu.com/images/favicon.png',
  255. width: 150,
  256. height: 150,
  257. opacity: 0.4
  258. }
  259. }, {
  260. type: 'group',
  261. id: 'rectgroup1',
  262. bottom: 0,
  263. right: 0,
  264. bounding: 'raw',
  265. children: [{
  266. type: 'rect',
  267. left: 'center',
  268. top: 'center',
  269. shape: {
  270. width: 20,
  271. height: 80
  272. },
  273. style: {
  274. stroke: 'green',
  275. fill: 'transparent'
  276. }
  277. }, {
  278. type: 'rect',
  279. left: 'center',
  280. top: 'center',
  281. shape: {
  282. width: 80,
  283. height: 20
  284. },
  285. style: {
  286. stroke: 'green',
  287. fill: 'transparent'
  288. }
  289. }]
  290. }, {
  291. type: 'rect',
  292. id: 'rect2',
  293. bottom: 0,
  294. right: 'center',
  295. shape: {
  296. width: 50,
  297. height: 80
  298. },
  299. style: {
  300. stroke: 'green',
  301. fill: 'transparent'
  302. }
  303. }, {
  304. type: 'group',
  305. id: 'textGroup1',
  306. left: '10%',
  307. top: 'center',
  308. scale: [1, .5],
  309. children: [
  310. {
  311. type: 'rect',
  312. z: 100,
  313. left: 'center',
  314. top: 'center',
  315. shape: {
  316. width: 170,
  317. height: 70
  318. },
  319. style: {
  320. fill: '#fff',
  321. stroke: '#999',
  322. lineWidth: 2,
  323. shadowBlur: 8,
  324. shadowOffsetX: 3,
  325. shadowOffsetY: 3,
  326. shadowColor: 'rgba(0,0,0,0.3)'
  327. }
  328. },
  329. {
  330. type: 'text',
  331. z: 100,
  332. top: 'middle',
  333. left: 'center',
  334. style: {
  335. text: [
  336. '横轴表示温度,单位是°C',
  337. '纵轴表示高度,单位是km',
  338. '右上角有一个图片做的水印'
  339. ].join('\n'),
  340. font: '12px Microsoft YaHei'
  341. }
  342. }
  343. ]
  344. }],
  345. series: [
  346. {
  347. name: '高度(km)与气温(°C)变化关系',
  348. type: 'line',
  349. data:[15, -50, -56.5, -46.5, -22.1, -2.5, -27.7, -55.7, -76.5]
  350. }
  351. ]
  352. }
  353. </textarea>
  354. <script>
  355. require([
  356. 'echarts',
  357. 'echarts/chart/line',
  358. 'echarts/component/graphic',
  359. 'echarts/component/grid',
  360. 'echarts/component/legend',
  361. 'echarts/component/tooltip'
  362. ], function (echarts) {
  363. var main = getMain('main5');
  364. if (!main.dom) {
  365. return;
  366. }
  367. var chart = echarts.init(main.dom);
  368. draggable.init(main.dom, chart, {throttle: 70});
  369. chart.setOption(main.option);
  370. var rotation = 0;
  371. setInterval(function () {
  372. rotation += Math.PI / 60;
  373. chart.setOption({
  374. graphic: [{
  375. id: 'img',
  376. bounding: 'raw',
  377. origin: [75, 75],
  378. rotation: rotation
  379. }, {
  380. id: 'rectgroup1',
  381. rotation: rotation
  382. }, {
  383. id: 'rect2',
  384. rotation: rotation
  385. }, {
  386. id: 'textGroup1',
  387. rotation: rotation
  388. }]
  389. });
  390. }, 17);
  391. });
  392. </script>
  393. </div>
  394. <h3>replace</h3>
  395. <div class="block" id="main0">
  396. <div class="chart"></div>
  397. <textarea>
  398. {
  399. graphic: {
  400. type: 'circle',
  401. shape: {
  402. cx: 50,
  403. cy: 50,
  404. r: 20,
  405. },
  406. style: {
  407. fill: 'green',
  408. stroke: 'pink',
  409. lineWidth: 3
  410. }
  411. }
  412. }
  413. </textarea>
  414. <textarea>
  415. {
  416. graphic: {
  417. type: 'rect',
  418. $action: 'replace',
  419. shape: {
  420. x: 50,
  421. y: 50,
  422. width: 20,
  423. height: 60
  424. },
  425. style: {
  426. fill: 'green',
  427. stroke: 'pink',
  428. lineWidth: 3
  429. }
  430. }
  431. }
  432. </textarea>
  433. <script>
  434. require([
  435. 'echarts',
  436. 'echarts/chart/line',
  437. 'echarts/component/graphic',
  438. 'echarts/component/grid',
  439. 'echarts/component/legend',
  440. 'echarts/component/tooltip'
  441. ], function (echarts) {
  442. var main = getMain('main0');
  443. if (!main.dom) {
  444. return;
  445. }
  446. var chart = echarts.init(main.dom);
  447. chart.setOption(main.option);
  448. setTimeout(function () {
  449. chart.setOption(chart.getOption());
  450. setTimeout(function () {
  451. chart.setOption(main.options[1]);
  452. }, 1200);
  453. }, 800);
  454. });
  455. </script>
  456. </div>
  457. <div class="block" id="mainz">
  458. <div class="chart"></div>
  459. 只有第一个 graphic 会生效。
  460. <textarea>
  461. {
  462. graphic: [{
  463. elements: [{
  464. type: 'circle',
  465. shape: {
  466. cx: 50,
  467. cy: 50,
  468. r: 20,
  469. }
  470. }, {
  471. type: 'circle',
  472. shape: {
  473. cx: 150,
  474. cy: 150,
  475. r: 20,
  476. }
  477. }]
  478. }, {
  479. elements: [{
  480. type: 'circle',
  481. shape: {
  482. cx: 100,
  483. cy: 100,
  484. r: 20,
  485. }
  486. }]
  487. }]
  488. }
  489. </textarea>
  490. <script>
  491. require([
  492. 'echarts',
  493. 'echarts/chart/line',
  494. 'echarts/component/graphic',
  495. 'echarts/component/grid',
  496. 'echarts/component/legend',
  497. 'echarts/component/tooltip'
  498. ], function (echarts) {
  499. var main = getMain('mainz');
  500. if (!main.dom) {
  501. return;
  502. }
  503. var chart = echarts.init(main.dom);
  504. chart.setOption(main.option);
  505. });
  506. </script>
  507. </div>
  508. <div class="block" id="main1">
  509. <div class="chart"></div>
  510. <textarea>
  511. {
  512. graphic: [{
  513. type: 'rect',
  514. shape: {
  515. x: 50,
  516. y: 50,
  517. width: 20,
  518. height: 80
  519. },
  520. style: {
  521. fill: 'green',
  522. stroke: 'pink',
  523. lineWidth: 3
  524. }
  525. }, {
  526. type: 'ring',
  527. shape: {
  528. cx: 150,
  529. cy: 150,
  530. r: 20,
  531. r0: 5
  532. },
  533. style: {
  534. fill: 'green',
  535. stroke: 'pink',
  536. lineWidth: 3
  537. }
  538. }]
  539. }
  540. </textarea>
  541. <script>
  542. require([
  543. 'echarts',
  544. 'echarts/chart/line',
  545. 'echarts/component/graphic',
  546. 'echarts/component/grid',
  547. 'echarts/component/legend',
  548. 'echarts/component/tooltip'
  549. ], function (echarts) {
  550. var main = getMain('main1');
  551. if (!main.dom) {
  552. return;
  553. }
  554. var chart = echarts.init(main.dom);
  555. chart.setOption(main.option);
  556. setTimeout(function () {
  557. chart.setOption(chart.getOption());
  558. }, 800);
  559. });
  560. </script>
  561. </div>
  562. <div class="block" id="main2">
  563. <div class="chart"></div>
  564. <textarea>
  565. {
  566. graphic: [{
  567. type: 'text',
  568. style: {
  569. text: 'asdf哈呵',
  570. font: '40px sans-serif',
  571. x: 100,
  572. y: 40
  573. }
  574. }, {
  575. id: 'rrr',
  576. type: 'ring',
  577. shape: {
  578. cx: 50,
  579. cy: 150,
  580. r: 20,
  581. r0: 5
  582. }
  583. }, {
  584. id: 'xxx',
  585. type: 'rect',
  586. shape: {
  587. x: 250,
  588. y: 50,
  589. width: 20,
  590. height: 80
  591. }
  592. }]
  593. }
  594. </textarea>
  595. <button>delete by $action</button>
  596. <button>delete by setOption({...}, true)</button>
  597. <button>delete by clear</button>
  598. <script>
  599. require([
  600. 'echarts',
  601. 'echarts/chart/line',
  602. 'echarts/component/graphic',
  603. 'echarts/component/grid',
  604. 'echarts/component/legend',
  605. 'echarts/component/tooltip'
  606. ], function (echarts) {
  607. var main = getMain('main2');
  608. if (!main.dom) {
  609. return;
  610. }
  611. var chart = echarts.init(main.dom);
  612. chart.setOption(main.option);
  613. $(main.buttons[0]).on('click', function () {
  614. chart.setOption({
  615. graphic: {
  616. id: 'rrr',
  617. $action: 'remove'
  618. }
  619. });
  620. });
  621. $(main.buttons[1]).on('click', function () {
  622. chart.setOption({
  623. graphic: {
  624. type: 'rect',
  625. shape: {
  626. y: 100,
  627. x: 250,
  628. width: 40,
  629. height: 140
  630. },
  631. style: {
  632. fill: 'blue'
  633. }
  634. }
  635. }, true);
  636. });
  637. $(main.buttons[2]).on('click', function () {
  638. chart.clear();
  639. });
  640. });
  641. </script>
  642. </div>
  643. <div class="block" id="main3">
  644. <div class="chart"></div>
  645. <textarea>
  646. {
  647. xAxis: {
  648. data: ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat']
  649. },
  650. yAxis: {},
  651. series: [{
  652. type: 'line',
  653. data:[220, 182, 191, 234, 290, 330, 310]
  654. }],
  655. graphic: [{
  656. type: 'text',
  657. style: {
  658. text: 'asdf哈呵',
  659. font: '40px sans-serif',
  660. x: 100,
  661. y: 40
  662. }
  663. }, {
  664. id: 'rrr',
  665. type: 'ring',
  666. shape: {
  667. cx: 50,
  668. cy: 150,
  669. r: 20,
  670. r0: 5
  671. }
  672. }, {
  673. type: 'rect',
  674. shape: {
  675. x: 250,
  676. y: 50,
  677. width: 20,
  678. height: 80
  679. }
  680. }, {
  681. type: 'group',
  682. children: [{
  683. id: 'ing',
  684. type: 'rect',
  685. shape: {
  686. x: 30,
  687. y: 30,
  688. width: 10,
  689. height: 20
  690. },
  691. style: {
  692. fill: 'yellow'
  693. }
  694. }]
  695. }]
  696. }
  697. </textarea>
  698. <textarea>
  699. {
  700. graphic: [{
  701. style: {
  702. font: '60px sans-serif',
  703. x: 200
  704. },
  705. z: 222
  706. }, {
  707. shape: {
  708. cx: 150
  709. },
  710. style: {
  711. fill: 'green'
  712. },
  713. z: 222
  714. }, {
  715. shape: {
  716. x: 350
  717. },
  718. z: 222
  719. }, {
  720. id: 'ing',
  721. style: {
  722. fill: 'pink'
  723. },
  724. z: 222
  725. }]
  726. }
  727. </textarea>
  728. <script>
  729. require([
  730. 'echarts',
  731. 'echarts/chart/line',
  732. 'echarts/component/graphic',
  733. 'echarts/component/grid',
  734. 'echarts/component/legend',
  735. 'echarts/component/tooltip'
  736. ], function (echarts) {
  737. var main = getMain('main3');
  738. if (!main.dom) {
  739. return;
  740. }
  741. var chart = echarts.init(main.dom);
  742. chart.setOption(main.option);
  743. setTimeout(function () {
  744. chart.setOption(main.options[1]);
  745. }, 1200);
  746. });
  747. </script>
  748. </div>
  749. </body>
  750. </html>