haijiang
2018-07-17 63b87b529196c056fb4d96a58eded3936d3445f2
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
package com.moral.screen.activity;
 
import android.app.AlertDialog;
import android.graphics.Color;
import android.graphics.drawable.ColorDrawable;
import android.os.Bundle;
import android.support.annotation.IdRes;
import android.text.TextUtils;
import android.view.LayoutInflater;
import android.view.View;
import android.view.Window;
import android.widget.Button;
import android.widget.ImageView;
import android.widget.RadioGroup;
import android.widget.TextView;
 
import com.lzy.okgo.cache.CacheMode;
import com.moral.andbrickslib.utils.FastJsonTools;
import com.moral.andbrickslib.utils.NumberUtils;
import com.moral.andbrickslib.utils.TimeUtil;
import com.moral.screen.R;
import com.moral.screen.base.BaseActivity;
import com.moral.screen.common.API;
import com.moral.screen.httputils.HttpCallBack;
import com.moral.screen.model.SensorData;
 
import org.json.JSONException;
import org.json.JSONObject;
 
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Timer;
import java.util.TimerTask;
 
import lecho.lib.hellocharts.formatter.AxisValueFormatter;
import lecho.lib.hellocharts.formatter.LineChartValueFormatter;
import lecho.lib.hellocharts.formatter.SimpleAxisValueFormatter;
import lecho.lib.hellocharts.formatter.SimpleLineChartValueFormatter;
import lecho.lib.hellocharts.gesture.ContainerScrollType;
import lecho.lib.hellocharts.gesture.ZoomType;
import lecho.lib.hellocharts.model.Axis;
import lecho.lib.hellocharts.model.AxisValue;
import lecho.lib.hellocharts.model.Line;
import lecho.lib.hellocharts.model.LineChartData;
import lecho.lib.hellocharts.model.PointValue;
import lecho.lib.hellocharts.model.ValueShape;
import lecho.lib.hellocharts.model.Viewport;
import lecho.lib.hellocharts.view.LineChartView;
 
/**
 * Created by haijiang on 2017/7/13.
 */
 
public class ChartActivity extends BaseActivity {
    private LineChartView chartView;
    Line line;
    LineChartData data;
    Axis axisX;
    Axis axisY;
    private List<PointValue> mPointValues = new ArrayList<>();
    private List<AxisValue> mAxisXValues = new ArrayList<>();
 
    private TextView tv_sub,tv_unit;
    private String sensorKey, mac, name, unit;
    private float maxValue;
 
    private Timer timer;
 
    /**
     * 计时器
     */
    private boolean isFinish = false;
    private void showChangeLineChart() {
        timer = new Timer();
        timer.schedule(new TimerTask() {
            @Override
            public void run() {
                if(!isFinish){
                    getData(1,false);
                }
            }
        },0,5*1000);
    }
    @Override
    protected void getBundleExtras(Bundle extras) {
        sensorKey = getIntent().getStringExtra("sensorKey");
        mac = getIntent().getStringExtra("mac");
        name = getIntent().getStringExtra("name");
        unit = getIntent().getStringExtra("unit");
        maxValue = getIntent().getFloatExtra("maxValue", 0);
    }
 
    @Override
    protected int getLayoutId() {
        return R.layout.ac_charts_layout;
    }
 
    @Override
    protected void initViews() {
        initTopBar();
        tv_title.setText("动态走势");
        tv_sub = findView(R.id.tv_sub);
        tv_unit = findView(R.id.tv_unit);
        tv_sub.setText(name + "动态走势图");
        tv_unit.setText("单位:" + unit);
        chartView = findView(R.id.chart);
        initLineChart();
    }
 
    @Override
    protected void initListener() {
 
    }
 
    @Override
    protected void initData() {
        getData(8,true);
        showChangeLineChart();
    }
 
    @Override
    protected void processClick(View view) {
        switch (view.getId()) {
            case R.id.tv_left:
                finish();
                break;
        }
 
    }
 
    @Override
    protected void onErrorPageClick() {
 
    }
 
