Как вернуться к первой ячейке представления прокрутки из последней ячейки и как добавить кнопку в каждую ячейку в Swift 4? - PullRequest
0 голосов
/ 09 мая 2018

Я использовал представление прокрутки в своем проекте, которое выглядит как контроллер просмотра страниц, прокручивается с таймером и работает хорошо.Я хочу прокрутить представление, когда достигает последней ячейки прокрутки до первой ячейки из этой последней ячейки.вот мой код, который я использую для смены ячеек

    @objc func moveToNextPage (){

    let pageWidth:CGFloat = self.scrollView.frame.width
    let maxWidth:CGFloat = pageWidth * 4
    let contentOffset:CGFloat = self.scrollView.contentOffset.x

    var slideToX = contentOffset + pageWidth

    if  contentOffset + pageWidth == maxWidth
    {
        slideToX = 0
    }
    self.scrollView.scrollRectToVisible(CGRect(x:slideToX, y:0, width:pageWidth, height:self.scrollView.frame.height), animated: true)
}

еще одна вещь!Я хочу добавить кнопку на каждую страницу, но я не смог этого сделать, вот мой метод прокрутки

func addscrollV()
{

    scrollView.delegate = self
    var selectingItem = Int()
    for i in 0...(initials?.response.count)! - 1 {
        if ((initials.initInstamall?.response[i].type!)!) == "0" {
            selectingItem = i
            break
        }
    }

    for image in 0...(initials?.response[selectingItem].itemLists.count)! - 1 {
        let imageView = UIImageView()
        let placeHolderImage = UIImage(named : "ic_logo")
        let url = "http://www.example/\((initials?.response[selectingItem].itemLists[image].imagePath!)!)"
        let urls = URL(string: url)
        imageView.kf.setImage(with: urls , placeholder : placeHolderImage ,options:[.transition(ImageTransition.fade(1.0))])
        let xCoordinate = self.contentView.frame.width * CGFloat(image)
        contentWidth += self.contentView.frame.width
        scrollView.addSubview(imageView)
        imageView.frame = CGRect(x: xCoordinate , y: 0 , width: self.contentView.frame.width, height: self.contentView.frame.height)
        selectScrollImage.frame = CGRect(x: xCoordinate , y: 0 , width: self.contentView.frame.width, height: self.contentView.frame.height)
        selectScrollImage.tag = image
        selectScrollImage.addTarget(self, action: #selector
            (scrollImageSelected), for: UIControlEvents.touchUpInside)
        imageView.contentMode = .scaleAspectFill
        imageView.clipsToBounds = true
        scrollView.addSubview(selectScrollImage)
        imageView.addSubview(selectScrollImage)
        imageView.bringSubview(toFront: selectScrollImage)
        selectScrollImage.backgroundColor = UIColor.blue
    }

    scrollView.contentSize = CGSize(width: contentWidth, height: self.contentView.frame.height)
}
...