我试图创建一个“上传图像”系统,并且试图调整每个图像之间的空间。但是,由于旋转木马停止移动时,由于重叠,图像始终必须移到最前面,因此并没有按计划进行。如何停止这种重叠?谢谢!

func carousel(_ carousel: iCarousel, valueFor option: iCarouselOption, withDefault value: CGFloat) -> CGFloat {
    if option == .visibleItems {
        return CGFloat(images.count)
    } else if option == .spacing {
        return value * 0.87
    } else if option == .showBackfaces {
        return 0
    }
    return value
}

func carousel(_ carousel: iCarousel, viewForItemAt index: Int, reusing view: UIView?) -> UIView {

    let imageView = UIImageView(frame: CGRect(x: getWidths(upTo: index) , y: 0, width: widths[index], height: 200))
    imageView.image = images[index]
    imageView.layer.borderColor = UIColor.black.cgColor
    imageView.contentMode = .scaleAspectFit
    imageView.frame = CGRect(x: getWidths(upTo: index) , y: 0, width: widths[index], height: 200)
    imageView.layer.borderWidth = 4
    return imageView
}

func getWidths(upTo index: Int) -> CGFloat {
    var width = CGFloat()

    for i in 0..<index {
        width += widths[i]
    }

    return width

}


结果如下:

https://1drv.ms/v/s!AiYSVEFiXE12g_gNyVufJ1LqZMcZtw

最佳答案

轮播的类型是什么,如果您的类型是自定义的,则应覆盖该函数
-(CATransform3D)轮播:(RPiCarousel *)轮播itemTransformForOffset:(CGFloat)偏移基数Transform:(CATransform3D)transform

在此功能中,您可以使用
返回CATransform3DTranslate(transform,offset * self.taskView.itemWidth * offset,0.0,0.0);
这解决了我的问题

10-06 01:27