电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

iOS UICollectionView實現卡片效果

瀏覽:5日期:2022-09-17 09:42:42

現在使用卡片效果的app很多,之前公司讓實現一種卡片效果,就寫了一篇關于實現卡片的文章。文章最后附有demo

實現上我選擇了使用UICollectionView ;用UICollectionViewFlowLayout來定制樣式;下面看看具體實現

具體實現

1、創建UICollectionView

- (void)createCollectionView { CGFloat pading = 0 * SCREEN_WIDTH/375; LHLeftCollocationView * layout = [[LHLeftCollocationView alloc]init]; layout.scrollDirection = UICollectionViewScrollDirectionHorizontal; layout.minimumLineSpacing = pading; layout.minimumInteritemSpacing = pading;// UICollectionViewFlowLayout *layout = [[UICollectionViewFlowLayout alloc]init];// layout.scrollDirection = UICollectionViewScrollDirectionHorizontal; _collectionView3 = [[UICollectionView alloc] initWithFrame:CGRectMake(0, 100, [UIScreen mainScreen].bounds.size.width, imageHeight * SCREEN_RATE) collectionViewLayout:layout]; _collectionView3.tag = 33; _collectionView3.dataSource = self; _collectionView3.delegate = self; _collectionView3.bounces = NO; _collectionView3.alwaysBounceHorizontal = NO; _collectionView3.alwaysBounceVertical = NO; _collectionView3.backgroundColor = [UIColor grayColor]; _collectionView3.showsHorizontalScrollIndicator = NO; _collectionView3.showsVerticalScrollIndicator = NO; [self.view addSubview:_collectionView3]; [_collectionView3 registerClass:[CollectionViewCell class] forCellWithReuseIdentifier:collectionViewCell];}

2、實現具體代理方法 UICollectionViewDelegate,UICollectionViewDataSource

- (NSInteger)collectionView:(UICollectionView *)collectionView numberOfItemsInSection:(NSInteger)section{ return self.modelArray.count;}- (NSMutableArray *)modelArray { if (!_modelArray) { _modelArray = [NSMutableArray array]; } return _modelArray;}- (UICollectionViewCell *)collectionView:(UICollectionView *)collectionView cellForItemAtIndexPath:(NSIndexPath *)indexPath { CollModel *infoModel = self.modelArray[indexPath.row]; NSLog(@'section:%ld --- row:%ld -----%@',indexPath.section,indexPath.row,infoModel.title); CollectionViewCell * cell = [collectionView dequeueReusableCellWithReuseIdentifier:collectionViewCell forIndexPath:indexPath]; cell.itemModel = infoModel; return cell;}// 返回每個item的大小- (CGSize)collectionView:(UICollectionView *)collectionView layout:(UICollectionViewLayout *)collectionViewLayout sizeForItemAtIndexPath:(NSIndexPath *)indexPath { CGFloat CWidth = 80 * SCREEN_RATE; CGFloat CHeight = 80 * SCREEN_RATE; return CGSizeMake(CWidth, CHeight);}#pragma mark - UICollectionViewDelegate點擊事件- (void)collectionView:(UICollectionView *)collectionView didSelectItemAtIndexPath:(NSIndexPath *)indexPath{ CollModel *infoModel = self.modelArray[indexPath.row]; NSLog(@'infoModelArray----%@',infoModel.title);}

3、自定義UICollectionViewFlowLayout

LHLeftCollocationView.m 實現

#import 'LHLeftCollocationView.h'@implementation LHLeftCollocationView- (CGPoint)targetContentOffsetForProposedContentOffset:(CGPoint)proposedContentOffset withScrollingVelocity:(CGPoint)velocity { CGRect targectRect = CGRectMake(proposedContentOffset.x, 0.0, [UIScreen mainScreen].bounds.size.width, [UIScreen mainScreen].bounds.size.height); NSArray * attriArray = [super layoutAttributesForElementsInRect:targectRect]; CGFloat horizontalCenterX = proposedContentOffset.x + ([UIScreen mainScreen].bounds.size.width); CGFloat offsetAdjustment = CGFLOAT_MAX; for (UICollectionViewLayoutAttributes * layoutAttributes in attriArray) { CGFloat itemHorizontalCenterX = layoutAttributes.center.x; if (fabs(itemHorizontalCenterX-horizontalCenterX) < fabs(offsetAdjustment)) { offsetAdjustment = itemHorizontalCenterX - horizontalCenterX; } } return CGPointMake(proposedContentOffset.x , proposedContentOffset.y);}CGFloat ActiveDistance = 400; //垂直縮放除以系數CGFloat ScaleFactor = 0.50; //縮放系數 越大縮放越大- (NSArray<UICollectionViewLayoutAttributes *> *)layoutAttributesForElementsInRect:(CGRect)rect { NSArray * array = [super layoutAttributesForElementsInRect:rect]; CGRect visibleRect = CGRectZero; visibleRect.origin = self.collectionView.contentOffset; visibleRect.size = self.collectionView.bounds.size; for (UICollectionViewLayoutAttributes *attributes in array) { CGFloat distance = CGRectGetMidX(visibleRect) - attributes.center.x; CGFloat normalizedDistance = fabs(distance / ActiveDistance); CGFloat zoom = 1 - ScaleFactor * normalizedDistance; NSLog(@'zoom----%f',zoom); attributes.transform3D = CATransform3DMakeScale(1.0, zoom, 1.0); //底部顯示效果 attributes.frame = CGRectMake(attributes.frame.origin.x, attributes.frame.origin.y + zoom, attributes.size.width, attributes.size.height); //居中顯示效果// CGFloat scrollDirectionItemHeight = self.itemSize.height;// CGFloat sideItemFixedOffset = 0;// sideItemFixedOffset = (scrollDirectionItemHeight - scrollDirectionItemHeight * 0.7) / 2;// attributes.center = CGPointMake(attributes.center.x, attributes.center.y + zoom); } return array;}////設置放大動畫//-(NSArray<UICollectionViewLayoutAttributes *> *)layoutAttributesForElementsInRect:(CGRect)rect//{// NSArray *arr = [self getCopyOfAttributes:[super layoutAttributesForElementsInRect:rect]];// //屏幕中線// CGFloat centerX = self.collectionView.contentOffset.x + self.collectionView.bounds.size.width/2.0f;// //刷新cell縮放// for (UICollectionViewLayoutAttributes *attributes in arr) {// CGFloat distance = fabs(attributes.center.x - centerX);// //移動的距離和屏幕寬度的的比例// CGFloat apartScale = distance/self.collectionView.bounds.size.width;// //把卡片移動范圍固定到 -π/4到 +π/4這一個范圍內// CGFloat scale = fabs(cos(apartScale * M_PI/4));// //設置cell的縮放 按照余弦函數曲線 越居中越趨近于1// attributes.transform = CGAffineTransformMakeScale(1.0, scale);// }// return arr;//}//防止報錯 先復制attributes- (NSArray *)getCopyOfAttributes:(NSArray *)attributes{ NSMutableArray *copyArr = [NSMutableArray new]; for (UICollectionViewLayoutAttributes *attribute in attributes) { [copyArr addObject:[attribute copy]]; } return copyArr;}- (BOOL)shouldInvalidateLayoutForBoundsChange:(CGRect)newBounds { return true;}@end

4、自定義cell 和model

model

#import <Foundation/Foundation.h>@interface CollModel : NSObject@property (nonatomic,strong)NSString *imgUrl;@property (nonatomic,strong)NSString *title;@property (nonatomic,strong)NSString *url;@end

cell 自定義

#import <UIKit/UIKit.h>#import 'CollModel.h'@interface CollectionViewCell : UICollectionViewCell@property (nonatomic, strong) CollModel * itemModel;@end#import 'CollectionViewCell.h'#define SCREEN_RATE ([UIScreen mainScreen].bounds.size.width/375.0)@interface CollectionViewCell()/** * 存放所有下載操作的隊列 */@property (nonatomic, strong) UIImageView *itemIcon;@property (nonatomic, strong) UILabel *itemLabel;@property (nonatomic, strong) UILabel *priceLabel;@end@implementation CollectionViewCell@synthesize itemModel = _itemModel;- (instancetype)initWithFrame:(CGRect)frame{ if (self = [super initWithFrame:frame]) { self.contentView.backgroundColor = [UIColor clearColor]; [self initView]; } return self;}- (void)initView { _itemIcon = [[UIImageView alloc] init]; [self.contentView addSubview:_itemIcon]; _itemIcon.backgroundColor = [UIColor clearColor]; // CGFloat iconWidth = ([UIScreen mainScreen].bounds.size.width / 5.0) * SCREEN_RATE; _itemIcon.frame = CGRectMake(0, 0, self.contentView.frame.size.width, self.contentView.frame.size.height); _itemIcon.center = self.contentView.center;}- (CollModel *)itemModel{ return _itemModel;}- (void)setItemModel:(CollModel *)itemModel{ if (!itemModel) { return; } _itemModel = itemModel; [self setCellWithModel:_itemModel];}- (void)setCellWithModel:(CollModel *)itemModel{ [[NSOperationQueue mainQueue] addOperationWithBlock:^{ _itemIcon.image = [UIImage imageNamed:itemModel.url]; }];}@end

運行效果

iOS UICollectionView實現卡片效果

下載demo

github 下載

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: IOS
相關文章:
主站蜘蛛池模板: 硅PU球场、篮球场地面施工「水性、环保、弹性」硅PU材料生产厂家-广东中星体育公司 | 哈希余氯测定仪,分光光度计,ph在线监测仪,浊度测定仪,试剂-上海京灿精密机械有限公司 | 运动木地板价格,篮球馆体育运动木地板生产厂家_欧氏地板 | 卷筒电缆-拖链电缆-特种柔性扁平电缆定制厂家「上海缆胜」 | 带式压滤机_污泥压滤机_污泥脱水机_带式过滤机_带式压滤机厂家-河南恒磊环保设备有限公司 | 镀锌钢格栅_热镀锌格栅板_钢格栅板_热镀锌钢格板-安平县昊泽丝网制品有限公司 | 土壤养分检测仪_肥料养分检测仪_土壤水分检测仪-山东莱恩德仪器 大型多片锯,圆木多片锯,方木多片锯,板材多片锯-祥富机械有限公司 | 转向助力泵/水泵/发电机皮带轮生产厂家-锦州华一精工有限公司 | MVR蒸发器厂家-多效蒸发器-工业废水蒸发器厂家-康景辉集团官网 | 桨叶搅拌机_螺旋挤压/方盒旋切造粒机厂家-无锡市鸿诚输送机械有限公司 | 长沙发电机-湖南发电机-柴油发电机供应厂家-长沙明邦智能科技 | 北京公司注册_代理记账_代办商标注册工商执照-企力宝 | 氧化锆陶瓷_氧化锆陶瓷加工_氧化锆陶瓷生产厂家-康柏工业陶瓷有限公司 | 苏州柯瑞德货架-仓库自动化改造解决方案 | 整合营销推广|营销网络推广公司|石家庄网站优化推广公司|智营销 好物生环保网、环保论坛 - 环保人的学习交流平台 | 复盛空压机配件-空气压缩机-复盛空压机(华北)总代理 | 杰福伦_磁致伸缩位移传感器_线性位移传感器-意大利GEFRAN杰福伦-河南赉威液压科技有限公司 | 电池高低温试验箱-气态冲击箱-双层电池防爆箱|简户百科 | 大型冰雕-景区冰雕展制作公司,3D创意设计源头厂家-[赛北冰雕] | 耐火砖厂家,异形耐火砖-山东瑞耐耐火材料厂 | 溶氧传感器-pH传感器|哈美顿(hamilton) | 南京办公用品网-办公文具用品批发-打印机耗材采购 | 旋振筛|圆形摇摆筛|直线振动筛|滚筒筛|压榨机|河南天众机械设备有限公司 | 英语词典_成语词典_日语词典_法语词典_在线词典网 | 无线遥控更衣吊篮_IC卡更衣吊篮_电动更衣吊篮配件_煤矿更衣吊篮-力得电子 | 上海阳光泵业制造有限公司 -【官方网站】 | NMRV减速机|铝合金减速机|蜗轮蜗杆减速机|NMRV减速机厂家-东莞市台机减速机有限公司 | 高效复合碳源-多核碳源生产厂家-污水处理反硝化菌种一长隆科技库巴鲁 | 金属检测机_金属分离器_检针验针机_食品药品金属检探测仪器-广东善安科技 | 山东包装,山东印刷厂,济南印刷厂-济南富丽彩印刷有限公司 | Safety light curtain|Belt Sway Switches|Pull Rope Switch|ultrasonic flaw detector-Shandong Zhuoxin Machinery Co., Ltd | 小型铜米机-干式铜米机-杂线全自动铜米机-河南鑫世昌机械制造有限公司 | elisa试剂盒-PCR试剂盒「上海谷研实业有限公司」 | 嘉兴泰东园林景观工程有限公司_花箱护栏 | 国际学校_国际学校哪个好_国际课程学校-国际学校择校网 | 澳威全屋定制官网|极简衣柜十大品牌|衣柜加盟代理|全屋定制招商 百度爱采购运营研究社社群-店铺托管-爱采购代运营-良言多米网络公司 | MVR蒸发器厂家-多效蒸发器-工业废水蒸发器厂家-康景辉集团官网 | 深圳展厅设计_企业展馆设计_展厅设计公司_数字展厅设计_深圳百艺堂 | MOOG伺服阀维修,ATOS比例流量阀维修,伺服阀维修-上海纽顿液压设备有限公司 | 小学教案模板_中学教师优秀教案_高中教学设计模板_教育巴巴 | 臭氧发生器_臭氧消毒机 - 【同林品牌 实力厂家】 |