Video ads
Serve video ads through Unity Exchange to ensure quality and performance.
Read time 5 minutesLast updated 2 months ago
Video Ad Serving Template (VAST) is a universal XML schema for serving ads to digital video players. Unity supports VAST 4.0 (standards developed and maintained by the Internet Advertising Bureau (IAB)), and is backward compatible with 2.0 (with the exception of certain features). The Unity SDK parses VAST XML to retrieve video media files and tracking URLs. Ensure that you follow these requirements:
- VAST must contain all of the required elements to render the video ad. For more information, refer to section 3.4 of the VAST guidelines.<InLine>
- Supported types include<MediaFile>, andvideo/mp4. They should includevideo/webm,bitrate,delivery, andwidthattributes. For more information, refer to section 3.9 of the VAST guidelines.height
- Video duration must be between 5 and 30 seconds.
- You can wrap VAST tags up to five times.
- Companions must be shown full-screen after the initial video ad is finished or skipped.
- All HTML markup must reference externally-hosted assets with an absolute URL path that contains and a domain. Pointing to assets fromhttps://or a relative URL path does not work.file://
- Max video file size is 20 MB.
- On WIFI connections, the video player will choose a file between 5 and 10 MB.
- On cellular connections, the video player will choose a file between 0.5 and 3 MB.
- Include video sizes for portrait and landscape modes whenever possible.
Skippable video ads
Publishers control whether the user can skip video ads in their app. Most skippable ads require the user to watch for a fixed number of seconds (determined by the publisher) before allowing them to skip to the end card. Because most skippable inventory allows the user to skip to the end card, Unity highly recommends including one with your video demand. Reach out to your partner manager to learn more about skippable and non-skippable inventory.Video controls
Unity's video controls overlay will fade into view while the video is playing. Users can hide or show it again by tapping the screen. The overlay includes a progress bar at the bottom of the screen, a privacy icon, and the call to action (CTA). It might include a close button in the top-right corner or a skip icon in the top-left corner.Video Click Support
A VAST tag must contain a single video click-through in the<ClickThrough><ClickTracking>- A click-through URL should use ,https://,market://, oritunes://prefixes on respective platforms.itms://
- Unity strongly recommends server-side redirects instead of lengthy appended URLs.
- Unity does not support click-to-call ads that use the prefix.tel://
- Click wrappers can contain additional click tracking.
Video CTAs
During video playback, a call to action (CTA) button appears on the bottom-right of the screen. A user must tap the button to trigger click-through events and open the<ClickThrough>

CTA icons
VAST 3.0 and higher supports the use of icons. The Unity video player displays a square icon alongside the "Install Now" button during video playback for bid responses that include a bundle ID. You can nest a custom icon in the VAST tag. For more information, refer to section 3.11 of the VAST guidelines. Icons should represent the advertised app. Unity does not support displaying any other icons over the video. Ensure that you follow these icon requirements:- Icons should be a image, with<StaticResource>,.png, or.jpgextensions..jpeg
- Icons will be displayed as squares, at 25 x 25 pixels.
- Unity does not support icon duration and functionality.<IconClickThrough>
All companions should include a<Icons> <Icon width="25" height="25"> <StaticResource creativeType="image/png"> <![CDATA[ https://Unity.com/DSP/square_icon_name ]]> </StaticResource> </Icon> </Icons>
heightwidth- The minimum square width/height is 200 pixels.
- The minimum landscape width/height is 480 x 320 pixels.
- The minimum portrait width/height is 320 x 480 pixels.
Companion ads
VAST companions appear as a full-screen end card after the video has finished playing. The recommended best practice is to use companions to maximize click-through. Most publishers allow skipping to end cards, so even skippable inventory will show an end card before the user can exit the ad experience.Companion click support
While an end card is displayed, the user can tap anywhere on the screen to trigger<CompanionClickTracking><CompanionClickThrough>End card resource types
| Type | Description | Notes | 
|---|---|---|
|  | HTML markup. | 
 | 
|  | An asset to be displayed in an  | 
 | 
Supported VAST 4.x macros
The following list details the VAST 4.x macros that Unity supports if they are provided in the tracking URL:- [ERRORCODE]- Refer to Error codes.
 
- [OMIDPARTNER]- An identifier of the OM SDK integration.
- This is the same as the andnameparameters of theversionStringobject.OMIDPartner
 
- [REASON]- The reason code for not executing verification.
 
- [TIMESTAMP]- (time stamp)
 
- [IFA]- A resettable advertising ID from a device-specific advertising ID scheme, such as Apple's ID for Advertisers or Android's Advertising ID, in UUID format or based on the IAB documentation on Guidelines For Identifier For Advertising On OTT Platforms.
 
- [IFATYPE]- A string value that indicates the type of IFA included in the macro.[IFA]
 
- A string value that indicates the type of IFA included in the 
- [APIFRAMEWORKS]- A list of frameworks supported by the player.
- Values are defined in the AdCOM 1.0 API Frameworks list.
 
- [APPBUNDLE(required)]- For app ads, a platform-specific application identifier, bundle, or package name. This identifier cannot be an app store ID, such as the Apple App Store ID.
- Where required and applicable, but unknown or unavailable, set to -1 or -2, as described in section 6.1 of the IAB documentation on VAST 4.x Macros.
- When required and not applicable (such as in an app), set to 0.
 
 
- For app ads, a platform-specific application identifier, bundle, or package name. This identifier cannot be an app store ID, such as the Apple App Store ID.
Troubleshooting
Low impressions
If you experience a high win rate but receive few impressions for a particular video campaign or creative, consider the following:| Cause | Suggested action | 
|---|---|
| The wrapped VAST tag points to a  | Check that the campaign is live. A media file might show up to two hours after it is received. | 
| Video file size too large | Provide at least one media file that is less than 20 MB. | 
| A platform or mobile browser is unable to play the media file. | Verify that media file and tracking URLs are secure. Include a file extension at the end of the URL such as  | 
Click-through URLs
If a video click-through URL has a forward slash (/+| Character | UTF-8 code | 
|---|---|
|  |  | 
|  |  | 
https://domain.com/anything_here_is_fine?this_is_a/query+stringhttps://domain.com/anything_here_is_fine?this_is_a%2Fquery%2BstringError codes
Unity sends VAST errors to the VAST tag's<Error>[ERRORCODE]| Code | Description | 
|---|---|
|  | XML parsing error. | 
|  | VAST schema validation error. | 
|  | VAST version unsupported. | 
|  | VAST format unsupported. | 
|  | Video duration is too long or is not formatted as  | 
|  | Wrapper error. | 
|  | A  | 
|  | Max wrapper limit (five) exceeded. | 
|  | No  | 
|  | Supported media file not found. | 
|  | Media file URI timed out. | 
|  | Unsupported media file. | 
|  | Media file URI is not supported on iOS. | 
|  | No click-through URL. | 
|  | General companion ad error. | 
|  | Unsupported companion ad size. | 
|  | Unable to display companion ad. | 
|  | Unable to fetch companion ad resource. | 
|  | Valid companion ad resource URL not found. | 
|  | Companion ad does not contain a valid click-through URL. | 
|  | Undefined error. | 
|  | VAST XML content contains an invalid URL. | 
|  | Unknown error. |