gpt4 book ai didi

ios - 如何在 pagecontrol 的 ScrollView 中将图像应用到 imageView。

转载 作者:可可西里 更新时间:2023-11-01 06:12:39 29 4
gpt4 key购买 nike

我在使用页面控件的 scrollView 中有一个 imageView 现在我想将不同的图像显示到同一个 imageView。页面控件 ScrollView 自动滚动。它显示第一张图像但不显示其他图像。我使用的代码如下:

// -----------------------------------------------------------------------------
// loadScrollViewWithPage

- (void)loadScrollViewWithPage:(int)page
{
if ( page < 0 ) return;
if ( page >= kNumberOfPages ) return;
}

// -----------------------------------------------------------------------------
// scrollViewDidScroll

- (void)scrollViewDidScroll:(UIScrollView *)sender
{
if ( pageControlUsed )
{
// do nothing - the scroll was initiated from the page control, not the user dragging
return;
}

// Switch the indicator when more than 50% of the previous/next page is visible
CGFloat pageWidth = mScrollView.frame.size.width;
int page = floor((mScrollView.contentOffset.x - pageWidth / 2) / pageWidth) + 1;
mPageControl.currentPage = page;

// load the visible page and the page on either side of it (to avoid flashes when the user starts scrolling)
[self loadScrollViewWithPage:page - 1];
[self loadScrollViewWithPage:page];
[self loadScrollViewWithPage:page + 1];
}

// -----------------------------------------------------------------------------
// scrollViewWillBeginDragging
// At the begin of scroll dragging, reset the boolean used when scrolls originate from the UIPageControl

- (void)scrollViewWillBeginDragging:(UIScrollView *)scrollView
{
pageControlUsed = NO;
[mTimer invalidate];
}

// ----------------------------------------------------------------
// scrollViewDidEndDecelerating
// At the end of scroll animation, reset the boolean used when scrolls originate from the UIPageControl

- (void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView
{
pageControlUsed = NO;
}

- (id)initWithNibName:(NSString *)nibNameOrNil
bundle:(NSBundle *)nibBundleOrNil
tag:(NSInteger)inTag
noOfPoses:(NSInteger)inNoOfPoses
imageName:(NSArray *)inImageNameArr
{
self = [super initWithNibName:@"TIphonePosesDetailView" bundle:nibBundleOrNil];
if (self)
{
mTag = inTag;// tag of the image taken from previous controller
mNoOfPoses = inNoOfPoses;
kNumberOfPages = mNoOfPoses;
if ( inImageNameArr != nil )
{
mImgNameArr = [inImageNameArr retain];// contains images
}
NSLog(@"Image Array%@",mImgNameArr);

}
return self;
}

// -----------------------------------------------------------------------------
// viewDidLoad

- (void)viewDidLoad
{
[super viewDidLoad];

mScrollView.delegate = self;
mScrollView.showsHorizontalScrollIndicator = FALSE;
[mScrollView setContentSize:CGSizeMake(1000, 464)];
[mScrollView setFrame:CGRectMake(45, 69, 240, 226)];

// Setting frame
mStartPoint = CGPointMake(0, 0);
[mPrevImgView setImage:[self getImageFromName:[mImgNameArr objectAtIndex:mTag]]];
[mPrevImgView setFrame:CGRectMake(mStartPoint.x, mStartPoint.y, 240, 226)];

// a page is the width of the scroll view
mScrollView.pagingEnabled = YES;
mScrollView.contentSize = CGSizeMake(mScrollView.frame.size.width * kNumberOfPages, mScrollView.frame.size.height);
mScrollView.showsHorizontalScrollIndicator = NO;
mScrollView.showsVerticalScrollIndicator = NO;
mScrollView.scrollsToTop = NO;
mPageControl.numberOfPages = kNumberOfPages;
mPageControl.currentPage = 0;

// pages are created on demand
// load the visible page
// load the page on either side to avoid flashes when the user starts scrolling
[self loadScrollViewWithPage:0];
[self loadScrollViewWithPage:1];
mTimer = [[NSTimer alloc] initWithFireDate:[NSDate dateWithTimeIntervalSinceNow:2] interval:2.0 target:self selector:@selector(scrollAutomatically:) userInfo:nil repeats:YES];
[[NSRunLoop currentRunLoop] addTimer:mTimer forMode:NSDefaultRunLoopMode];
}

// -----------------------------------------------------------------------------
// scrollAutomatically

- (void)scrollAutomatically:(id)sender
{
if ( mCurrentPage < [mPageControl numberOfPages] )
{
mCurrentPage ++;
mTag ++;
[mPrevImgView setImage:[self getImageFromName:[mImgNameArr objectAtIndex:mTag]]];
mStartPoint.x += 250 + mPrevImgView.frame.size.width;
}
else
{
mCurrentPage = 0;
}

[self loadScrollViewWithPage:mCurrentPage - 1];
[self loadScrollViewWithPage:mCurrentPage];
[self loadScrollViewWithPage:mCurrentPage + 1];

// update the scroll view to the appropriate page
CGRect frame = mScrollView.frame;
frame.origin.x = frame.size.width * mCurrentPage;
frame.origin.y = 0;
[mScrollView scrollRectToVisible:frame animated:YES];
}

最佳答案

当您调用此方法时,通过动态固定坐标来加载所有图像。您可以使用缓存来加载图像,这将节省加载时间并可用 here

- (void)loadScrollViewWithPage:(int)page 
{
if ( page < 0 ) return;
if ( page >= kNumberOfPages ) return;
}

但加载 View 时只显示第一页

之后,ScrollView 委托(delegate)方法将用于移动您的页面控件....

但停止调用这些

 [self loadScrollViewWithPage:page - 1];
[self loadScrollViewWithPage:page];
[self loadScrollViewWithPage:page + 1];

它会重复创建图像

关于ios - 如何在 pagecontrol 的 ScrollView 中将图像应用到 imageView。,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6262135/

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