我尝试通过将 min 和 max 值设置为 X 和来在我的图表中添加一些填充Y 轴。
我的XYMultipleSeriesRenderer代码如下:
// custom render
XYMultipleSeriesRenderer renderer = new XYMultipleSeriesRenderer();
// background
renderer.setBackgroundColor(Color.parseColor("#ffffff"));
renderer.setMarginsColor(Color.parseColor("#ffffff"));
renderer.setPointSize(pointStrokeWidth);
renderer.setPanEnabled(true, true);
//renderer.setPanEnabled(false);
renderer.setShowLegend(false);
// renderer.setZoomEnabled(false);
renderer.setInScroll(true);
renderer.setClickEnabled(true);
renderer.setXLabels(0);
// setscale
// renderer.setScale((float) 1.5);
//renderer.setShowAxes(true);
// label padding and size
renderer.setShowCustomTextGrid(true);
renderer.setLabelsTextSize(20);
renderer.setXAxisMin(-0.2f);
double maxX = dashboard.getDaysDashboard().size()-0.9F;
renderer.setXAxisMax(maxX);
renderer.setYAxisMin(-0.3f);
double maxY = dashboard.maxNumberOfContent()-5.0F;
Log.d(TAG, "max y: "+maxY);
renderer.setYAxisMax(maxY);
// y
renderer.setYLabelsPadding(20);
renderer.setYLabelsAlign(Align.LEFT);
// x
renderer.setXLabelsPadding(20);
renderer.setXLabelsAlign(Align.CENTER);
// margins - an array containing the margin size values, in this order:
// top, left, bottom, right
int[] margins = {10, 30, 0, 10 };
renderer.setMargins(margins);
如果我设置了不同的maxX值,我可以看到我的图表发生了变化。如果我更改maxY值,图表不会改变!我尝试在行的最大Y值处设置+/- 1,或者添加+/- 100,我尝试使用int或double但没有!为什么不通过更改Y轴值来更改图形填充?
答案 0 :(得分:2)
你可以试试这个:
mRenderer.setMargins(new int[] {0, 50, 0, 0});
第二个参数代表图的上边距。
或
mRenderer.setXLabelsPadding(10);
mRenderer.setYLabelsPadding(10);
答案 1 :(得分:1)
**parameter for setmargin**
// renderer.setMargins(new int[] {margin top, margin left, margin bottom, margin right}
ex:
renderer.setMargins(new int[] {90, 60, 20, 30});
答案 2 :(得分:1)
我用这段代码解决了:
// * ASSIX Y *
renderer.setYLabels(0);
renderer.setYLabelsPadding(35);
renderer.setYLabelsAlign(Align.RIGHT);
// Y max
renderer.setYAxisMax(dashboard.maxNumberOfContent());
// set ASSY numbers label
int unit = dashboard.maxNumberOfContent() / 5;
for (int i = 0; i <= 5; i++) {
String yLabel = "" + unit * i;
renderer.addYTextLabel((unit*i), yLabel);
}
renderer.addYTextLabel(dashboard.maxNumberOfContent(), dashboard.maxNumberOfContent()+"");
renderer.setYAxisMax(dashboard.maxNumberOfContent()+(unit/2));
// * ASSIX X *
renderer.setXLabels(0);
renderer.setXLabelsPadding(0);
renderer.setXLabelsAlign(Align.CENTER);
// X max
double maxX = dashboard.getDaysDashboard().size() - 0.9F;
renderer.setXAxisMax(maxX);
// X days label
ArrayList<String> dayNames = getWeekDaysDashboard();
for (int i = 0; i < days.size(); i++) {
renderer.addXTextLabel(days.get(i), dayNames.get(i));
}
// CUSTOM STYLE LINE CHART
// * background
renderer.setBackgroundColor(Color.parseColor("#ffffff"));
renderer.setMarginsColor(Color.parseColor("#ffffff"));
renderer.setPointSize(pointStrokeWidth);
renderer.setInScroll(true);
renderer.setClickEnabled(true);
renderer.setZoomEnabled(false, false);
renderer.setPanEnabled(false, false);
renderer.setShowLegend(false);
renderer.setShowAxes(true);
// label padding and size
renderer.setShowCustomTextGrid(true);
renderer.setLabelsTextSize(40.0f);
renderer.setXAxisMin(-0.2f);
int yMin = -(unit/5);
Log.d(TAG, "ymin: "+yMin+" // unit: "+unit);
if (yMin < 1) {
yMin = -1;
}
renderer.setYAxisMin(yMin);
// *** margins: top, left, bottom, right
int[] margins = { 10, 60, 10, 30 };
renderer.setMargins(margins);
(这就是诀窍:renderer.setYAxisMax(dashboard.maxNumberOfContent()+(unit/2));
)