Any serious video publisher either already supports iPad and iPhone or needs to think hard about adding support. For some major publishers, iPad delivery represents a third of total video views or more.
Encoding for iOS is a little tricky, though. These devices have gone through several generations of technical capabilities, and the ideal video settings for the iPhone 4 are not ideal for the iPhone 3GS or for the iPad.
Fortunately, with just a few encoding profiles, you can stream high quality video to every iOS device, from the first iPhone to the iPad 2, and even prepare for future generations of mobile hardware.
General Settings
Like most video today, use h.264 video and AAC audio when targeting iOS.
On the audio side, consider using HE-AAC at <64kbps, for App Store compliance. HE-AAC sounds reasonably good at these bitrates, even for complex audio.
On the video side, use multiple profiles to target each device. The iPhone 3GS and earlier only supports the h.264 Baseline profile, level 3.0 (and some support a more constrained version than that), whereas newer devices support the Main and High profiles.
For the best user experience, HTTP Live Streaming (HLS) is a must. Apple requires it of any video app in the App Store that plays content longer than 10 minutes, and it is the only true streaming format supported by iOS. HLS is also being adopted by Android (version 3+), Roku, and a range of other destinations.
General Approach
| Resolution | Profile | Bitrate | @ 16:9 | @ 4:3 | Audio | Comments | 
|---|---|---|---|---|---|---|
| 1024×768 | [email protected] | 2Mbps | 1024×576 | 1024×768 | 56kbps HE-AAC | |
| 960×640 | [email protected] | 1.5Mbps | 960×540 | 854×640 | 56kbps HE-AAC | |
| 640×432 | [email protected] | 1Mbps | 640×360 | 576×432 | 56kbps HE-AAC | |
| 480×320 | [email protected] | 600kbps | 480×272 | 426×320 | 56kbps HE-AAC | |
| 400×288 | [email protected] | 400kbps | 400×224 | 384×288 | 56kbps HE-AAC | |
| 400×288 | [email protected] | 200kbps | 400×224 | 384×288 | 56kbps HE-AAC | decimate frame rate | 
| N/A (Audio Only) | 56kbps HE-AAC | 
Why these recommendations?
- These are just recommendations. Different resolutions and bitrates are perfectly valid, and may actually be preferable in some circumstances. For example, extremely complex content may warrant higher bitrates.
- 720p is the largest video playable on iPad 1 and iPhone 4, and iPad 2/iPhone 4S play anything up to 1080p. But since the native display is only 1024 pixels wide, going all the way to 720p or 1080p isn’t critical. Unless, of course, you want to reuse a video somewhere else—720p is a great resolution for fullscreen web playback, and 1080p is entirely appropriate for Connected TVs. Future iPads are rumored to have 4x the resolution of the current iPad, so consider adding 720p for future-proofing.
- The h.264 profile is important. The iPad 1 and iPhone 4 both support the Main profile. The iPad 2/iPhone 4S support the High profile, which is marginally better than Main, but given the number of iPad 1 devices in the world, it is probably better to stick to Main profile. For truly optimal device targeting, encode to both Main and High.
- These six resolutions and bitrates provide reasonably good coverage of varying bandwidth. You could certainly do more, so add or subtract resolutions and profiles as desired.
- Legacy iPhone/iPod Touch users will have three streams available to them, including a reasonably high quality 480×320 video (the screen resolution of these devices). Users of the iPad and iPhone 4 will be able to make use of all six streams.
- The resolution scaler on the iPad is pretty good, so videos that are rescaled will generally look good.
- As much as possible, these settings allow for resolution dimensions divisible by 16. This makes for more efficient compression. The efficiency gains are small, especially at high resolutions, but at lower resolutions they start to make a difference.
- Be sure to keep the audio identical across each video. If the audio specifications change from one version to another, the user may hear pops and clicks during playback when switching streams.
Other Settings
- Set the speed based on desired turnaround time. For these recommendations, we’re going to use Speed 2, which improves compression a bit over the baseline but is still reasonably fast.
- Ensure that each segment is roughly the same size by using a peak bitrate\_capof 150% of the target bitrate, but within a longbuffer\_size(e.g., five seconds, or 5x thebitrate\_cap).
- Brightcove automatically chooses proper keyframe placement when you set the type to “segmented.” If you’re encoding to MP4 for separate segmenting to HLS, set forced\_keyframe\_rateto “0.2” or “0.1” (for five or 10 second keyframe intervals, respectively).
- If you can accept slightly unpredictable bitrates, add quality to the mix, and change video\_bitratetomax\_video\_bitrateto optimize for file size. The encoder will use the max bitrate when needed, and will use a lower bitrate when it can achieve the desired quality with fewer bits.
- Set the max\_frame\_rateto 30 and themax\_audio\_sample\_rateto 48000.
- The first generation if iOS devices only allow one h.264 reference\_frame, so enable this on the Baseline streams for max compatibility.
 
  
  
 