本篇文章給大家分享的是有關(guān)iOS中怎么實現(xiàn)一個AirPods彈出動畫,小編覺得挺實用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

網(wǎng)站的建設(shè)成都創(chuàng)新互聯(lián)專注網(wǎng)站定制,經(jīng)驗豐富,不做模板,主營網(wǎng)站定制開發(fā).小程序定制開發(fā),H5頁面制作!給你煥然一新的設(shè)計體驗!已為汽車玻璃修復(fù)等企業(yè)提供專業(yè)服務(wù)。
思路
在當(dāng)前ViewController下Present另外一個AnimationViewController,在彈出的AnimationViewController中播放動畫,彈出的時候原來的ViewController上有一個全屏覆蓋的maskView,在彈出時,有一個漸變動畫(頁面漸黑),在AnimationViewController聲明一個代理,在代理方法中實現(xiàn)收起的動畫效果(dissmissController和maskView消失)
主要代碼
HCAirPodsAnimationViewController *vc = [[HCAirPodsAnimationViewController alloc] init];
vc.delegate = self;
vc.modalPresentationStyle = UIModalPresentationOverCurrentContext;
[UIView animateWithDuration:0.2 animations:^{
self.maskBgView.alpha = 0.5;
} completion:nil];
[self presentViewController:vc animated:YES completion:^{
[vc.animationView play];
}];模態(tài)跳轉(zhuǎn)的style有一個枚舉值,在iOS13以前modalPresentationStyle的默認(rèn)值為UIModalPresentationFullScreen,iOS13以后變成了UIModalPresentationPageSheet,在這里我們把style設(shè)置為UIModalPresentationOverCurrentContext彈出的這個控制器就會覆蓋在原來的控制器之上
- (UIView *)maskBgView
{
if (!_maskBgView) {
_maskBgView = [[UIView alloc] initWithFrame:CGRectMake(0, 0, [UIScreen mainScreen].bounds.size.width, [UIScreen mainScreen].bounds.size.height)];
_maskBgView.backgroundColor = [UIColor blackColor];
_maskBgView.alpha = 0;
[self.view addSubview:_maskBgView];
}
return _maskBgView;
}一個覆蓋全屏的maskView采用懶加載的方式實現(xiàn)
- (void)initContentView
{
CGFloat containerW = SCREEN_WIDTH - 20;
CGFloat containerH = containerW * 0.9;
UIView *containerView = [[UIView alloc] initWithFrame:CGRectMake(10, SCREEN_HEIGHT - containerH - 10, containerW, containerH)];
containerView.layer.cornerRadius = 20;
containerView.backgroundColor = [UIColor whiteColor];
[self.view addSubview:containerView];
self.animationView = [[LOTAnimationView alloc] initWithFrame:CGRectMake(70, 70, containerW - 140, containerH - 140)];
[containerView addSubview:self.animationView];
self.animationView.animation = @"gift_animation";
self.animationView.loopAnimation = YES;
UIButton *confirmButton = [[UIButton alloc] initWithFrame:CGRectMake(0, 0, 200, 34)];
confirmButton.center = CGPointMake(self.animationView.center.x, containerH - 44);
[confirmButton setTitle:@"Close" forState:UIControlStateNormal];
[confirmButton setTitleColor:[UIColor whiteColor] forState:UIControlStateNormal];
[confirmButton setBackgroundColor:[UIColor blueColor]];
confirmButton.layer.cornerRadius = 10;
[confirmButton addTarget:self action:@selector(onConfirmButtonClick) forControlEvents:UIControlEventTouchUpInside];
[containerView addSubview:confirmButton];
}動畫這里用到的是Lottie這個動畫開源庫(Airbnb),這個開源庫主要的功能是可以將After Effects制作的動畫通過插件導(dǎo)出為json格式的文件,然后通過這個開源庫解析成動畫。
- (void)onConfirmButtonClick
{
if ([self.delegate respondsToSelector:@selector(onAirPodsAnimationViewControllerConfirmButtonClick:)]) {
[self dismissViewControllerAnimated:YES completion:nil];
[self.delegate onAirPodsAnimationViewControllerConfirmButtonClick:self];
}
}dissmiss當(dāng)前的控制器,讓viewController來實現(xiàn)這個代理方法,并且在代理方法中隱藏maskView
- (void)onAirPodsAnimationViewControllerConfirmButtonClick:(HCAirPodsAnimationViewController *)vc
{
[UIView animateWithDuration:0.2 animations:^{
self.maskBgView.alpha = 0.0;
} completion:nil];
}以上就是iOS中怎么實現(xiàn)一個AirPods彈出動畫,小編相信有部分知識點可能是我們?nèi)粘9ぷ鲿姷交蛴玫降摹OM隳芡ㄟ^這篇文章學(xué)到更多知識。更多詳情敬請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。
當(dāng)前題目:iOS中怎么實現(xiàn)一個AirPods彈出動畫
標(biāo)題路徑:http://www.chinadenli.net/article16/gccigg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供定制網(wǎng)站、建站公司、網(wǎng)站改版、外貿(mào)網(wǎng)站建設(shè)、網(wǎng)站營銷、網(wǎng)站內(nèi)鏈
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)