关于self.view以及applicationFrame之类屏幕高度的一点总结

今天搭一个小项目框架的时候遇到了一个bug,屏幕下面的tabBar只显示了一小条,打印了一下位置发现不对,我就找原因,


因为项目中很多地方用到self.view.frame.size.height,我就偷懒了,直接在公共文件里面定义了如下的一个变量

#define SCREENH  [UIScreen mainScreen].bounds.size.height

开始我一直觉得这是没有什么问题的,整个过程也很愉悦,直到后来我用6.1的系统运行的一下,bug就来了,发现下移了20的高度,我直接设置tabBar其实y:SCREENH-tabBar高度

后来经过对比研究才发现,6.1系统中每个ViewController在给view初始化的时候都是applicationFrame的值,

有状态栏20 :self.view的高度是460

无状态栏20 :self.view的高度是480

[UIScreen mainScreen].applicationFrame的取值

3.5inch为例(320x480

1>没有状态栏,applicationFrame的值{{0,0}, {320480}}

2>有状态栏,applicationFrame的值{{0,20}, {320,460}}

注意:[UIScreen mainScreen].bounds.size.height一直等于480;


又继续研究了一下7.1及以后的系统中,结果如下:

不管你是否显示状态栏,self.view的高度都是从屏幕最左边开始算的。也就是view.height=568.000000

不管你是否显示状态栏

注意:[UIScreen mainScreen].bounds.size.height一直等于568;


这也就很好地解释了为什么我在7.1以上的系统运行没有任何问题,但是6.1里面显示就有问题了


当我们在没有状态栏切换到有状态栏的视图是要注意先设置状态栏显示,然后再推出视图

为什么这么做呢,因为之前说了,6.1里面view是根据applicationFrame的高度来定的,如果先初始化控制器然后设置状态栏,就会存在下面的情况,状态栏把最上面遮住了:


虽然6.1之后的系统不会出现这种问题,但是我们也应该注意这两者之间的先后顺序

要使用ApplicationFrame实现jfreechart动态折线图,需要遵循以下步骤: 1. 导入jfreechart库。 2. 创建一个ApplicationFrame实例,它将包含动态折线图。 3. 创建一个TimeSeries对象,它将存储图表中的数据。 4. 创建一个TimeSeriesCollection对象,它将包含所有TimeSeries对象。 5. 创建一个ChartPanel对象,它将显示动态折线图。 6. 创建一个JFreeChart对象,它将与ChartPanel关联。 7. 设置折线图的样式和属性。 8. 创建一个Timer对象,它将定期更新折线图。 9. 在Timer对象的ActionListener方法中,添加新数据到TimeSeries对象中,并刷新折线图。 下面是一个简单的示例代码,演示如何使用ApplicationFrame实现jfreechart动态折线图: ```java import java.awt.BorderLayout; import java.awt.Dimension; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import java.text.SimpleDateFormat; import java.util.Date; import javax.swing.JFrame; import javax.swing.JPanel; import javax.swing.Timer; import org.jfree.chart.ChartFactory; import org.jfree.chart.ChartPanel; import org.jfree.chart.JFreeChart; import org.jfree.data.time.Millisecond; import org.jfree.data.time.TimeSeries; import org.jfree.data.time.TimeSeriesCollection; import org.jfree.data.xy.XYDataset; public class DynamicLineChart extends JFrame implements ActionListener { private static final long serialVersionUID = 1L; private TimeSeries series; private Timer timer; public DynamicLineChart(final String title) { super(title); this.series = new TimeSeries("Random Data"); final TimeSeriesCollection dataset = new TimeSeriesCollection(this.series); final JFreeChart chart = createChart(dataset); final ChartPanel chartPanel = new ChartPanel(chart); chartPanel.setPreferredSize(new Dimension(500, 270)); final JPanel content = new JPanel(new BorderLayout()); content.add(chartPanel); setContentPane(content); this.timer = new Timer(1000, this); this.timer.start(); } private JFreeChart createChart(final XYDataset dataset) { final JFreeChart result = ChartFactory.createTimeSeriesChart( "Dynamic Line Chart", "Time", "Value", dataset, true, true, false ); return result; } public void actionPerformed(final ActionEvent e) { final double factor = Math.random() * 0.1 + 0.95; final Millisecond now = new Millisecond(); this.series.add(new Millisecond(), Math.random() * factor); } public static void main(final String[] args) { final DynamicLineChart demo = new DynamicLineChart("Dynamic Line Chart"); demo.pack(); demo.setVisible(true); } } ``` 在这个示例中,我们创建了一个名为DynamicLineChart的类,它继承自JFrame,并实现了ActionListener接口,用于更新折线图。在构造函数中,我们创建了一个TimeSeries对象,将其添加到TimeSeriesCollection中,并将其与ChartPanel关联。我们还创建了一个定时器,每秒钟更新一次折线图。在ActionListener方法中,我们向TimeSeries对象中添加新数据,并使用ChartPanel对象的repaint()方法刷新折线图。最后,我们创建了一个DynamicLineChart对象,并调用它的pack()和setVisible()方法显示动态折线图。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值