带有卡片和列表的UITableView - iOS Swift

时间:2017-10-13 08:55:31

标签: ios swift uitableview

我试图创建一个自定义UITableView来显示包含我的项目的卡片,如下所示:

Custom UITableView with cards

我已经有一个类CardView用阴影创建我的卡片,但我没有成功地使用它来获得我正在寻找的东西。

也许最好的方法是自定义部分并在其上应用我的CardView。

你能帮帮我吗?

谢谢!

3 个答案:

答案 0 :(得分:1)

在tableviewcell中使用UITableview。

1.创建UITableView1-> UITableviewCell1-> UIView-> UITableView2-> UITableviewCell2

2.在UITableviewCell1中设置UITableview2委托

3.在UITableView1 cellforRow

中重写UITableView2

第2步 在UITableviewCell1里面 override func awakeFromNib() { //UITableView2 Delegates self.tableView2.delegate = self self.tableView2.dataSource = self super.awakeFromNib() }

答案 1 :(得分:1)

对于此问题,只需使用以下代码添加tableView:willDisplayCell:forRowAtIndexPath:委托方法(应该使用简单的复制/粘贴),它也适用于分组表。我评论了你应该在哪里设置边框的宽度和颜色。

- (void)tableView:(UITableView *)tableView willDisplayCell:(UITableViewCell *)cell forRowAtIndexPath:(NSIndexPath *)indexPath
    {

    if ([cell respondsToSelector:@selector(tintColor)]) {
        CGFloat cornerRadius = 5.f;
        cell.backgroundColor = UIColor.clearColor;
        CAShapeLayer *layer = [[CAShapeLayer alloc] init];
        CGMutablePathRef pathRef = CGPathCreateMutable();
        CGRect bounds = CGRectInset(cell.bounds, 10, 0);
        BOOL addLine = NO;
        if (indexPath.row == 0 && indexPath.row == [tableView numberOfRowsInSection:indexPath.section]-1) {
            CGPathAddRoundedRect(pathRef, nil, bounds, cornerRadius, cornerRadius);
        } else if (indexPath.row == 0) {
            CGPathMoveToPoint(pathRef, nil, CGRectGetMinX(bounds), CGRectGetMaxY(bounds));
            CGPathAddArcToPoint(pathRef, nil, CGRectGetMinX(bounds), CGRectGetMinY(bounds), CGRectGetMidX(bounds), CGRectGetMinY(bounds), cornerRadius);
            CGPathAddArcToPoint(pathRef, nil, CGRectGetMaxX(bounds), CGRectGetMinY(bounds), CGRectGetMaxX(bounds), CGRectGetMidY(bounds), cornerRadius);
            CGPathAddLineToPoint(pathRef, nil, CGRectGetMaxX(bounds), CGRectGetMaxY(bounds));
            addLine = YES;
        } else if (indexPath.row == [tableView numberOfRowsInSection:indexPath.section]-1) {
            CGPathMoveToPoint(pathRef, nil, CGRectGetMinX(bounds), CGRectGetMinY(bounds));
            CGPathAddArcToPoint(pathRef, nil, CGRectGetMinX(bounds), CGRectGetMaxY(bounds), CGRectGetMidX(bounds), CGRectGetMaxY(bounds), cornerRadius);
            CGPathAddArcToPoint(pathRef, nil, CGRectGetMaxX(bounds), CGRectGetMaxY(bounds), CGRectGetMaxX(bounds), CGRectGetMidY(bounds), cornerRadius);
            CGPathAddLineToPoint(pathRef, nil, CGRectGetMaxX(bounds), CGRectGetMinY(bounds));
        } else {
            CGPathAddRect(pathRef, nil, bounds);
            addLine = YES;
        }
        layer.path = pathRef;
        CFRelease(pathRef);
        //set the border color
        layer.strokeColor = [UIColor lightGrayColor].CGColor;
        //set the border width
        layer.lineWidth = 1;
        layer.fillColor = [UIColor colorWithWhite:1.f alpha:1.0f].CGColor;


        if (addLine == YES) {
            CALayer *lineLayer = [[CALayer alloc] init];
            CGFloat lineHeight = (1.f / [UIScreen mainScreen].scale);
            lineLayer.frame = CGRectMake(CGRectGetMinX(bounds), bounds.size.height-lineHeight, bounds.size.width, lineHeight);
            lineLayer.backgroundColor = tableView.separatorColor.CGColor;
            [layer addSublayer:lineLayer];
        }

        UIView *testView = [[UIView alloc] initWithFrame:bounds];
        [testView.layer insertSublayer:layer atIndex:0];
        testView.backgroundColor = UIColor.clearColor;
        cell.backgroundView = testView;
    }
}

另外,请记住在Interface Builder中将表的separator属性设置为none(默认为单行),如果以编程方式创建表,则应设置此属性

tableView.separatorStyle = UITableViewCellSeparatorStyleNone

截图: enter image description here

代码: https://drive.google.com/file/d/0BwYZPQSG7kikbVpUZklGSWFwMTA/view?usp=sharing

答案 2 :(得分:0)

使用UICollectionView并查看以下教程,它完全符合您的要求:

http://www.phillfarrugia.com/2017/06/19/rebuilding-the-new-app-store-app-today-view/