gpt4 book ai didi

iOS 如何在更改页面时动态更改 PageControl 颜色?

转载 作者:塔克拉玛干 更新时间:2023-11-02 20:01:16 27 4
gpt4 key购买 nike

我有 3 个页面 - A ViewController、B ViewController 和 C ViewController。

还有一个 PageViewController 控制水平滚动。

PagesViewController.m

 - (void)viewDidLoad {
[super viewDidLoad];
self.aVC = [self.storyboard
instantiateViewControllerWithIdentifier:@"AViewController"];
self.bVC = [self.storyboard
instantiateViewControllerWithIdentifier:@"BViewController"];
self.cVC = [self.storyboard
instantiateViewControllerWithIdentifier:@"CViewController"];

self.delegate = self;
self.dataSource = self;

self.allViewControllers = @[self.aVC,self.bVC
,self.cVC];

[self setViewControllers:@[self.aVC]
direction:UIPageViewControllerNavigationDirectionForward
animated:NO completion:nil];

_pageControl = [UIPageControl appearance];

}

我想在滚动到 A VC 、 B VC 和 C VC 时更改 _pageControl 颜色。

所以我把代码放在

 -(NSInteger)presentationIndexForPageViewController:
(UIPageViewController *)pageViewController
{

NSLog(@"%@",pageViewController.viewControllers[0]);
for( int i = 0 ; i< self.allViewControllers.count ; i++ )
{
if( pageViewController.viewControllers[0] == self.allViewControllers[i])
{
if( i ==0 )
{
_pageControl.backgroundColor = [UIColor greenColor];
}
else if( i ==1)
{
_pageControl.backgroundColor = [UIColor redColor];
}
else
{
_pageControl.backgroundColor = [UIColor clearColor];
}
NSLog(@"return index:%d", i);
return i;
}
}

return 0;
}

但是页面控件没有改变颜色。

我尝试将代码放在 viewDidLoad 中,它会在所有 View Controller 处改变颜色。

 _pageControl.backgroundColor = [UIColor redColor];

但是现在我想在滚动到不同的 UIViewController 时更改 pageControl 颜色。

我该怎么办?或如何刷新 pageControl 颜色?

因为现在颜色总是黑色。

我向其他人提供有关 PageViewController 的委托(delegate)方法:

 -(UIViewController*) pageViewController:(UIPageViewController *)pageViewController viewControllerBeforeViewController:(UIViewController *)viewController

{

NSUInteger currentIndex = [self.allViewControllers indexOfObject:viewController];
if( currentIndex == 0 )
{
return nil;
}
currentIndex--;


return [self.allViewControllers objectAtIndex:currentIndex];
}

-(UIViewController *) pageViewController:(UIPageViewController *)pageViewController viewControllerAfterViewController:(UIViewController *)viewController
{
NSUInteger currentIndex = [self.allViewControllers indexOfObject:viewController];


NSLog(@"after currentIndex:%ld",currentIndex);
currentIndex++;

if( currentIndex == [self.allViewControllers count])
{
return nil;
}

return [self.allViewControllers objectAtIndex:currentIndex];
}


-(NSInteger)presentationCountForPageViewController:
(UIPageViewController *)pageViewController
{
return self.allViewControllers.count;
}

最佳答案

在你的 viewDidLoad: 方法中,

代替:

_pageControl = [UIPageControl appearance];

使用:

NSArray *subviews = self.view.subviews;
_pageControl = nil;
for (int i=0; i<[subviews count]; i++) {
if ([[subviews objectAtIndex:i] isKindOfClass:[UIPageControl class]]) {
_pageControl = (UIPageControl *)[subviews objectAtIndex:i];
}
}

=====

编辑:

对于您的特定项目,您没有获得 _pageControl(它返回 nil),因为 Storyboard 尚未完成在 viewDidLoad 中实例化您的 View Controller 。我认为它需要进入 viewDidAppear:animated,但这也不起作用,所以我通过延迟请求它 0.2 毫秒来作弊。

在你的 viewDidLoad 中,把这个:

[self performSelector:@selector(findPageControl) withObject:nil afterDelay:0.2f];

然后,添加这个方法:

- (void) findPageControl {
NSArray *subviews = self.view.subviews;
_pageControl = nil;
for (int i=0; i<[subviews count]; i++) {
if ([[subviews objectAtIndex:i] isKindOfClass:[UIPageControl class]]) {
_pageControl = (UIPageControl *)[subviews objectAtIndex:i];
}
}
[self changePage:0];
}

在您的 viewControllerAfterViewController 方法中,我在 NSUInteger currentIndex = 行之后添加了这个:

[self changePage:currentIndex];

这似乎使它起作用了。现在,您可以在 changePage 方法中添加动画,使转换看起来更平滑一些。

此外,在调试时,这就是我所做的:

我在 _pageControl = 行上添加了一个断点,这样我就可以检查并查看发生了什么。当我看到它为零时,这告诉我它没有正确设置。查看调试区域,您可以看到我打印出的内容(“po”)以了解存在哪些值——以及为什么没有 UIPageControl。如果您在我上面列出的更改之后执行相同的操作,您会看到现在已找到并设置它。

enter image description here

关于iOS 如何在更改页面时动态更改 PageControl 颜色?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28844505/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com