- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试获得与图片中相同的图表:
好吧,我有一个负数列表 {-50,-70,-40...},我想要相同的图表,但如果我正常工作,我会得到这张向上的图表:
我试着用标签代替 y 轴数字,但我没有给我想要的图表。请有人告诉我如何制作这张图表,我花了 4 天时间试图在第一张图片中得到结果。或者给我一个想法,我已经失去了 4 天的搜索和尝试:(。这是我正在使用的代码:
public class TruitonAChartEngineActivity extends ActionBarActivity {
private static int SERIES_NR ; //the number of columns to display,
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_truiton_achart_engine);
XYMultipleSeriesRenderer renderer = getTruitonBarRenderer();
myChartSettings(renderer);
Intent intent = ChartFactory.getBarChartIntent(this, getTruitonBarDataset(), renderer, Type.DEFAULT);
startActivity(intent);
}
private XYMultipleSeriesDataset getTruitonBarDataset() {
XYMultipleSeriesDataset dataset = new XYMultipleSeriesDataset();
final int nr = 15;
int [] classObject =new int[] {70,-56,-40,-80};
Random r = new Random();
ArrayList<String> legendTitles = new ArrayList<String>();
legendTitles.add("Sales");
legendTitles.add("Expenses");
SERIES_NR = 2 ;
for (int i = 0; i < SERIES_NR; i++) {
CategorySeries series = new CategorySeries(legendTitles.get(i));
for (int k = 0; k < nr; k++) {
if (k==2)
series.add(classObject[k]);
if (k==1)
series.add(classObject[k]);
if (k==0)
series.add(classObject[k]);
if (k==3)
series.add(classObject[k]);
}
dataset.addSeries(series.toXYSeries());
}
return dataset;
}
public XYMultipleSeriesRenderer getTruitonBarRenderer() {
XYMultipleSeriesRenderer renderer = new XYMultipleSeriesRenderer();
renderer.setAxisTitleTextSize(10);
renderer.setChartTitleTextSize(20);
renderer.setLabelsTextSize(10);
renderer.setLegendTextSize(10);
renderer.setMargins(new int[] { 30, 40, 15, 0 });
int randomColor = Color.rgb((int)(Math.random() * 255), (int)(Math.random() * 255), (int)Math.random() * 255);
SimpleSeriesRenderer r = new SimpleSeriesRenderer();
r.setColor(Color.rgb((int)(Math.random() * 255), (int)(Math.random() * 255), (int)Math.random() * 255));
renderer.addSeriesRenderer(r);
r = new SimpleSeriesRenderer();
r.setColor(Color.rgb((int)(Math.random() * 255), (int)(Math.random() * 255), (int)Math.random() * 255));
renderer.addSeriesRenderer(r);
return renderer;
}
@SuppressWarnings("deprecation")
private void myChartSettings(XYMultipleSeriesRenderer renderer) {
renderer.setChartTitle("Wifi Channels");
renderer.setXAxisMin(0.5);
renderer.setXAxisMax(14.5);
renderer.setYAxisMin(-90);
renderer.setYAxisMax(-30);
renderer.addXTextLabel(1, "1");
renderer.addXTextLabel(2, "2");
renderer.addXTextLabel(3, "3");
renderer.addXTextLabel(4, "4");
renderer.addXTextLabel(5, "5");
renderer.addXTextLabel(6, "6");
renderer.addXTextLabel(7, "7");
renderer.addXTextLabel(8, "8");
renderer.addXTextLabel(9, "9");
renderer.addXTextLabel(10, "10");
renderer.addXTextLabel(11, "11");
renderer.addXTextLabel(12, "12");
renderer.addXTextLabel(13, "13");
renderer.addXTextLabel(14, "14");
/*renderer.addYTextLabel(0, "");
renderer.addYTextLabel(10, "-90");
renderer.addYTextLabel(20, "-80");
renderer.addYTextLabel(30, "-70");
renderer.addYTextLabel(40, "-60");
renderer.addYTextLabel(50, "-50");
renderer.addYTextLabel(60, "-40");
renderer.addYTextLabel(70, "-30");
renderer.addYTextLabel(80, "");*/
renderer.setPanEnabled(true, true);
renderer.setZoomEnabled(false, false);
renderer.setApplyBackgroundColor(true);
renderer.setBackgroundColor(Color.BLACK);
renderer.setYLabelsAlign(Align.RIGHT);
renderer.setBarSpacing(0.5);
renderer.setXTitle("Canal du WiFi");
renderer.setYTitle("Puissance du signal[dbm]");
renderer.setShowGrid(true);
renderer.setGridColor(Color.GRAY);
renderer.setXLabels(0); // sets the number of integer labels to appear
renderer.setXLabels((int) 0.5);//25
renderer.setYLabels(10);
}`enter code here`
谢谢。
PS:我正在使用 achartengine。
最佳答案
好吧,我找到了一个解决方案,我确定它不是最好的,但总比什么都没有好:
Y 轴将从 30 到 90
(实数)开始,我将设置标签而不是像这样的实数:
-90 correspond to 30
-80 correspond to 40 ...
PS:我确定我的 Y 坐标会在 -90 到 -30 之间变化
:
这是代码:
public class TruitonAChartEngineActivity extends ActionBarActivity {
private static int SERIES_NR ; //the number of columns to display,
List<int[]> values = new ArrayList<int[]>();
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_truiton_achart_engine);
XYMultipleSeriesRenderer renderer = getTruitonBarRenderer();
myChartSettings(renderer);
Intent intent = ChartFactory.getBarChartIntent(this, getTruitonBarDataset(), renderer, Type.DEFAULT);
startActivity(intent);
}
private XYMultipleSeriesDataset getTruitonBarDataset() {
XYMultipleSeriesDataset dataset = new XYMultipleSeriesDataset();
int [] classObject =new int[] {-70,-56,-45,-80,-47,-55,-80 , 70, 20, 75,
95, 35,45,10};//Signal strength receiver from each access point
for (int j=0;j<classObject.length;j++){
values.add(new int[] { classObject[j]}); //every serie will concern an access point and contain one RSSI
}
final int nr = classObject.length;
ArrayList<String> legendTitles = new ArrayList<String>();
for (int k = 0; k < classObject.length; k++) {
legendTitles.add("Sales"+k);//every serie will have a legend
}
SERIES_NR = classObject.length ;//number of access point
for (int i = 0; i < SERIES_NR; i++) {
CategorySeries series = new CategorySeries(legendTitles.get(i));
int[] v = values.get(i);
int seriesLength = v.length;
for (int k = 0; k < seriesLength; k++) {
switch (v[k] / 10){
case -8 :
//series.add(classObject[k]);
if (v[k] %10 == 0)
series.add(40);
else
series.add(40 - v[k] %10);
break;
case -7 :
//series.add(classObject[k]);
if (v[k] %10 == 0)
series.add(50);
else
series.add(50 - v[k] %10);
break;
case -6 :
//series.add(classObject[k]);
if (v[k] %10 == 0)
series.add(60);
else
series.add(60 - v[k] %10);
break;
case -5 :
//series.add(classObject[k]);
if (v[k] %10 == 0)
series.add(70);
else
series.add(70 - v[k] %10);
break;
case -4 :
//series.add(classObject[k]);
if (v[k] %10 == 0)
series.add(80);
else
series.add(80 - v[k] %10);
break;
case -3 :
//series.add(classObject[k]);
if (v[k] %10 == 0)
series.add(90);
else
series.add(90 - v[k] %10);
break;
}
}
dataset.addSeries(series.toXYSeries());
}
return dataset;
}
public XYMultipleSeriesRenderer getTruitonBarRenderer() {
XYMultipleSeriesRenderer renderer = new XYMultipleSeriesRenderer();
renderer.setAxisTitleTextSize(10);
renderer.setChartTitleTextSize(20);
renderer.setLabelsTextSize(10);
renderer.setLegendTextSize(10);
renderer.setMargins(new int[] { 30, 40, 15, 0 });
int randomColor = Color.rgb((int)(Math.random() * 255), (int)(Math.random() * 255), (int)Math.random() * 255);
for (int k = 0; k < 14; k++)
{
SimpleSeriesRenderer r = new SimpleSeriesRenderer();
r.setColor(Color.rgb((int)(Math.random() * 255), (int)(Math.random() * 255), (int)Math.random() * 255));
renderer.addSeriesRenderer(r);
}
/* SimpleSeriesRenderer r = new SimpleSeriesRenderer();
r.setColor(Color.rgb((int)(Math.random() * 255), (int)(Math.random() * 255), (int)Math.random() * 255));
renderer.addSeriesRenderer(r);
r = new SimpleSeriesRenderer();
r.setColor(Color.rgb((int)(Math.random() * 255), (int)(Math.random() * 255), (int)Math.random() * 255));
renderer.addSeriesRenderer(r);*/
return renderer;
}
@SuppressWarnings("deprecation")
private void myChartSettings(XYMultipleSeriesRenderer renderer) {
renderer.setChartTitle("Wifi Channels");
renderer.setXAxisMin(0.5);
renderer.setXAxisMax(14.5);
renderer.setYAxisMin(30);
renderer.setYAxisMax(90);
renderer.addXTextLabel(1, "1");
renderer.addXTextLabel(2, "2");
renderer.addXTextLabel(3, "3");
renderer.addXTextLabel(4, "4");
renderer.addXTextLabel(5, "5");
renderer.addXTextLabel(6, "6");
renderer.addXTextLabel(7, "7");
renderer.addXTextLabel(8, "8");
renderer.addXTextLabel(9, "9");
renderer.addXTextLabel(10, "10");
renderer.addXTextLabel(11, "11");
renderer.addXTextLabel(12, "12");
renderer.addXTextLabel(13, "13");
renderer.addXTextLabel(14, "14");
renderer.addYTextLabel(0, "");
renderer.addYTextLabel(30, "-90");
renderer.addYTextLabel(40, "-80");
renderer.addYTextLabel(50, "-70");
renderer.addYTextLabel(60, "-60");
renderer.addYTextLabel(70, "-50");
renderer.addYTextLabel(80, "-40");
renderer.addYTextLabel(90, "-30");
renderer.addYTextLabel(100, "");
renderer.setPanEnabled(true, true);
renderer.setZoomEnabled(false, false);
renderer.setApplyBackgroundColor(true);
renderer.setBackgroundColor(Color.BLACK);
renderer.setYLabelsAlign(Align.RIGHT);
renderer.setBarSpacing(0.5);
renderer.setXTitle("Canal du WiFi");
renderer.setYTitle("Puissance du signal[dbm]");
renderer.setShowGrid(true);
renderer.setGridColor(Color.GRAY);
renderer.setXLabels(0); // sets the number of integer labels to appear
renderer.setXLabels((int) 0.5);//25
renderer.setYLabels(10);
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.truiton_achart_engine, menu);
return true;
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
// Handle action bar item clicks here. The action bar will
// automatically handle clicks on the Home/Up button, so long
// as you specify a parent activity in AndroidManifest.xml.
int id = item.getItemId();
if (id == R.id.action_settings) {
return true;
}
return super.onOptionsItemSelected(item);
}
}
关于安卓 :Wifi analyzer bar chart,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22981828/
我想将 EditText 始终设置为 LTR,我该怎么做?android:textDirection 似乎确实是答案,我无法让项目使用该指令进行编译 最佳答案 为 editText 使用引力 andr
我希望我的应用在每次打开时都显示登录屏幕。使用 android:clearTaskOnLaunch="true" 一切正常。但是有一个错误,只有在手机关机并且应用程序首先使用小部件启动时才会发生。 I
实际上我的要求是我想将动态文件加载到像图像一样的网页中。视频,音频等,它来自 Assets 或应用程序自己的文件目录,这不是问题。 我尝试使用以下两种方式。 方式一 这是我的 html 文件在 ass
我正在触发一个 DatePickerDialog,在 api 22 (Android 5.1) 之前它一直在工作并显示良好,我在上面设置混合和最大日期(最小 = 当前日期,最大 = 从当前日期开始的
我有一个 ListView ,我在其中将标题 View 添加到该列表。一切都很好,但是当滚动列表 headerview 也随着列表移动时,所以我想避免 headerview 滚动,我的意思是当我列表到
虽然我在android上做过一些app,但我还是一头雾水。是否可以使用 SDK 4.0 中的功能,并在 android 2.1 或更低版本上运行该应用程序? 我尝试了你们提到的方法,但出现错误 - F
您好,我正在开发小型 android 应用程序,我想在其中显示带有一些元素的简单 gridview。它工作正常。唯一的问题是即使有空间,它也总是只显示两列。它平均将屏幕分成 2 列并仅显示两个元素。如
我正在使用 Android 2.3.3 API 构建一个应用程序。我需要识别方向的变化并执行一些操作。所以我在 Android Manifest 中添加了以下内容, android:configCha
我正在尝试在“点击”包含特定 MIME 类型的 nfc 标签时开始一项 Activity 。我制作了一个 mime 类型为“text/plain”的标签,并将其添加到 list 中:
我可以将一些数据保存到文件中 val byteArrayOutputStream = ByteArrayOutputStream() byteArrayOutputStream.wri
我正在尝试解析一个包含复杂阿拉伯字母的 XML 文件.. 当我在 android 2.3.7 上测试时,并不是所有的阿拉伯字母都被支持,仍然有一些复杂的显示为方 block .. 但是在 androi
我需要编写一个方法来确定设备是平板电脑还是手机。我不需要根据这个显示不同的用户界面。我只需要有关设备的信息,以便将来我可以将其发送到指标。 在互联网上,我找到了很多方法来确定设备是否是平板电脑。我已经
我正在玩文字转语音,让我的测试应用程序更有趣。它适用于模拟器,但不适用于我的手机,因为我的默认语言环境不是英语。 但是,文本是英文的,所以 tts 当然应该使用英文。据我所知,我可以实现一个自动安装,
我正在使用 MVVM 和整洁的架构编写应用程序。在其中一个屏幕上,我需要使用 pagination 实现 RecyclerView。我将使用库 Paging3。 Android 开发者推荐在存储库层使
这个问题在这里已经有了答案: I lost my .keystore file? (12 个回答) 4年前关闭。 当我以前的操作系统损坏并安装新的(7 月 3 日)时,以前的 android_key_
我正在使用 MVVM 和整洁的架构编写应用程序。在其中一个屏幕上,我需要使用 pagination 实现 RecyclerView。我将使用库 Paging3。 Android 开发者推荐在存储库层使
在我的 v27\style.xml 中,我有以下代码来设置白色导航栏: @color/colorPrimary @color/colorPrimaryDark @color/
我想通过发送电子邮件 startActivity(Intent.createChooser(new Intent(android.content.Intent.ACTION_SEND))) 我知道要将
我实现了一个自定义 ListView ,它看起来像 Twitter 时间线。 adapter = new MyClickableListAdapter(this, R.layout.timeline,
我有一个显示启动画面的自定义对话框; mSplashDialog = new Dialog(MyActivity.this,R.layout.splash); mSplashDialog.setCon
我是一名优秀的程序员,十分优秀!