国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 系統(tǒng) > iOS > 正文

iOS UICollectionView實(shí)現(xiàn)卡片效果

2020-07-26 01:28:46
字體:
供稿:網(wǎng)友

現(xiàn)在使用卡片效果的app很多,之前公司讓實(shí)現(xiàn)一種卡片效果,就寫了一篇關(guān)于實(shí)現(xiàn)卡片的文章。文章最后附有demo

實(shí)現(xiàn)上我選擇了使用UICollectionView ;用UICollectionViewFlowLayout來定制樣式;下面看看具體實(shí)現(xiàn)

具體實(shí)現(xiàn)

1、創(chuàng)建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、實(shí)現(xiàn)具體代理方法 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;}// 返回每個(gè)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點(diǎn)擊事件- (void)collectionView:(UICollectionView *)collectionView didSelectItemAtIndexPath:(NSIndexPath *)indexPath{ CollModel *infoModel = self.modelArray[indexPath.row]; NSLog(@"infoModelArray----%@",infoModel.title);}

3、自定義UICollectionViewFlowLayout

LHLeftCollocationView.m 實(shí)現(xiàn)

#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; //垂直縮放除以系數(shù)CGFloat ScaleFactor = 0.50; //縮放系數(shù) 越大縮放越大- (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;}////設(shè)置放大動(dòng)畫//-(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);// //移動(dòng)的距離和屏幕寬度的的比例// CGFloat apartScale = distance/self.collectionView.bounds.size.width;// //把卡片移動(dòng)范圍固定到 -π/4到 +π/4這一個(gè)范圍內(nèi)// CGFloat scale = fabs(cos(apartScale * M_PI/4));// //設(shè)置cell的縮放 按照余弦函數(shù)曲線 越居中越趨近于1// attributes.transform = CGAffineTransformMakeScale(1.0, scale);// }// return arr;//}//防止報(bào)錯(cuò) 先復(fù)制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()/** * 存放所有下載操作的隊(duì)列 */@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

運(yùn)行效果

下載demo

github 下載

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持武林網(wǎng)。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 鄂伦春自治旗| 日喀则市| 临泉县| 博湖县| 银川市| 澎湖县| 牙克石市| 瑞昌市| 太湖县| 宜都市| 浙江省| 昌平区| 沐川县| 浦县| 扎兰屯市| 宁明县| 峨边| 七台河市| 南宁市| 子洲县| 寿阳县| 中牟县| 安仁县| 泾川县| 阿克| 娄烦县| 丽水市| 曲松县| 宜宾县| 定远县| 台南市| 乐山市| 南丰县| 宁陵县| 漾濞| 阜城县| 林口县| 阿坝县| 衡山县| 汉源县| 德清县|