    private void initLineChart() {
        line = new Line(mPointValues).setColor(Color.parseColor("#ffffff"));  //折线的颜色
        List<Line> lines = new ArrayList<>();
        line.setShape(ValueShape.CIRCLE);//折线图上每个数据点的形状  这里是圆形 (有三种 :ValueShape.SQUARE  ValueShape.CIRCLE  ValueShape.DIAMOND)
        line.setPointColor(Color.parseColor("#ffffff"));
        line.setCubic(false);//曲线是否平滑,即是曲线还是折线
        line.setFilled(false);//是否填充曲线的面积
        line.setHasLabels(true);//曲线的数据坐标是否加上备注
//      line.setHasLabelsOnlyForSelected(true);//点击数据坐标提示数据(设置了这个line.setHasLabels(true);就无效)
        line.setHasLines(true);//是否用线显示。如果为false 则没有曲线只有点显示
        line.setHasPoints(true);//是否显示圆点 如果为false 则没有原点只有点显示(每个数据点都是个大的圆点)
        LineChartValueFormatter chartValueFormatter = new SimpleLineChartValueFormatter(1);
        line.setFormatter(chartValueFormatter);//显示小数点
        lines.add(line);
        data = new LineChartData();
        data.setLines(lines);
        data.setValueLabelBackgroundColor(Color.TRANSPARENT);//此处设置坐标点旁边的文字背景
        data.setValueLabelBackgroundEnabled(false);
        data.setValueLabelsTextColor(Color.WHITE);
        data.setValueLabelTextSize(8);
 
        //坐标轴
        axisX = new Axis(); //X轴
        axisX.setHasTiltedLabels(false);  //X坐标轴字体是斜的显示还是直的,true是斜的显示
        axisX.setName("实时数据");  //表格名称
        axisX.setTextSize(8);//设置字体大小
        axisX.setTextColor(getResources().getColor(R.color.blue_txt));
//        axisX.setMaxLabelChars(7); //最多几个X轴坐标,意思就是你的缩放让X轴上数据的个数7<=x<=mAxisXValues.length
        axisX.setValues(mAxisXValues);  //填充X轴的坐标名称
        axisX.setHasLines(true); //x 轴分割线
        axisX.setLineColor(getResources().getColor(R.color.blue_txt));
        axisX.setHasSeparationLine(true);
        data.setAxisXBottom(axisX); //x 轴在底部
        //data.setAxisXTop(axisX);  //x 轴在顶部
 
        // Y轴是根据数据的大小自动设置Y轴上限(在下面我会给出固定Y轴数据个数的解决方案)
        axisY = Axis.generateAxisFromRange((float) 0.0, maxValue == 0 ? 100 : maxValue, maxValue == 0 ? 10 : maxValue / 16);  //Y轴
//        axisY = new Axis();
        axisY.setAutoGenerated(false);
//        AxisValueFormatter yvalue = new SimpleAxisValueFormatter(1);
//        axisY.setFormatter(yvalue);
        axisY.setHasLines(true);
        axisY.setHasSeparationLine(true);
        axisY.setName("            ");//y轴标注
        axisY.setTextSize(8);//设置字体大小
        axisY.setTextColor(getResources().getColor(R.color.blue_txt));
        axisY.setLineColor(getResources().getColor(R.color.blue_txt));
        data.setAxisYLeft(axisY);  //Y轴设置在左边
 
        //设置行为属性,支持缩放、滑动以及平移
        chartView.setInteractive(true);
        chartView.setZoomType(ZoomType.HORIZONTAL);
        chartView.setMaxZoom((float) 2);//最大方法比例
        chartView.setContainerScrollEnabled(true, ContainerScrollType.HORIZONTAL);
        chartView.setLineChartData(data);
        chartView.setVisibility(View.VISIBLE);
        /**注:下面的7,10只是代表一个数字去类比而已
         * 当时是为了解决X轴固定数据个数。见(http://forum.xda-developers.com/tools/programming/library-hellocharts-charting-library-t2904456/page2);
         */
        final Viewport v = new Viewport(chartView.getMaximumViewport());
        v.bottom = (float) 0.0;
        v.top = maxValue;
        chartView.setMaximumViewport(v);
        chartView.setCurrentViewport(v);
    }
 
    private int index = 0;
 
    private void reshowChart(final SensorData sensorData) {
        chartView.post(new Runnable() {
            @Override
            public void run() {
                mPointValues.add(new PointValue(index, sensorData.getValue()));
                mAxisXValues.add(new AxisValue(index).setLabel(index + ""));
                if(mPointValues.size()>8){
                    mPointValues.remove(0);
                }
                if(mAxisXValues.size()>8){
                    mAxisXValues.remove(0);
                }
                axisX.setValues(mAxisXValues);
                data.setAxisXBottom(axisX);
                line.setValues(mPointValues);
                List<Line> lines = new ArrayList<Line>();
                lines.add(line);
                data.setLines(lines);
                chartView.setLineChartData(data);
                index++;
                final Viewport v = new Viewport(chartView.getMaximumViewport());
                v.bottom = (float) 0.0;
                v.top = maxValue;
                chartView.setMaximumViewport(v);
                chartView.setCurrentViewport(v);
            }
        });
    }
 
    private ArrayList<SensorData> dataList = new ArrayList<>();
 
    private void getData(int size,boolean show) {
        HashMap<String, String> params = new HashMap<>();
        params.put("sensorKey", sensorKey);
        params.put("mac", mac);
        params.put("size", size + "");
        mHttpUtils.doGet(API.SENSOR, params, CacheMode.DEFAULT, show, new HttpCallBack() {
            @Override
            public void onSuccess(String res, String msg) {
                if (progressDialog.isShowing()) {
                    progressDialog.dismiss();
                }
                ArrayList<SensorData> temp = (ArrayList<SensorData>) FastJsonTools.getArrayJson(res, SensorData.class);
                if (temp != null) {
                    dataList.clear();
                    dataList.addAll(temp);
                }
                for (SensorData data:dataList){
                    reshowChart(data);
                }
            }
 
            @Override
            public void showLoadingDialog() {
                progressDialog.show();
            }
 
            @Override
            public void onFail(int errno, String s) {
                if (progressDialog.isShowing()) {
                    progressDialog.dismiss();
                }
            }
        });
    }
 
    @Override
    protected void onDestroy() {
        super.onDestroy();
        if(timer!=null){
            timer.cancel();
            timer =null;
        }
    }
}