zoukankan      html  css  js  c++  java
  • 图片视频毛玻璃效果实现

    毛玻璃效果主要实现就是在图片(imageview)上加一个 UIVisualEffectView

    @property (nonatomic, strong) UIVisualEffectView *effectView;// 毛玻璃处理模糊图片
    #import "VideoTableViewCell.h"
    #import "UIImageView+WebCache.h"
    
    @interface VideoTableViewCell()
    @property (nonatomic, strong) UIImageView *vadioImageView; // 模糊图片
    @property (nonatomic, strong) UIVisualEffectView *effectView;// 毛玻璃处理模糊图片
    @property (nonatomic, strong) UIImageView *backgroundIV;
    
    @end
    
    @implementation VideoTableViewCell
    - (instancetype)initWithStyle:(UITableViewCellStyle)style reuseIdentifier:(NSString *)reuseIdentifier
    {
        if (self = [super initWithStyle:style reuseIdentifier:reuseIdentifier]) {
            self.selectionStyle = UITableViewCellSelectionStyleNone;
            self.separatorInset = UIEdgeInsetsZero;
            
            [self.contentView addSubview:self.vadioImageView];// 模糊图片
            [self.contentView addSubview:self.effectView];// 毛玻璃处理模糊图片
            [self.contentView addSubview:self.backgroundIV]; // 清晰图片
            
            __weak typeof(self)weakself = self;
            [self.backgroundIV mas_makeConstraints:^(MASConstraintMaker *make) {
                make.top.equalTo(weakself.mas_top).offset(10 / WIDTH_6S_SCALE);
                make.left.right.equalTo(weakself);
                make.height.mas_offset(IMG_HEIGHT / WIDTH_6S_SCALE);
            }];
            [self.vadioImageView mas_makeConstraints:^(MASConstraintMaker *make) {
                make.top.equalTo(weakself.mas_top).offset(10 / WIDTH_6S_SCALE);
                make.left.right.equalTo(weakself);
                make.height.mas_offset(IMG_HEIGHT / WIDTH_6S_SCALE);
            }];
            [self.effectView mas_makeConstraints:^(MASConstraintMaker *make) {
                make.top.equalTo(weakself.mas_top).offset(10 / WIDTH_6S_SCALE);
                make.left.right.equalTo(weakself);
                make.height.mas_offset(IMG_HEIGHT / WIDTH_6S_SCALE);
            }];
            
            [self.contentView mas_makeConstraints:^(MASConstraintMaker *make) {
                make.top.equalTo(weakself.backgroundIV.mas_top).offset(-10 / HEIGHT_6S_SCALE);
                make.left.right.equalTo(weakself);
                make.bottom.equalTo(weakself.backgroundIV.mas_bottom).offset(10 / HEIGHT_6S_SCALE);
            }];
        }
        return self;
    }
    #pragma mark - set
    - (void)setHomePageModelList:(HomePageModelList *)homePageModelList
    {
        _homePageModelList = homePageModelList;
        NSURL *videoUrl = [NSURL URLWithStringAddOffset:self.homePageModelList.file];
        WS(ws);
        [UIImage getImageFromVideoURLString:videoUrl.absoluteString handle:^(NSDictionary *dic) {
            ws.backgroundIV.image = dic[@"image"];
            ws.vadioImageView.image = dic[@"image"];
        }];
    }
    #pragma mark - init
    - (UIImageView *)backgroundIV
    {
        if (!_backgroundIV) {
            _backgroundIV = [[UIImageView alloc]init];
            _backgroundIV.contentMode = UIViewContentModeScaleAspectFit;
        }
        return _backgroundIV;
    }
    - (UIImageView *)vadioImageView
    {
        if (!_vadioImageView)
        {
            _vadioImageView = [[UIImageView alloc]init];
            _vadioImageView.backgroundColor = [UIColor grayColor];
            _vadioImageView.image = [UIImage imageNamed:@"h4"];
            //        _vadioImageView.contentMode = UIViewContentModeScaleAspectFit;
        }
        return _vadioImageView;
    }
    
    - (UIVisualEffectView *)effectView
    {
        if (!_effectView)
        {
            _effectView = [[UIVisualEffectView alloc] initWithEffect:[UIBlurEffect effectWithStyle:UIBlurEffectStyleLight]];
            _effectView.alpha = 0.9f;
        }
        return _effectView;
    }
    @end
  • 相关阅读:
    npm ERR! shasum check failed for
    使用js闭包封装一个原生的模态框
    使用weexplus + vue开发APP的填坑之旅
    weex 中出现 loading无法关闭
    weex create test-app Error: Cannot find module '../package.json'
    flutter 填坑之旅(dart学习笔记篇)
    各种版本的Linux 镜像下载网址
    在vue 项目中嵌入jsp页面
    mahout 推荐引擎的相关介绍,理解,如何应用。(2)
    mahout 推荐引擎的相关介绍,理解,如何应用。(1)
  • 原文地址:https://www.cnblogs.com/dujiahong/p/8556314.html
Copyright © 2011-2022 走看看