Comments (3)
Can you paste part of code responsible for chart's data generation?
from hellocharts-android.
private LineChartData buildLineChartData(AQIHourDatas aqiHourDatas) {
if (aqiHourDatas == null) return null;
List<PointValue> values = new ArrayList<>();
List<AQIHourData> hourDatas = aqiHourDatas.getData();
int size = hourDatas.size();
for (int i = 0; i < size; ++i) {
//if (i > 12) values.add(new PointValue(i, hourDatas.get(i).getAqi()));
//TODO Sometimes pointvalue will be the same..example..
if (i > 12) values.add(new PointValue(i, 8));
}
Line line = new Line(values);
line.setStrokeWidth(2);
line.setFilled(false);
line.setShape(ValueShape.CIRCLE);
line.setColor(ColorUtil.EXCELLENT);
line.setHasLabels(true);
line.setPointRadius(4);
List<Line> lines = new ArrayList<>();
lines.add(line);
LineChartData lineChartData = new LineChartData(lines);
List<AxisValue> axisValueX = new ArrayList<>();
Calendar calendar = Calendar.getInstance();
SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
for (int i = 0; i < size; ++i) {
if (i > 12) {
String dateTime = hourDatas.get(i).getDateTime();
try {
Date date = simpleDateFormat.parse(dateTime);
calendar.setTime(date);
dateTime = calendar.get(Calendar.HOUR_OF_DAY) + ":00";
} catch (ParseException e) {
Timber.e(e.toString());
dateTime = "";
}
axisValueX.add(new AxisValue(i, dateTime.toCharArray()));
}
}
Axis axisX = new Axis().setValues(axisValueX).setHasLines(true);
Axis axisY = new Axis().setHasLines(true);
lineChartData.setAxisXBottom(axisX);
lineChartData.setAxisYLeft(axisY);
lineChartData.setValueLabelTextSize(8);
lineChartData.setValueLabelsTextColor(ColorUtil.EXCELLENT);
return lineChartData;
}
If I have to set the Viewport?
from hellocharts-android.
Oh, I think now I understand. When all chart's entries have the same value there is no difference between min and max value so viewport's height is equal 0. So yes, you need to modify viewport.
//set chart data to initialize viewport, otherwise it will be[0,0;0,0]
//get initialized viewport and change if ranges according to your needs.
final Viewport v = new Viewport(chart.getMaximumViewport());
v.top =100;
v.bottom = 0;
chart.setMaximumViewport(v);
chart.setCurrentViewport(v);
//Optional step: disable viewport recalculations, thanks to this animations will not change viewport automatically.
//chart.setViewportCalculationEnabled(false);
Check out LineChartActivity in samples, specifically method LineChartActivity.resetViewport() for more code.
from hellocharts-android.
Related Issues (20)
- y axis value only shows three digits. i.e, 0,300,600,900,200,500,800,100 etc. I need to show it as 0,300,600,900,1200,1500,1800,2100 HOT 1
- groovy.lang.MissingPropertyException: Could not set unknown property 'name' for object of type org.gradle.api.publish.maven.internal.publication.DefaultMavenPom.
- How to change Background Color Label?
- setCurrentViewport different result on Run and ApplyChanges
- Hellocharts android library not rendering chart when there is a single value or when y axis values are same HOT 2
- "setHasGradientToTransparent" Are Missing on LineChart with Kotlin HOT 3
- How to set axis number to Text in column chart? HOT 1
- Cannot use line.setHasGradientToTransparent() method
- Is it possible to obtain values from the generated graph?
- Importing it as Module
- linechart with multicolor data line
- Compatibility with AndroidX HOT 1
- Horizontal spacing between points
- 关于一个点问题(已解决)
- About the problem that the y-axis is not displayed.
- Unsupported Modules Detected
- HelloCharts
- library configuration
- LineChartView can not make steps of 0.5f
- 垂直折线图
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from hellocharts-android.