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