我们要实现的效果如下:
我们使用系统自带的,实际上,代码量很少,在我们要显示的按钮上,打上下面一句代码即可:
self.tabbaritem.badgevalue = @"1";
同时设置图标和按钮的代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
/**
* 获得未读数
*/
- ( void )setupunreadcount
{
//获取未读数具体方法
//最终返回一个数字,如:
int count=10;
// 设置提醒数字(微博的未读数)
nsstring *status = [nsstring stringwithformat:@ "%d" , count];
if ([status isequaltostring:@ "0" ]) { // 如果是0,得清空数字
self.tabbaritem.badgevalue = nil;<br> //应用图标显示
[uiapplication sharedapplication].applicationiconbadgenumber = 0;
} else { // 非0情况
self.tabbaritem.badgevalue = status;
[uiapplication sharedapplication].applicationiconbadgenumber = status.intvalue;
}
}
|
当然,设置的显示的这个数字,是应该会定时的变的。如何使这个方法定时的调用呢?
1
2
3
4
5
6
7
8
9
|
- ( void )viewdidload
{
[super viewdidload];
// 获得未读数
nstimer *timer = [nstimer scheduledtimerwithtimeinterval:60 target:self selector:@selector(setupunreadcount) userinfo:nil repeats:yes];
// 主线程也会抽时间处理一下timer(不管主线程是否正在其他事件)
[[nsrunloop mainrunloop] addtimer:timer formode:nsrunloopcommonmodes];
}
|
做完上面的操作后,我们是可以看到效果了。但还存在一个问题就是,我们的应用进入后台后,定时器不再工作,变成了一个暂时状态。那为什么一个音乐的应用可以一直在后台运行呢?实际上,在appdelegate里面已经有后台运行的方法,我们在这个方法里做一些操作即可。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
|
/**
* 当app进入后台时调用
*/
- ( void )applicationdidenterbackground:(uiapplication *)application
{
/**
* app的状态
* 1.死亡状态:没有打开app
* 2.前台运行状态
* 3.后台暂停状态:停止一切动画、定时器、多媒体、联网操作,很难再作其他操作
* 4.后台运行状态
*/
// 向操作系统申请后台运行的资格,能维持多久,是不确定的
uibackgroundtaskidentifier task = [application beginbackgroundtaskwithexpirationhandler:^{
// 当申请的后台运行时间已经结束(过期),就会调用这个block
// 赶紧结束任务
[application endbackgroundtask:task];
}];
// 在info.plst中设置后台模式:required background modes == app plays audio or streams audio/video using airplay
// 搞一个0kb的mp3文件,没有声音
// 循环播放
// 以前的后台模式只有3种
// 保持网络连接
// 多媒体应用
// voip:网络电话
}
|
在上面的代码里,我们看到,需要在info.plst中设置后台模式:required background modes == app plays audio or streams audio/video using airplay,如图:
最后搞一个0kb的mp3,没有声音的,循环播放即可。
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持服务器之家!
原文链接:http://www.cnblogs.com/jys509/p/4509207.html