Я использую диаграмму движения Google Visualization для отображения различных отчетов.В одном отчете показаны исполняемые строки кода и предупреждения в каждом файле.Вот как выглядит график.Ось X представляет eloc, а ось Y представляет предупреждения в каждом файле.Когда график загружен, как вы можете видеть, все файлы представлены синими шарами, кроме одного файла, он отображается с красным шаром.что это значит?это ошибка?Я пытался искать в Интернете, чтобы найти объяснения, но не повезло.
Ниже мой код:
public class DashboardWidget
{
private HorizontalPanel containerPanel=null;
private DataTable data=null;
public DashboardWidget()
{
containerPanel = new HorizontalPanel();
}
public HorizontalPanel getContainerPanel()
{
SQLRunnerAsync service = (SQLRunnerAsync) GWT.create(SQLRunner.class);
AsyncCallback<ArrayList<String[]>> callback = new AsyncCallback<ArrayList<String[]>>()
{
@Override
public void onFailure(Throwable caught)
{
}
@Override
public void onSuccess(final ArrayList<String[]> result)
{
Runnable onLoadCallback = new Runnable()
{
public void run()
{
data = DataTable.create();
data.addColumn(ColumnType.STRING, "Name");
data.addColumn(ColumnType.DATE, "Date");
data.addColumn(ColumnType.NUMBER, "Option1");
data.addColumn(ColumnType.NUMBER, "Option2");
data.addColumn(ColumnType.NUMBER, "Option3");
data.addRows(result.size());
Date date = new Date();
DateTimeFormat fmt = DateTimeFormat.getFormat("MM/dd/yyyy");
Date d1 = fmt.parse(fmt.format(date));
int i;
for(i=0;i<result.size();i++)
{
String[] temp = result.get(i);
String Name=temp[0];//name
String Option1 = temp[1];
String Option2=temp[2];
String Option3=temp[3];
data.setValue(i, 0, Name);//NAME
data.setValue(i, 1, d1);//date
data.setValue(i, 2, Integer.parseInt(Option1));
data.setValue(i, 3, Integer.parseInt(Option2));
data.setValue(i, 4, Integer.parseInt(Option13));
}
Options options = Options.create();
options.setWidth(1000);
options.setHeight(1000);
MotionChart chart = new MotionChart(data, options);
containerPanel.add(chart);
}
};
VisualizationUtils.loadVisualizationApi(onLoadCallback, MotionChart.PACKAGE);
}
};
service.getData("","","","", callback);
return containerPanel;
}
}