Make background color change during scroll

前端 未结 5 1890
太阳男子
太阳男子 2021-01-14 07:10

I have an onboarding section of my app with 4 pages the users scrolls through horizontally to get an idea of how to use the app (standard). I want the background color to tr

相关标签:
5条回答
  • 2021-01-14 07:40
        var currPage = 0
        let colors: [UIColor] = [.red, .blue, .green, .yellow, .purple, .orange]
    
        func scrollViewDidScroll(_ scrollView: UIScrollView) {
            // for horizontal scrolling
            let progress = scrollView.contentOffset.x / scrollView.bounds.width
            let page = Int(progress)
            if currPage != page { currPage = page }
            let nextPage = Int(progress + 1)
            let prog = 1 - (CGFloat(Int(progress + 1)) - progress)
            print("\(currPage) \(nextPage) \(prog)")
            if currPage >= 0 && currPage < colors.count && nextPage >= 0 && nextPage < colors.count {
                let interColor = colorBetween(col1: colors[currPage], col2: colors[nextPage], percent: prog)
                scrollView.backgroundColor = interColor.withAlphaComponent(0.5)
            }
        }
    
        // calculates intermediate color, percent should in between 0.0 - 1.0
        func colorBetween(col1: UIColor, col2: UIColor, percent: CGFloat) -> UIColor {
            let c1 = CIColor(color: col1)
            let c2 = CIColor(color: col2)
    
            let alpha = (c2.alpha - c1.alpha) * percent + c1.alpha
            let red = (c2.red - c1.red) * percent + c1.red
            let blue = (c2.blue - c1.blue) * percent + c1.blue
            let green = (c2.green - c1.green) * percent + c1.green
    
            return UIColor(red: red, green: green, blue: blue, alpha: alpha)
        }
    
    0 讨论(0)
  • 2021-01-14 07:43

    For anyone interested. This is the solution. I combined some answers I found on stack and adapted it to use 4 colors

    - (void)scrollViewDidScroll:(UIScrollView *)scrollView  {
    CGFloat pageWidth = self.scrollView.frame.size.width;
    float fractionalPage = self.scrollView.contentOffset.x / pageWidth;
    NSInteger page = lround(fractionalPage);
    self.pageControl.currentPage = page;
    
    // horizontal
    CGFloat maximumHorizontalOffset = scrollView.contentSize.width - CGRectGetWidth(scrollView.frame);
    CGFloat currentHorizontalOffset = scrollView.contentOffset.x;
    
    // percentages
    CGFloat percentageHorizontalOffset = currentHorizontalOffset / maximumHorizontalOffset;
    
    NSLog(@"content offfset: %f", percentageHorizontalOffset);
    
    if (percentageHorizontalOffset < 0.333333) {
        self.view.backgroundColor = [self fadeFromColor:self.colorArray[0] toColor:self.colorArray[1] withPercentage:percentageHorizontalOffset*3];
    } else if (percentageHorizontalOffset >= 0.333333 && percentageHorizontalOffset < 0.666667) {
        self.view.backgroundColor = [self fadeFromColor:self.colorArray[1] toColor:self.colorArray[2] withPercentage:(percentageHorizontalOffset-0.333333)*3];
    } else if (percentageHorizontalOffset >= 0.666667) {
        self.view.backgroundColor = [self fadeFromColor:self.colorArray[2] toColor:self.colorArray[3] withPercentage:(percentageHorizontalOffset-0.666667)*3];
    }
    }
    
    - (UIColor *)fadeFromColor:(UIColor *)fromColor toColor:(UIColor *)toColor withPercentage:(CGFloat)percentage
    {
        // get the RGBA values from the colours
    CGFloat fromRed, fromGreen, fromBlue, fromAlpha;
    [fromColor getRed:&fromRed green:&fromGreen blue:&fromBlue alpha:&fromAlpha];
    
    CGFloat toRed, toGreen, toBlue, toAlpha;
    [toColor getRed:&toRed green:&toGreen blue:&toBlue alpha:&toAlpha];
    
    //calculate the actual RGBA values of the fade colour
    CGFloat red = (toRed - fromRed) * percentage + fromRed;
    CGFloat green = (toGreen - fromGreen) * percentage + fromGreen;
    CGFloat blue = (toBlue - fromBlue) * percentage + fromBlue;
    CGFloat alpha = (toAlpha - fromAlpha) * percentage + fromAlpha;
    
    // return the fade colour
    return [UIColor colorWithRed:red green:green blue:blue alpha:alpha];
    }    
    
    0 讨论(0)
  • 2021-01-14 07:51

    To enable paging in scrollview you have to enable the paging property of scrollview first from attribute inspector.

    As per your requirement you have 4 pages. so your scrollview content size will be like scrollviewWidth * 4

    Put this code in viewDidLoad

    [self.scrollVw setContentSize:CGSizeMake(self.scrollVw.frame.size.width * 4,0)];
    

    Then take an array to store color values something like below.

     arrColor = [[NSMutableArray alloc]init];
    
     [arrColor addObject:[UIColor colorWithRed:(241.0f/255.0f) green:(170.0f/255.0f) blue:(170.0f/255.0f) alpha:1.0f]];
    
     [arrColor addObject:[UIColor colorWithRed:(170.0f/255.0f) green:(201.0f/255.0f) blue:(241/255.0f) alpha:1.0f]];
     [arrColor addObject:[UIColor colorWithRed:(188.0f/255.0f) green:(170.0f/255.0f) blue:(241.0f/255.0f) alpha:1.0f]];
     [arrColor addObject:[UIColor colorWithRed:(241.0f/255.0f) green:(199.0f/255.0f) blue:(170.0f/255.0f) alpha:1.0f]];
    
     [self.scrollVw setBackgroundColor:[arrColor objectAtIndex:0]]; //this is for first time to display first color when scrollview is load. you can avoid this by directly setting color from UI
    

    Scrollview delegate method code.

    -(void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView
    {
     [self.scrollVw setBackgroundColor:[arrColor objectAtIndex:currentPage]]; //currentPage overhere is simple int variable which i had incremented and decremented its values based on current offset of scrollview. Also currentPage value should not be > 4.
    }
    

    Hope this will help you out. Happy coding :)

    0 讨论(0)
  • 2021-01-14 07:52

    You can use a delegate based on your need. If you when to change the background colour simultaneously when when scrolling you should use scrollViewDidScroll method where you can get the contentOffSet dynamically and change the background colour. If you wants it after completing the scroll you can use as @Chetan said

    0 讨论(0)
  • 2021-01-14 08:00

    Set scroll view delegate and use below method

    //This method is called when scroll view ends scrolling
    - (void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView
    {
        [self updateColor];
    }
    
    0 讨论(0)
提交回复
热议问题