iOS 后台永久保活,亲测有效

97 篇文章 0 订阅

一想到后台保活,我们最常见的就是音乐播放软件了,那在我们不是音乐软件的情况下我们要如何后台保活呢?

首先我们就要在Background Modes把音乐对应权限打开。

这个权限打开后,我们的工作就已经完成了1/3了

接下来我就就要在app进入后台的时候开始播放无声音的mp3。

我这里对音乐播放器进行了简单的封装,方便使用 SXAudioSessionObject

.h


#import <Foundation/Foundation.h>

NS_ASSUME_NONNULL_BEGIN

@interface SXAudioSessionObject : NSObject

/// 创建单利
+ (SXAudioSessionObject *)shareManager;

/// 创建音乐播放器
- (void)creatAVAudioSessionObject;

/// 开始播放音乐
- (void)startPlayAudioSession;

/// 停止播放音乐
- (void)stopPlayAudioSession;

@end

NS_ASSUME_NONNULL_END

.m


#import "SXAudioSessionObject.h"
#import <AVFoundation/AVFoundation.h>
#import <AudioToolbox/AudioToolbox.h>

@interface SXAudioSessionObject()
@property (strong, nonatomic) AVAudioPlayer *audioPlayer;
@end

@implementation SXAudioSessionObject

/// 创建单利
+ (SXAudioSessionObject *)shareManager{
    static SXAudioSessionObject *manager = nil;
    static dispatch_once_t onceToken;
    dispatch_once(&onceToken, ^{
        manager = [[SXAudioSessionObject alloc]init];
    });
    return manager;
}

/// 创建音乐播放器
- (void)creatAVAudioSessionObject{
    //设置后台模式和锁屏模式下依然能够播放
    [[AVAudioSession sharedInstance] setCategory:AVAudioSessionCategoryPlayback withOptions:AVAudioSessionCategoryOptionMixWithOthers error:nil];
    [[AVAudioSession sharedInstance] setActive: YES error: nil];
    //初始化音频播放器
    NSError *playerError;
    NSURL *urlSound = [[NSURL alloc]initWithString:[[NSBundle mainBundle]pathForResource:@"pomodoSound" ofType:@"m4a"]];
    _audioPlayer = [[AVAudioPlayer alloc] initWithContentsOfURL:urlSound error:&playerError];
    _audioPlayer.numberOfLoops = -1;//无限播放
    _audioPlayer.volume = 0;
}

/// 开始播放声音
- (void)startPlayAudioSession{
    [_audioPlayer play];
}

/// 停止播放声音
- (void)stopPlayAudioSession{
    [_audioPlayer stop];
}

@end

对这个封装完,我们就要使用了。后台保活,我们只需要在进入后台的时候播放音乐即可,进入前台我们停止音乐播放

首先我们先要穿件音乐播放器

[[SXAudioSessionObject shareManager] creatAVAudioSessionObject];

接下来就是播放和停止 


//应用程序已经进入后台运行
- (void)applicationDidEnterBackground:(UIApplication *)application
{
    NSLog(@"如果应用程序支持后台运行,则应用程序已经进入后台运行"); //如果需要退出后台,则在这里加上:exit(0);
    [[SXAudioSessionObject shareManager] startPlayAudioSession];    //创建一个背景任务去和系统请求后台运行的时间
}
//应用程序已经进入活动状态
- (void)applicationDidBecomeActive:(UIApplication *)application{
    NSLog(@"应用程序已进入前台,处于活动状态");
    [[SXAudioSessionObject shareManager] stopPlayAudioSession];
}

同时我们还要创建一下UIBackgroundTaskIdentifier和NSTimer

@property (nonatomic, assign) UIBackgroundTaskIdentifier backgrounTask;
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
    self.timer = [NSTimer scheduledTimerWithTimeInterval:5.0 target:self selector:@selector(applyToSystemForMoreTime) userInfo:nil repeats:YES];
    [self.timer setFireDate:[NSDate distantPast]];
    return YES;
}


#pragma mark - 定时器设置判断后台保活时间,如果将要被后台杀死,重新唤醒
- (void)applyToSystemForMoreTime {
    if ([UIApplication sharedApplication].backgroundTimeRemaining < 30.0) {//如果剩余时间小于30秒
        [[UIApplication sharedApplication] endBackgroundTask:self.self.backgrounTask];
        self.backgrounTask = [[UIApplication sharedApplication] beginBackgroundTaskWithExpirationHandler:^{
            [[UIApplication sharedApplication] endBackgroundTask:self.self.backgrounTask];
            self.backgrounTask = UIBackgroundTaskInvalid;
        }];
    }
}

上面的代码最好写成,如果进入后台的时候再启用定时器,在前台定时器处于停止状态即可。

  • 0
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
Uniapp 是一个跨平台的应用开发框架,需要在不同的平台上实现后台定位保活可能会有些不同。一般来说,在 Android 平台上可以通过 Service 实现后台定位保活,而在 iOS 平台上则需要使用后台任务和后台模式。 在 Android 平台上,可以创建一个 Service,在其中开启一个线程进行定位,保证定位服务一直在后台运行。同时,需要在 AndroidManifest.xml 文件中申明该 Service 的启动方式为 START_STICKY,这样当系统回收资源时,会自动重新启动该 Service。 在 iOS 平台上,需要使用后台任务和后台模式来实现后台定位保活。可以使用 Core Location 框架来实现定位功能,在开启定位时,需要在 Info.plist 文件中加入 NSLocationAlwaysUsageDescription 权限申明,以获取后台定位权限。同时,需要在 AppDelegate.m 文件中申明后台任务和后台模式,例如: ``` - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions { // 启用后台任务和后台模式 [self enableBackgroundTaskAndMode]; return YES; } - (void)enableBackgroundTaskAndMode { // 申明后台任务 self.backgroundTask = [[UIApplication sharedApplication] beginBackgroundTaskWithExpirationHandler:^{ [self endBackgroundTask]; }]; // 申明后台模式 CLLocationManager *locationManager = [[CLLocationManager alloc] init]; [locationManager setAllowsBackgroundLocationUpdates:YES]; } ``` 需要注意的是,在 iOS 平台上,由于苹果的限制,后台定位保活可能会被系统杀掉,因此需要在代码中添加相应的处理逻辑,例如重新开启定位等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

王 哪跑!!!

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值