avg.js 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261
  1. // pages/avg/avg.js
  2. import * as echarts from '../../ec-canvas/echarts';
  3. const $api = require('../../utils/api.js').API;
  4. var records = []
  5. Page({
  6. /**
  7. * 页面的初始数据
  8. */
  9. data: {
  10. tab:['冠军组','千万组','百万组'],
  11. list:[],
  12. cur:0,
  13. match_name:'',
  14. ec: {
  15. onInit: null
  16. },
  17. datas:[],
  18. date:'',
  19. },
  20. /**
  21. * 生命周期函数--监听页面加载
  22. */
  23. onLoad(options) {
  24. let nlist = JSON.parse(decodeURIComponent(options.list))
  25. this.setData({
  26. cur:options.index,
  27. list:nlist,
  28. match_name:nlist[0].match_name,
  29. })
  30. if(options.index == -1){
  31. this.loadAvg()
  32. } else{
  33. this.loadGroupAvg()
  34. }
  35. },
  36. loadGroupAvg(){
  37. var group = this.data.list[this.data.cur]
  38. var param = {
  39. match_id:group.match_id,
  40. group_id:group.match_group,
  41. }
  42. $api.getAllDay(param).then(res => {
  43. // console.log(res.data.data.list)
  44. if(res.data.code == 0){
  45. records = res.data.data.list
  46. var data = records[0]
  47. var date = data.stock_date.substring(0,7)
  48. var days = [], w = new Date(date + '-01').getDay();
  49. for (let i = 0; i < w; i++) {
  50. days.push({
  51. day: '',
  52. income: ''
  53. })
  54. }
  55. for (let i = 0; i < records.length; i++) {
  56. days.push({
  57. day: i+1,
  58. income: records[i].today_income,
  59. })
  60. }
  61. this.setData({
  62. ec: {
  63. onInit: initChart
  64. },
  65. days: days,
  66. date:date,
  67. })
  68. }
  69. })
  70. },
  71. loadAvg(){
  72. var group = this.data.list[0]
  73. var param = {
  74. match_id:group.match_id,
  75. }
  76. $api.getAvg(param).then(res => {
  77. if(res.data.code == 0){
  78. records = res.data.data.list
  79. var data = records[0]
  80. var date = data.stock_date.substring(0,7)
  81. var days = [], w = new Date(date + '-01').getDay();
  82. for (let i = 0; i < w; i++) {
  83. days.push({
  84. day: '',
  85. income: ''
  86. })
  87. }
  88. for (let i = 0; i < records.length; i++) {
  89. days.push({
  90. day: i+1,
  91. income: records[i].today_income,
  92. })
  93. }
  94. this.setData({
  95. ec: {
  96. onInit: initChart
  97. },
  98. days: days,
  99. date:date,
  100. })
  101. }
  102. })
  103. },
  104. tabChange(e){
  105. this.setData({
  106. cur:e.target.dataset.id
  107. })
  108. },
  109. /**
  110. * 生命周期函数--监听页面初次渲染完成
  111. */
  112. onReady() {
  113. },
  114. /**
  115. * 生命周期函数--监听页面显示
  116. */
  117. onShow() {
  118. },
  119. /**
  120. * 生命周期函数--监听页面隐藏
  121. */
  122. onHide() {
  123. },
  124. /**
  125. * 生命周期函数--监听页面卸载
  126. */
  127. onUnload() {
  128. },
  129. /**
  130. * 页面相关事件处理函数--监听用户下拉动作
  131. */
  132. onPullDownRefresh() {
  133. },
  134. /**
  135. * 页面上拉触底事件的处理函数
  136. */
  137. onReachBottom() {
  138. },
  139. /**
  140. * 用户点击右上角分享
  141. */
  142. onShareAppMessage() {
  143. }
  144. })
  145. /**折线图 */
  146. function initChart(canvas, width, height, dpr) {
  147. var xdata = [], ydata = [];
  148. for (let i = 0; i < records.length; i++) {
  149. let date = records[i].stock_date.split('-');
  150. xdata.push(date[1] + '/' + date[2])
  151. let y = records[i].total_income.replace('%', '')
  152. ydata.push(Number(y))
  153. }
  154. xdata = xdata.reverse()
  155. ydata = ydata.reverse()
  156. const chart = echarts.init(canvas, null, {
  157. width: width,
  158. height: height,
  159. devicePixelRatio: dpr // new
  160. });
  161. canvas.setChart(chart);
  162. var option = {
  163. legend: {
  164. show: false
  165. },
  166. grid: {
  167. x: 40,
  168. y: 10,
  169. x2: 10,
  170. y2: 35
  171. },
  172. tooltip: {
  173. show: true,
  174. trigger: 'axis',
  175. formatter: '{b0}: {c0}%',
  176. },
  177. xAxis: {
  178. type: 'category',
  179. data: xdata,
  180. axisLabel: {
  181. interval: 0,
  182. rotate: 40,
  183. color: '#999999',
  184. interval: 2
  185. }
  186. },
  187. yAxis: {
  188. axisLine: {
  189. show: true,
  190. },
  191. type: 'value',
  192. // name: '收益曲线',
  193. axisLabel: {
  194. color: '#999999',
  195. formatter: function (value, index) {//隐藏 0
  196. let texts = [];
  197. texts.push(value + '%')
  198. return texts;
  199. },
  200. show: true
  201. },
  202. },
  203. series: [{
  204. name: 'A',
  205. type: 'line',
  206. smooth: true,
  207. symbolSize: 4,
  208. lineStyle: {
  209. color: '#FF2D68'
  210. // color: new echarts.graphic.LinearGradient(1, 0, 0, 0, [{
  211. // offset: 0,
  212. // color: '#FF2D68'
  213. // }, {
  214. // offset: 1,
  215. // color: '#4C4BFF'
  216. // }]),
  217. },
  218. itemStyle: {
  219. borderWidth: 5,
  220. borderColor: '#FFAD52',
  221. color: '#FFAD52'
  222. },
  223. data: ydata
  224. }]
  225. };
  226. chart.setOption(option);
  227. return chart;
  228. }