2

我有一个以编程方式创建的 UICollectionView。集合视图中的每个单元格都显示一个标签,并且所有标签都具有相同的属性。尽管如此,我注意到集合视图中心列中每个标签中包含的文本看起来很模糊。

对集合视图的递归描述表明,表格中的中心单元格始终具有一个十进制值的 x 原点:

 <UICollectionViewCell: 0xd98c1e0; frame = (242.5 0; 220 45); layer = <CALayer: 0xd98c270>> ...

我的问题是:1)这会导致模糊吗?和 2) 确保 x 和 y 原点都没有最终具有十进制值的最佳方法是什么?(除了手动计算布局)

作为参考,这是我的 UICollectionView 代码:

//subclass UICollectionViewFlowLayout

@implementation LabelLayout

-(BOOL)shouldInvalidateLayoutForBoundsChange:(CGRect)newBounds{
    return YES;
}

- (id)init
{
    self = [super init];
    if (self) {
        [self setup];
    }
    return self;
}

-(void)prepareLayout
{
    [super prepareLayout];
    _cellCount = [[self collectionView] numberOfItemsInSection:0];
}

- (void)setup
{
    self.itemSize = CGSizeMake(220.0f, 45.0f);
    self.sectionInset = UIEdgeInsetsMake(0.0f, 0.0f, 0.0f, 0.0f);
    self.minimumLineSpacing = 10.0f;
    self.minimumInteritemSpacing = 20.0f;
}

@end
4

1 回答 1

1

这肯定会导致模糊,因为所有内容都在两个像素上进行了抗锯齿处理(注意:在视网膜屏幕上,您不会看到任何模糊,因为每个点实际上是两个像素,因此从技术上讲,半个点作为单个像素存在)。要修复它,您可能必须使用 CGRectIntegral 将帧强制为整数边界。最好的方法是:

- (NSArray *)layoutAttributesForElementsInRect:(CGRect)rect{
    NSArray *attributes = [super layoutAttributesForElementsInRect:rect];
    for (NSLayoutAttributes *attribute in attributes){
        attribute.frame = CGRectIntegral(attribute.frame);
    }
}

你应该为layoutAttributesForItemAtIndexPath:.

于 2013-07-30T22:31:37.233 回答