Repeating background image in native iPhone app

2019-01-20 22:11发布

Short of putting a UIWebView as the back-most layer in my nib file, how can I add a repeating background image to an iPhone app (like the corduroy look in the background of a grouped UITableView)?

Do I need to create an image that's the size of the iPhone's screen and manually repeat it using copy and paste?

4条回答
对你真心纯属浪费
2楼-- · 2019-01-20 22:19

You should have a look at the QuartzDemo iPhone example code from Apple, specifically QuartzImageDrawing.m. Should use the following method call.

CGContextDrawTiledImage
查看更多
Luminary・发光体
3楼-- · 2019-01-20 22:22

You can even have an animated tiled background images that move. :D

Apps Amuck has a simple tutorial that show you how to do this on their site.

31 Days of iPhone Apps - Day 16: World Tour

查看更多
一夜七次
4楼-- · 2019-01-20 22:29

You should use colorWithPatternImage

查看更多
5楼-- · 2019-01-20 22:35

Apparently a UIColor is not necessarily a single color, but can be a pattern as well. Confusingly, this is not supported in Interface Builder.

Instead you set the backgroundColor of the view (say, in -viewDidLoad) with the convenience method +colorWithPatternImage: and pass it a UI Image. For Instance:

- (void)viewDidLoad {
    [super viewDidLoad];
    self.view.backgroundColor = [UIColor colorWithPatternImage: [UIImage imageNamed:@"gingham.png"]]; 
}

Of course, don't forget to add the image file to your application bundle.

There are also some built-in background pattern "colors":

  • groupTableViewBackgroundColor
  • viewFlipsideBackgroundColor

Because the are used globally across all iPhone apps, you incur the double-edged sword of an OS update updating the look and feel of your application (giving it a fresh new look that may or may not work right).

For instance:

- (void)viewDidLoad {
    [super viewDidLoad];
    self.view.backgroundColor = [UIColor groupTableViewBackgroundColor]; 
}
查看更多
登录 后发表回答