IOS实战 (4) 之 仿微信新闻评论框+ 半透明模糊效果

效果图


网易新闻评论图

网易新闻评论

仿图

这里写图片描述

实现思路


1.键盘弹出事件
2.UIVisualEffectView作为背景图

核心代码


1.键盘弹出事件监听
添加通知监听

 [[NSNotificationCenter defaultCenter] addObserver:self
                                             selector:@selector(keyboardWillShow:)
                                                 name:UIKeyboardWillShowNotification
                                               object:nil];

实现 keyboardWillShow 方法(获取键盘高度然后针对 View 进行调整 )

 CGRect keyboardBounds;
    [[notification.userInfo valueForKey:UIKeyboardFrameEndUserInfoKey] getValue:&keyboardBounds];
    NSLog(@"keyboadr  %@",NSStringFromCGRect(keyboardBounds));
    int  keyBoardHeight=keyboardBounds.size.height;
    NSNumber *duration = [notification.userInfo objectForKey:UIKeyboardAnimationDurationUserInfoKey];
    NSNumber *curve = [notification.userInfo objectForKey:UIKeyboardAnimationCurveUserInfoKey];
    [UIView beginAnimations:nil context:NULL];
    [UIView setAnimationBeginsFromCurrentState:YES];
    [UIView setAnimationDuration:[duration doubleValue]];
    [UIView setAnimationCurve:[curve intValue]];

        dialogView.center=CGPointMake(ScreenWidth/2, ScreenHeight-keyBoardHeight-DialogViewHeight/2);
    NSLog(@"dialogView  frame %@",NSStringFromCGRect(dialogView.frame));
    NSLog(@"comment  frame %@",NSStringFromCGRect(commentView.frame));
    [UIView commitAnimations];

创建模糊图层


    UIView *maskView;
    double version = [[UIDevice currentDevice].systemVersion doubleValue];
    if (version >= 8.0f) {

        UIBlurEffect *blur = [UIBlurEffect effectWithStyle:UIBlurEffectStyleDark];
        maskView = [[UIVisualEffectView alloc] initWithEffect:blur];
        ((UIVisualEffectView *)maskView).frame = self.view.bounds;

    }else if(version >= 7.0f){

        maskView = [[UIToolbar alloc] initWithFrame:self.view.bounds];
        ((UIToolbar *)maskView).barStyle = UIBarStyleDefault;

    }

总结


整个例子非常简单,模糊效果 IOS8 及以上 可以使用UIVisualEffectView 就可以实现官方的模糊效果. IOS 7 以上可以用 ToolBar 勉强代替.要是还要向下兼容.我的源码里有一个大神做的 BlurView 也可以使用.

源码


源码下载

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值