setOption.js 64 KB

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