setOption.js 63 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221
  1. describe('graphic_setOption', function() {
  2. var utHelper = window.utHelper;
  3. var testCase = utHelper.prepare([
  4. 'echarts/src/chart/line',
  5. 'echarts/src/component/graphic',
  6. 'echarts/src/component/grid'
  7. ]);
  8. var NUMBER_PRECISION = 6;
  9. function propHasAll(els, propsObjList) {
  10. for (var i = 0; i < propsObjList.length; i++) {
  11. propHas(els[i], propsObjList[i]);
  12. }
  13. }
  14. function propHas(target, propsObj) {
  15. if (target == null || propsObj == null) {
  16. expect(false).toEqual(true);
  17. }
  18. expect(typeof target === 'object' && typeof propsObj === 'object').toEqual(true);
  19. // propsObj can be array
  20. if (propsObj instanceof Array) {
  21. expect(target instanceof Array).toEqual(true);
  22. for (var i = 0; i < propsObj.length; i++) {
  23. each(target[i], propsObj[i]);
  24. }
  25. }
  26. else {
  27. for (var name in propsObj) {
  28. if (propsObj.hasOwnProperty(name)) {
  29. each(target[name], propsObj[name]);
  30. }
  31. }
  32. }
  33. function each(targetVal, propVal) {
  34. if (propVal == null) {
  35. expect(targetVal == null).toEqual(true);
  36. }
  37. // object or array
  38. else if (typeof propVal === 'object') {
  39. propHas(targetVal, propVal);
  40. }
  41. else if (typeof propVal === 'number') {
  42. expect(
  43. typeof targetVal === 'number'
  44. && propVal.toFixed(NUMBER_PRECISION) === targetVal.toFixed(NUMBER_PRECISION)
  45. ).toEqual(true);
  46. }
  47. else {
  48. expect(targetVal === propVal).toEqual(true);
  49. }
  50. }
  51. }
  52. var imageURI = ''; // jshint ignore:line
  53. describe('option', function () {
  54. testCase.createChart()('optionFlatten', function () {
  55. this.chart.setOption({
  56. graphic: [
  57. {
  58. id: 'uriimg',
  59. type: 'image',
  60. name: 'nameuriimg',
  61. origin: [20, 20],
  62. left: 10,
  63. top: 10,
  64. style: {
  65. image: imageURI,
  66. width: 80,
  67. height: 80,
  68. opacity: 0.5
  69. }
  70. },
  71. {
  72. type: 'group',
  73. id: 'gr',
  74. width: 230,
  75. height: 110,
  76. position: [70, 90],
  77. children: [
  78. {
  79. type: 'rect',
  80. name: 'rectxx',
  81. shape: {
  82. width: 230,
  83. height: 80
  84. },
  85. style: {
  86. stroke: 'red',
  87. fill: 'transparent',
  88. lineWidth: 2
  89. },
  90. z: 100
  91. },
  92. {
  93. id: 'grouptext',
  94. type: 'text',
  95. bottom: 0,
  96. right: 0,
  97. rotation: 0.5,
  98. style: {
  99. text: 'aaa'
  100. },
  101. z: 100
  102. }
  103. ]
  104. },
  105. {
  106. type: 'text',
  107. bottom: 0,
  108. left: 'center',
  109. style: {
  110. text: 'bbb'
  111. },
  112. z: 100
  113. }
  114. ]
  115. });
  116. // Set option using getOption
  117. var option = this.chart.getOption();
  118. expect(option.graphic.length === 1).toEqual(true);
  119. var optionElements = option.graphic[0].elements;
  120. expect(optionElements && optionElements.length === 5).toEqual(true);
  121. expect(optionElements[0].id === 'uriimg' && optionElements[0].parentId == null).toEqual(true);
  122. expect(optionElements[1].id === 'gr' && optionElements[1].parentId == null).toEqual(true);
  123. expect(optionElements[2].name === 'rectxx' && optionElements[2].parentId === 'gr').toEqual(true);
  124. expect(optionElements[3].style.text === 'aaa' && optionElements[3].parentId === 'gr').toEqual(true);
  125. expect(optionElements[4].style.text === 'bbb' && optionElements[4].parentId == null).toEqual(true);
  126. });
  127. testCase.createChart()('groupSetOptionGetOption', function () {
  128. var chart = this.chart;
  129. chart.setOption({
  130. graphic: [
  131. {
  132. id: 'uriimg',
  133. type: 'image',
  134. name: 'nameuriimg',
  135. origin: [20, 20],
  136. left: 10,
  137. top: 10,
  138. style: {
  139. image: imageURI,
  140. width: 80,
  141. height: 80,
  142. opacity: 0.5
  143. }
  144. },
  145. {
  146. type: 'group',
  147. id: 'gr',
  148. width: 230,
  149. height: 110,
  150. position: [70, 90],
  151. children: [
  152. {
  153. type: 'rect',
  154. name: 'rectxx',
  155. shape: {
  156. width: 230,
  157. height: 80
  158. },
  159. style: {
  160. stroke: 'red',
  161. fill: 'transparent',
  162. lineWidth: 2
  163. },
  164. z: 100
  165. },
  166. {
  167. id: 'grouptext',
  168. type: 'text',
  169. bottom: 0,
  170. right: 0,
  171. rotation: 0.5,
  172. style: {
  173. text: 'aaa'
  174. },
  175. z: 100
  176. }
  177. ]
  178. },
  179. {
  180. type: 'text',
  181. bottom: 0,
  182. left: 'center',
  183. style: {
  184. text: 'bbb'
  185. },
  186. z: 100
  187. }
  188. ]
  189. });
  190. checkExistsAndRelations();
  191. // Set option using getOption
  192. chart.setOption(this.chart.getOption());
  193. // Check again, should be the same as before.
  194. checkExistsAndRelations();
  195. function checkExistsAndRelations() {
  196. var els = utHelper.getGraphicElements(chart, 'graphic');
  197. expect(els.length === 6).toEqual(true);
  198. expect(els[0].type === 'group').toEqual(true);
  199. expect(els[1].name === 'nameuriimg').toEqual(true);
  200. expect(els[2].type === 'group').toEqual(true);
  201. var groupEls = utHelper.getGraphicElements(els[2], 'graphic');
  202. expect(groupEls.length === 2).toEqual(true);
  203. expect(groupEls[0] === els[3]).toEqual(true);
  204. expect(groupEls[1] === els[4]).toEqual(true);
  205. expect(els[3].name === 'rectxx').toEqual(true);
  206. expect(els[4].style.text === 'aaa').toEqual(true);
  207. expect(els[5].style.text === 'bbb').toEqual(true);
  208. }
  209. });
  210. testCase.createChart()('onlyOneGraphicComponentAvailable', function () {
  211. var chart = this.chart;
  212. chart.setOption({
  213. graphic: [
  214. {
  215. elements: [
  216. {
  217. type: 'circle',
  218. shape: {
  219. cx: 50,
  220. cy: 50,
  221. r: 20
  222. }
  223. },
  224. {
  225. type: 'circle',
  226. shape: {
  227. cx: 150,
  228. cy: 150,
  229. r: 20
  230. }
  231. }
  232. ]
  233. },
  234. {
  235. elements: [
  236. {
  237. type: 'circle',
  238. shape: {
  239. cx: 100,
  240. cy: 100,
  241. r: 20
  242. }
  243. }
  244. ]
  245. }
  246. ]
  247. });
  248. expect(!!chart.getModel().getComponent('graphic')).toEqual(true);
  249. expect(chart.getModel().getComponent('graphic', 1) == null).toEqual(true);
  250. });
  251. testCase.createChart()('replace', function () {
  252. var chart = this.chart;
  253. chart.setOption({
  254. graphic: {
  255. type: 'circle',
  256. name: 'a',
  257. shape: {
  258. cx: 50,
  259. cy: 50,
  260. r: 20
  261. },
  262. style: {
  263. fill: 'green',
  264. stroke: 'pink',
  265. lineWidth: 3
  266. }
  267. }
  268. });
  269. var els = utHelper.getGraphicElements(chart, 'graphic');
  270. expect(els.length === 2).toEqual(true);
  271. expect(els[0].type === 'group').toEqual(true);
  272. expect(els[1].name === 'a' && els[1].type === 'circle').toEqual(true);
  273. chart.setOption({
  274. graphic: {
  275. type: 'rect',
  276. $action: 'replace',
  277. name: 'b',
  278. shape: {
  279. x: 50,
  280. y: 50,
  281. width: 20,
  282. height: 60
  283. },
  284. style: {
  285. fill: 'green',
  286. stroke: 'pink',
  287. lineWidth: 3
  288. }
  289. }
  290. });
  291. var els = utHelper.getGraphicElements(chart, 'graphic');
  292. expect(els.length === 2).toEqual(true);
  293. expect(els[0].type === 'group').toEqual(true);
  294. expect(els[1].name === 'b' && els[1].type === 'rect').toEqual(true);
  295. expect(els[1].shape && els[1].shape.width === 20).toEqual(true);
  296. });
  297. function getDeleteSourceOption() {
  298. return {
  299. graphic: [
  300. {
  301. type: 'text',
  302. name: 'textname',
  303. style: {
  304. text: 'asdf哈呵',
  305. font: '40px sans-serif',
  306. x: 100,
  307. y: 40
  308. }
  309. },
  310. {
  311. id: 'rrr',
  312. name: 'ringname',
  313. type: 'ring',
  314. shape: {
  315. cx: 50,
  316. cy: 150,
  317. r: 20,
  318. r0: 5
  319. }
  320. },
  321. {
  322. id: 'xxx',
  323. name: 'rectname',
  324. type: 'rect',
  325. shape: {
  326. x: 250,
  327. y: 50,
  328. width: 20,
  329. height: 80
  330. }
  331. }
  332. ]
  333. };
  334. }
  335. function checkDeteteSource(chart) {
  336. var els = utHelper.getGraphicElements(chart, 'graphic');
  337. expect(els.length === 4);
  338. expect(els[1].type === 'text' && els[1].name === 'textname').toEqual(true);
  339. expect(els[2].type === 'ring' && els[2].name === 'ringname').toEqual(true);
  340. expect(els[3].type === 'rect' && els[3].name === 'rectname').toEqual(true);
  341. }
  342. testCase.createChart()('deleteBy$action', function () {
  343. var chart = this.chart;
  344. chart.setOption(getDeleteSourceOption());
  345. checkDeteteSource(chart);
  346. chart.setOption({
  347. graphic: {
  348. id: 'rrr',
  349. $action: 'remove'
  350. }
  351. });
  352. var els = utHelper.getGraphicElements(chart, 'graphic');
  353. expect(els.length === 3);
  354. expect(els[1].type === 'text' && els[1].name === 'textname').toEqual(true);
  355. expect(els[2].type === 'rect' && els[2].name === 'rectname').toEqual(true);
  356. });
  357. testCase.createChart()('deleteBySetOptionNotMerge', function () {
  358. var chart = this.chart;
  359. chart.setOption(getDeleteSourceOption());
  360. checkDeteteSource(chart);
  361. chart.setOption({
  362. graphic: {
  363. type: 'rect',
  364. name: 'rectname2',
  365. shape: {
  366. y: 100,
  367. x: 250,
  368. width: 40,
  369. height: 140
  370. },
  371. style: {
  372. fill: 'blue'
  373. }
  374. }
  375. }, true);
  376. var els = utHelper.getGraphicElements(chart, 'graphic');
  377. expect(els.length === 2);
  378. expect(els[1].type === 'rect' && els[1].name === 'rectname2').toEqual(true);
  379. });
  380. testCase.createChart()('deleteByClear', function () {
  381. var chart = this.chart;
  382. chart.setOption(getDeleteSourceOption());
  383. checkDeteteSource(chart);
  384. chart.clear();
  385. var els = utHelper.getGraphicElements(chart, 'graphic');
  386. expect(els.length === 0);
  387. });
  388. function checkMergeElements(chart, merged) {
  389. propHasAll(utHelper.getGraphicElements(chart, 'graphic'), [
  390. {
  391. position: [0, 0],
  392. scale: [1, 1],
  393. rotation: 0
  394. },
  395. {
  396. position: [0, 0],
  397. scale: [1, 1],
  398. rotation: 0,
  399. style: {},
  400. shape: {
  401. x: !merged ? 250 : 350,
  402. y: 50,
  403. width: 20,
  404. height: 80,
  405. r: 0
  406. }
  407. },
  408. {
  409. position: [0, 0],
  410. scale: [1, 1],
  411. rotation: 0
  412. },
  413. {
  414. position: [0, 0],
  415. scale: [1, 1],
  416. rotation: 0,
  417. style: {
  418. fill: !merged ? 'yellow' : 'pink'
  419. },
  420. shape: {
  421. x: 30,
  422. y: 30,
  423. width: 10,
  424. height: 20,
  425. r: 0
  426. }
  427. },
  428. {
  429. position: [0, 0],
  430. scale: [1, 1],
  431. rotation: 0,
  432. style: !merged
  433. ? {}
  434. : {
  435. fill: 'green'
  436. },
  437. shape: {
  438. cx: !merged ? 50 : 150,
  439. cy: 150,
  440. r: 20,
  441. r0: 5
  442. }
  443. }
  444. ]);
  445. }
  446. testCase.createChart()('mergeTroughFlatForamt', function () {
  447. var chart = this.chart;
  448. chart.setOption({
  449. graphic: [
  450. {
  451. type: 'rect',
  452. shape: {
  453. x: 250,
  454. y: 50,
  455. width: 20,
  456. height: 80
  457. }
  458. },
  459. {
  460. type: 'group',
  461. children: [
  462. {
  463. id: 'ing',
  464. type: 'rect',
  465. shape: {
  466. x: 30,
  467. y: 30,
  468. width: 10,
  469. height: 20
  470. },
  471. style: {
  472. fill: 'yellow'
  473. }
  474. }
  475. ]
  476. },
  477. {
  478. id: 'rrr',
  479. type: 'ring',
  480. shape: {
  481. cx: 50,
  482. cy: 150,
  483. r: 20,
  484. r0: 5
  485. }
  486. }
  487. ]
  488. });
  489. checkMergeElements(chart);
  490. chart.setOption({
  491. graphic: [
  492. {
  493. shape: {
  494. x: 350
  495. }
  496. },
  497. {
  498. id: 'rrr',
  499. shape: {
  500. cx: 150
  501. },
  502. style: {
  503. fill: 'green'
  504. }
  505. },
  506. // flat mode
  507. {
  508. id: 'ing',
  509. style: {
  510. fill: 'pink'
  511. }
  512. }
  513. ]
  514. });
  515. checkMergeElements(chart, true);
  516. });
  517. });
  518. describe('groupLRTB', function() {
  519. function getOption() {
  520. return {
  521. graphic: [
  522. {
  523. type: 'text',
  524. bottom: 0,
  525. right: 0,
  526. rotation: Math.PI / 4,
  527. style: {
  528. font: '24px Microsoft YaHei',
  529. text: '全屏右下角'
  530. },
  531. z: 100
  532. },
  533. {
  534. id: 'uriimg',
  535. type: 'image',
  536. origin: [20, 20],
  537. left: 10,
  538. top: 10,
  539. style: {
  540. image: imageURI,
  541. width: 80,
  542. height: 80,
  543. opacity: 0.5
  544. }
  545. },
  546. {
  547. type: 'group',
  548. id: 'gr',
  549. width: 230,
  550. height: 110,
  551. position: [70, 90],
  552. children: [
  553. {
  554. type: 'rect',
  555. shape: {
  556. width: 230,
  557. height: 80
  558. },
  559. style: {
  560. stroke: 'red',
  561. fill: 'transparent',
  562. lineWidth: 2
  563. },
  564. z: 100
  565. },
  566. {
  567. type: 'rect',
  568. shape: {
  569. width: 60,
  570. height: 110
  571. },
  572. style: {
  573. stroke: 'red',
  574. fill: 'transparent',
  575. lineWidth: 2
  576. },
  577. z: 100
  578. },
  579. {
  580. id: 'grouptext',
  581. type: 'text',
  582. bottom: 0,
  583. right: 0,
  584. rotation: 0.5,
  585. style: {
  586. font: '14px Microsoft YaHei',
  587. text: 'group最右下角'
  588. },
  589. z: 100
  590. }
  591. ]
  592. },
  593. {
  594. type: 'text',
  595. bottom: 0,
  596. left: 'center',
  597. style: {
  598. font: '18px sans-serif',
  599. text: '全屏最下中间\n这是多行文字\n这是第三行'
  600. },
  601. z: 100
  602. }
  603. ]
  604. };
  605. }
  606. function checkLocations(chart, uriimgChanged) {
  607. propHasAll(utHelper.getGraphicElements(chart, 'graphic'), [
  608. {
  609. position: [0, 0],
  610. scale: [1, 1],
  611. rotation: 0
  612. },
  613. {
  614. position: [98.17662350913716, 133.02943725152284],
  615. scale: [1, 1],
  616. rotation: 0.7853981633974483,
  617. style: {
  618. font: '24px Microsoft YaHei',
  619. text: '全屏右下角',
  620. textVerticalAlign: null
  621. }
  622. },
  623. !uriimgChanged
  624. ? {
  625. position: [10, 10],
  626. scale: [1, 1],
  627. rotation: 0,
  628. style: {
  629. height: 80,
  630. opacity: 0.5,
  631. width: 80,
  632. image: imageURI
  633. }
  634. }
  635. : {
  636. position: [61, 45],
  637. scale: [1, 1],
  638. rotation: 0,
  639. style: {
  640. height: 60,
  641. opacity: 0.5,
  642. width: 78,
  643. image: imageURI
  644. }
  645. },
  646. {
  647. position: [70, 90],
  648. scale: [1, 1],
  649. rotation: 0
  650. },
  651. {
  652. position: [0, 0],
  653. scale: [1, 1],
  654. rotation: 0,
  655. style: {
  656. stroke: 'red',
  657. fill: 'transparent',
  658. lineWidth: 2
  659. },
  660. shape: {
  661. width: 230,
  662. height: 80,
  663. r: 0,
  664. x: 0,
  665. y: 0
  666. }
  667. },
  668. {
  669. position: [0, 0],
  670. scale: [1, 1],
  671. rotation: 0,
  672. style: {
  673. stroke: 'red',
  674. fill: 'transparent',
  675. lineWidth: 2
  676. },
  677. shape: {
  678. width: 60,
  679. height: 110,
  680. r: 0,
  681. x: 0,
  682. y: 0
  683. }
  684. },
  685. {
  686. position: [145.47972137162424, 97.71384413353478],
  687. scale: [1, 1],
  688. rotation: 0.5,
  689. style: {
  690. font: '14px Microsoft YaHei',
  691. text: 'group最右下角',
  692. textVerticalAlign: null
  693. }
  694. },
  695. {
  696. position: [46, 96],
  697. scale: [1, 1],
  698. rotation: 0,
  699. style: {
  700. font: '18px sans-serif',
  701. text: '全屏最下中间\n这是多行文字\n这是第三行',
  702. textVerticalAlign: null
  703. }
  704. }
  705. ]);
  706. }
  707. function checkResizedLocations(chart) {
  708. propHasAll(utHelper.getGraphicElements(chart, 'graphic'), [
  709. {
  710. position: [0, 0],
  711. scale: [1, 1],
  712. rotation: 0
  713. },
  714. {
  715. position: [98.17662350913716, 133.02943725152286],
  716. scale: [1, 1],
  717. rotation: 0.7853981633974483,
  718. style: {
  719. font: '24px Microsoft YaHei',
  720. text: '全屏右下角',
  721. textVerticalAlign: null
  722. }
  723. },
  724. {
  725. position: [10, 10],
  726. scale: [1, 1],
  727. rotation: 0,
  728. style: {
  729. image: imageURI,
  730. width: 80,
  731. height: 80,
  732. opacity: 0.5
  733. }
  734. },
  735. {
  736. position: [70, 90],
  737. scale: [1, 1],
  738. rotation: 0
  739. },
  740. {
  741. position: [0, 0],
  742. scale: [1, 1],
  743. rotation: 0,
  744. style: {
  745. stroke: 'red',
  746. fill: 'transparent',
  747. lineWidth: 2
  748. },
  749. shape: {
  750. width: 230,
  751. height: 80,
  752. r: 0,
  753. x: 0,
  754. y: 0
  755. }
  756. },
  757. {
  758. position: [0, 0],
  759. scale: [1, 1],
  760. rotation: 0,
  761. style: {
  762. stroke: 'red',
  763. fill: 'transparent',
  764. lineWidth: 2
  765. },
  766. shape: {
  767. width: 60,
  768. height: 110,
  769. r: 0,
  770. x: 0,
  771. y: 0
  772. }
  773. },
  774. {
  775. position: [145.47972137162424, 97.71384413353478],
  776. scale: [1, 1],
  777. rotation: 0.5,
  778. style: {
  779. font: '14px Microsoft YaHei',
  780. text: 'group最右下角',
  781. textVerticalAlign: null
  782. }
  783. },
  784. {
  785. position: [46, 96],
  786. scale: [1, 1],
  787. rotation: 0,
  788. style: {
  789. font: '18px sans-serif',
  790. text: '全屏最下中间\n这是多行文字\n这是第三行',
  791. textVerticalAlign: null
  792. }
  793. }
  794. ]);
  795. }
  796. testCase.createChart(1, 200, 150)('getAndGet', function () {
  797. var chart = this.chart;
  798. chart.setOption(getOption());
  799. checkLocations(chart);
  800. // Set option using getOption
  801. chart.setOption(this.chart.getOption());
  802. // Check again, should be the same as before.
  803. checkLocations(chart);
  804. });
  805. // Test modify location by setOption.
  806. // And test center and middle.
  807. testCase.createChart(1, 200, 150)('modifyAndCenter', function () {
  808. var chart = this.chart;
  809. chart.setOption(getOption());
  810. checkLocations(chart);
  811. chart.setOption({
  812. graphic: [{
  813. id: 'uriimg',
  814. left: 'center',
  815. top: 'middle',
  816. style: {
  817. width: 78,
  818. height: 60
  819. }
  820. }]
  821. });
  822. checkLocations(chart, true);
  823. });
  824. testCase.createChart(1, 200, 150)('resize', function () {
  825. var chart = this.chart;
  826. chart.setOption(getOption());
  827. checkLocations(chart);
  828. chart.resize(220, 300);
  829. checkResizedLocations(chart);
  830. });
  831. });
  832. describe('boundingAndRotation', function() {
  833. function getOption() {
  834. return {
  835. legend: {
  836. data:['高度(km)与气温(°C)变化关系']
  837. },
  838. xAxis: {
  839. },
  840. yAxis: {
  841. type: 'category',
  842. data: ['0', '10', '20', '30', '40', '50', '60', '70', '80']
  843. },
  844. graphic: [
  845. {
  846. type: 'image',
  847. id: 'img',
  848. z: -10,
  849. right: 0,
  850. top: 0,
  851. bounding: 'raw',
  852. origin: [75, 75],
  853. style: {
  854. fill: '#000',
  855. image: imageURI,
  856. width: 150,
  857. height: 150,
  858. opacity: 0.4
  859. }
  860. },
  861. {
  862. type: 'group',
  863. id: 'rectgroup1',
  864. bottom: 0,
  865. right: 0,
  866. bounding: 'raw',
  867. children: [
  868. {
  869. type: 'rect',
  870. left: 'center',
  871. top: 'center',
  872. shape: {
  873. width: 20,
  874. height: 80
  875. },
  876. style: {
  877. stroke: 'green',
  878. fill: 'transparent'
  879. }
  880. },
  881. {
  882. type: 'rect',
  883. left: 'center',
  884. top: 'center',
  885. shape: {
  886. width: 80,
  887. height: 20
  888. },
  889. style: {
  890. stroke: 'green',
  891. fill: 'transparent'
  892. }
  893. }
  894. ]
  895. },
  896. {
  897. type: 'rect',
  898. id: 'rect2',
  899. bottom: 0,
  900. right: 'center',
  901. shape: {
  902. width: 50,
  903. height: 80
  904. },
  905. style: {
  906. stroke: 'green',
  907. fill: 'transparent'
  908. }
  909. },
  910. {
  911. type: 'group',
  912. id: 'textGroup1',
  913. left: '10%',
  914. top: 'center',
  915. scale: [1, 0.5],
  916. children: [
  917. {
  918. type: 'rect',
  919. z: 100,
  920. left: 'center',
  921. top: 'center',
  922. shape: {
  923. width: 170,
  924. height: 70
  925. },
  926. style: {
  927. fill: '#fff',
  928. stroke: '#999',
  929. lineWidth: 2,
  930. shadowBlur: 8,
  931. shadowOffsetX: 3,
  932. shadowOffsetY: 3,
  933. shadowColor: 'rgba(0,0,0,0.3)'
  934. }
  935. },
  936. {
  937. type: 'text',
  938. z: 100,
  939. top: 'middle',
  940. left: 'center',
  941. style: {
  942. text: [
  943. '横轴表示温度,单位是°C',
  944. '纵轴表示高度,单位是km',
  945. '右上角有一个图片做的水印'
  946. ].join('\n'),
  947. font: '12px Microsoft YaHei'
  948. }
  949. }
  950. ]
  951. }
  952. ],
  953. series: [
  954. {
  955. name: '高度(km)与气温(°C)变化关系',
  956. type: 'line',
  957. data:[15, -50, -56.5, -46.5, -22.1, -2.5, -27.7, -55.7, -76.5]
  958. }
  959. ]
  960. };
  961. }
  962. function checkLocations(chart, rotated) {
  963. propHasAll(utHelper.getGraphicElements(chart, 'graphic'), [
  964. {
  965. position: [0, 0],
  966. scale: [1, 1],
  967. rotation: 0
  968. },
  969. {
  970. position: [350, 0],
  971. scale: [1, 1],
  972. rotation: !rotated ? 0 : 0.6283185307179586,
  973. style: {
  974. fill: '#000',
  975. image: imageURI,
  976. width: 150,
  977. height: 150,
  978. opacity: 0.4
  979. }
  980. },
  981. {
  982. position: [500, 400],
  983. scale: [1, 1],
  984. rotation: !rotated ? 0 : 0.6283185307179586
  985. },
  986. {
  987. position: [-10, -40],
  988. scale: [1, 1],
  989. rotation: 0,
  990. style: {
  991. stroke: 'green',
  992. fill: 'transparent'
  993. },
  994. shape: {
  995. width: 20,
  996. height: 80,
  997. r: 0,
  998. x: 0,
  999. y: 0
  1000. }
  1001. },
  1002. {
  1003. position: [-40, -10],
  1004. scale: [1, 1],
  1005. rotation: 0,
  1006. style: {
  1007. stroke: 'green',
  1008. fill: 'transparent'
  1009. },
  1010. shape: {
  1011. width: 80,
  1012. height: 20,
  1013. r: 0,
  1014. x: 0,
  1015. y: 0
  1016. }
  1017. },
  1018. {
  1019. position: !rotated ? [225, 319.5] : [206.2631650489274, 334.5802393266705],
  1020. scale: [1, 1],
  1021. rotation: !rotated ? 0 : 0.6283185307179586,
  1022. style: {
  1023. stroke: 'green',
  1024. fill: 'transparent'
  1025. },
  1026. shape: {
  1027. width: 50,
  1028. height: 80,
  1029. r: 0,
  1030. x: 0,
  1031. y: 0
  1032. }
  1033. },
  1034. {
  1035. position: !rotated ? [136, 200] : [130.15559605751, 200],
  1036. scale: [1, 0.5],
  1037. rotation: !rotated ? 0 : 0.6283185307179586
  1038. },
  1039. {
  1040. position: [-85, -35],
  1041. scale: [1, 1],
  1042. rotation: 0,
  1043. style: {
  1044. fill: '#fff',
  1045. stroke: '#999',
  1046. lineWidth: 2,
  1047. shadowBlur: 8,
  1048. shadowOffsetX: 3,
  1049. shadowOffsetY: 3,
  1050. shadowColor: 'rgba(0,0,0,0.3)'
  1051. },
  1052. shape: {
  1053. width: 170,
  1054. height: 70,
  1055. r: 0,
  1056. x: 0,
  1057. y: 0
  1058. }
  1059. },
  1060. {
  1061. position: [-72, -18],
  1062. scale: [1, 1],
  1063. rotation: 0,
  1064. style: {
  1065. text: '横轴表示温度,单位是°C\n纵轴表示高度,单位是km\n右上角有一个图片做的水印',
  1066. font: '12px Microsoft YaHei',
  1067. textVerticalAlign: null
  1068. }
  1069. }
  1070. ]);
  1071. }
  1072. testCase.createChart()('bounding', function () {
  1073. var chart = this.chart;
  1074. chart.setOption(getOption());
  1075. checkLocations(chart);
  1076. // Set option using getOption
  1077. chart.setOption(this.chart.getOption());
  1078. // Check again, should be the same as before.
  1079. checkLocations(chart);
  1080. var rotation = Math.PI / 5;
  1081. chart.setOption({
  1082. graphic: [{
  1083. id: 'img',
  1084. bounding: 'raw',
  1085. origin: [75, 75],
  1086. rotation: rotation
  1087. }, {
  1088. id: 'rectgroup1',
  1089. rotation: rotation
  1090. }, {
  1091. id: 'rect2',
  1092. rotation: rotation
  1093. }, {
  1094. id: 'textGroup1',
  1095. rotation: rotation
  1096. }]
  1097. });
  1098. checkLocations(chart, true);
  1099. });
  1100. });
  1101. });