在配置文件屏幕中,从用户名,电子邮件ID,汽车类别的Firestore中检索数据。这里的汽车类别为紧凑型,小型,中型和全尺寸。并将carCategory参数值存储为String(即CarCategory:“ 1”,这意味着汽车类别为“ 0” ,然后,如果其紧凑型汽车 < strong>汽车类别值为“ 1” ,然后为小)。
在用户更新页面中,汽车类别是集合视图,流程布局是旋转木马视图
如果汽车类别的单元格索引路径值为1,那么它将显示单元格详细信息,而无需滚动。
我的问题是如何在集合视图单元格中加载特定的单元格索引。
这是到目前为止我尝试过的代码:
**collection view and carousel view**
var car = [String]()
var carCategory = [ "Compact","small", "Midsize", "Full", "Van/Pick-up" ]
var carCategoryImage = ["compactCar", "smallCar", "mediumCar", "fullCar", "vanPickup"]
var carCategoryMeter = ["3.5 - 4.5m", "2.5 - 3.5m", "4 - 5m", "5 - 5.5m", "5.5 - 6.5m"]
var carCategoryLabel: UILabel?
var carMetersLabel: UILabel?
var carCategoryImageLabel: UIImageView?
var currentPageValue: String?
var currentCell: Int?
func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
return carCategory.count
}
func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell {
let cell = collectionView.dequeueReusableCell(withReuseIdentifier: "Cell", for: indexPath) as! carCollectionSettingCollectionViewCell
cell.carName.text = carCategory[indexPath.row]
print("carcategoryIndex\(carCategory)")
cell.carImage.image = UIImage(named: carCategoryImage[indexPath.row])
cell.carMeters.text = carCategoryMeter[indexPath.row]
return cell
}
fileprivate var pageSize: CGSize {
let layout = self.carCollection.collectionViewLayout as! UPCarouselFlowLayout
var pageSize = layout.itemSize
if layout.scrollDirection == .horizontal {
pageSize.width += layout.minimumLineSpacing
} else {
pageSize.height += layout.minimumLineSpacing
}
return pageSize
}
func scrollViewDidEndDecelerating(_ scrollView: UIScrollView) {
let layout = carCollection.collectionViewLayout as! UPCarouselFlowLayout
let pageSide = (layout.scrollDirection == .horizontal) ? self.pageSize.width : self.pageSize.height
let offset = (layout.scrollDirection == .horizontal) ? scrollView.contentOffset.x : scrollView.contentOffset.y
currentPage = Int(floor((offset - pageSide / 2) / pageSide) + 1)
print("currentpage::::\(currentPage)")
}
fileprivate var currentPage: Int! {
didSet {
currentPage = self.currentCell
print("currentapge::::\(currentPage)")
let character = self.carCategory[self.currentPage!]
print("character::::\(character)")
}
}
func loadUserData(){
API.User.observeCurrentUser { (user) in
if self.userName.text != nil {
self.userName.text = user.username
print("username:::\(String(describing: user.username))")
}
if let photoUrlString = user.profileImageURL {
let photoUrl = URL(string: photoUrlString)
self.profileImage.sd_setImage(with: photoUrl)
}
if self.email.text != nil {
self.email.text = user.email
}
switch user.carCategory {
case "0":
self.carCategoryLabel?.text = "Compact"
self.carMetersLabel?.text = "3.5 - 4.5m"
self.carCategoryImageLabel?.image = UIImage(named: "compactCar")
self.currentCell = 0
print("currentCell:::\(String(describing: self.currentCell))")
self.carCollection.reloadData()
case "1":
self.carCategoryLabel?.text = "Small"
self.carMetersLabel?.text = "2.5 - 3.5m"
self.carCategoryImageLabel?.image = UIImage(named: "smallCar")
self.carCategoryLabel?.text = "1"
self.currentCell = 1
print("currentCell:::\(String(describing: self.currentCell))")
self.carCollection.reloadData()
case "2":
self.carCategoryLabel?.text = "Midsize"
self.carMetersLabel?.text = "4 - 5m"
self.carCategoryImageLabel?.image = UIImage(named: "mediumCar")
self.currentCell = 2
print("currentCell:::\(String(describing: self.currentCell))")
self.carCollection.reloadData()
case "3":
self.carCategoryLabel?.text = "Full"
self.carMetersLabel?.text = "5 - 5.5m"
self.carCategoryImageLabel?.image = UIImage(named: "fullCar")
self.currentCell = 3
print("currentCell:::\(String(describing: self.currentCell))")
self.carCollection.reloadData()
case "4":
self.carCategoryLabel?.text = "Van/Pick-up"
self.carMetersLabel?.text = "5.5 - 6.5m"
self.carCategoryImageLabel?.image = UIImage(named: "vanPickup")
self.currentCell = 4
print("currentCell:::\(String(describing: self.currentCell))")
self.carCollection.reloadData()
default:
self.carCategoryLabel?.text = ""
self.carMetersLabel?.text = ""
self.carCategoryImageLabel?.image = UIImage(named: "")
break
}
}
}//loaduserData
答案 0 :(得分:1)
下面的代码可能会帮助您解决此问题
// MARK: - Collectionview delegates
extension FaqcategoriesViewController : UICollectionViewDelegate, UICollectionViewDataSource , UICollectionViewDelegateFlowLayout{
func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
return (Global.shared.FAQsCategoriesList?.list.count)!
}
func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell {
let cell = collectionView.dequeueReusableCell(withReuseIdentifier: "faqcategoriesCollectioncell",
for: indexPath) as! FAQCategoryCollectionViewCell
cell.configure(data: (Global.shared.FAQsCategoriesList?.list[indexPath.row])!)
return cell
}
func collectionView(_ collectionView: UICollectionView, didSelectItemAt indexPath: IndexPath) {
let storyBoard = Utilities.getStoryboard(name: SBMEMBERSANDCOMMISSIONS)
let nextView = storyBoard.instantiateViewController(withIdentifier: "faq") as! FAQViewController
nextView.id = indexPath.row
self.navigationController?.pushViewController(nextView, animated: false)
}
func collectionView(_ collectionView: UICollectionView,
layout collectionViewLayout: UICollectionViewLayout,
sizeForItemAt indexPath: IndexPath) -> CGSize {
let collectionViewSize = collectionView.frame.size.width
print(self.view.frame.width)
print(collectionView.frame.size.width)
print( "width: \(collectionViewSize/2 - 20) height: \(collectionView.frame.size.height/3.3)")
return CGSize(width: collectionViewSize/2 - 5, height: collectionView.frame.size.height/3.3)
}
func collectionView(_ collectionView: UICollectionView,
layout collectionViewLayout: UICollectionViewLayout,
minimumInteritemSpacingForSectionAt section: Int) -> CGFloat {
return 1.0
}
func collectionView(_ collectionView: UICollectionView, layout
collectionViewLayout: UICollectionViewLayout,
minimumLineSpacingForSectionAt section: Int) -> CGFloat {
return 1.0
}
}
答案 1 :(得分:1)
这是完成此操作的方法:
override func viewDidLoad() {
super.viewDidLoad()
collectionView.selectItem(at: [0, currentCell], animated: false, scrollPosition: .centeredHorizontally)
}
当您加载viewController时,我假设您设置了currentCell?我看不到您原来的viewDidLoad()
或viewDidAppear()
函数。如果从先前的viewController实例化此viewController,则从那里设置currentCell。如果您选择使用此viewController,请在prepareForSegue
方法中进行设置。