--- title: Product media UX guidelines description: About UX guidelines for including product media in your theme. source_url: html: >- https://shopify.dev/docs/storefronts/themes/product-merchandising/media/media-ux md: >- https://shopify.dev/docs/storefronts/themes/product-merchandising/media/media-ux.md --- ExpandOn this page * [Badges and buttons](https://shopify.dev/docs/storefronts/themes/product-merchandising/media/media-ux.md#badges-and-buttons) * [3D model viewers](https://shopify.dev/docs/storefronts/themes/product-merchandising/media/media-ux.md#3d-model-viewers) * [Video players](https://shopify.dev/docs/storefronts/themes/product-merchandising/media/media-ux.md#video-players) * [General behavior](https://shopify.dev/docs/storefronts/themes/product-merchandising/media/media-ux.md#general-behavior) * [Slideshows](https://shopify.dev/docs/storefronts/themes/product-merchandising/media/media-ux.md#slideshows) # Product media UX guidelines The following are the main user experience (UX), and user interface (UI), aspects to consider with product media: * [Badges and buttons](#badges-and-buttons) * [3D model viewers](#3d-model-viewers) * [Video players](#video-players) * [Slideshows](#slideshows) *** ## Badges and buttons Both video and 3D model media displays should have the following included in their display, with each associated element, respectively: * A **play** or **3D** icon badge on the media thumbnail * A **play** or **3D** icon button control on the featured media 3D model media displays should also include a [**View in your space** button](#the-view-in-your-space-button). For example: ![](https://shopify.dev/assets/assets/images/themes/product-media/badges-controls-example-C7r0EEgT.png) When adding these badges and buttons you should consider the following: * [The icons to use](#icons) * [Their placement and sizing](#badge-placement-and-sizing) * [Their styling](#styling) ### The 'View in your space' button When including the **View in your space** button, you should consider the following: * If the button is being placed on top of the media display, then you need to ensure that video and 3D controls aren't obstructed. * Only show the button for devices that support AR. Supporting devices will run iOS version 13 or higher, or Android version 9 or higher. * If a product's media includes a 3D model, and that media should be displayed, then the button should be visible regardless of the currently displayed media type. Additionally, if the product has more than one 3D model, then the button should open the currently visible model, or the first model if none are currently visible. * The button should include the 3D [icon](#icons). * The button should only be placed below the featured media. For example: ![](https://shopify.dev/assets/assets/images/themes/product-media/view-in-your-space-placement-BDj6ibJk.png) Tip To learn more about how to create a **View in your space** button, refer to [Support product media](https://shopify.dev/docs/storefronts/themes/product-merchandising/media/support-media#support-ar-functionality). ### Icons Click the button below to download an asset library that includes icons for video and 3D model displays. You should use the icons from this library, rather than create custom icons as they're industry standards that will help customers more easily identify the available interaction. [](https://shopify.dev/zip/shopify-product-media-assets.zip) [Download product media assets](https://shopify.dev/zip/shopify-product-media-assets.zip) The icons come in two different styles: * Rounded * Angular You should only use one style, and it should match your theme's style. ### Badge placement and sizing The placement, and sizing, of the display varies depending whether it's for a [thumbnail badge](#thumbnail-badge-placement-and-styling), or a [featured button control](#featured-button-control-placement-and-styling). #### Thumbnail badge Thumbnail badges should adhere to the following guidelines: * They shouldn't occupy more than 1/9th of the thumbnail display, or 1/6th for landscape thumbnails, and shouldn't be smaller than `20px x 20px`. For example: ![](https://shopify.dev/assets/assets/images/themes/product-media/thumbnail-badge-size-MBf0SvHJ.png) * They can be aligned in any corner of the thumbnail, however should be uniformly aligned. For example: ![](https://shopify.dev/assets/assets/images/themes/product-media/badge-alignment-BKeuEcGn.png) #### Featured button control Featured button controls should be a minimum of `60px x 60px`, and maximum of `90px x 90px`. ### Styling The styling of the badges and buttons should adhere to the following guidelines: * You should maintain the whitespace around the badge and button icons, as well as their proportions. For example: ![](https://shopify.dev/assets/assets/images/themes/product-media/icon-whitespace-Dd3fG8VK.png) * The background of both badges, and buttons, can be modified to match your theme style. For example, a circle, rounded corners, etc. For example: ![](https://shopify.dev/assets/assets/images/themes/product-media/background-modification-BLRUEJDG.png) * You should use existing colour settings to style the badges and buttons. There should be a high contrast between the background and the icon, as well as the media and the background, so settings for "Main background", "Heading", or "Text" generally give the best results. For example: ![](https://shopify.dev/assets/assets/images/themes/product-media/color-settings-Dh1kcAgQ.png) * The opacity of the badge elements should vary depending on the element. Refer to [Thumbnail badge opacity](#thumbnail-badge-opacity) and [Featured button control opacity](#featured-button-control-opacity) to learn more. In addition to the above, the **View in your space** button should either have no background color, or a very neutral color, so that it doesn't compete with primary and secondary calls to action. For example: ![](https://shopify.dev/assets/assets/images/themes/product-media/view-in-your-space-color-D-Si4Ffx.png) #### Thumbnail badge opacity The thumbnail badge elements should adhere to the following opacity guidelines: * The icon opacity should be 60%. * The badge background opacity should be 100%. * The badge background should have a border that is at least 5% opacity of the icon's colour. For example: ![](https://shopify.dev/assets/assets/images/themes/product-media/badge-opacity-Chq1YqCx.png) #### Featured button control opacity The featured badge elements should adhere to the following opacity guidelines: * The icon opacity should be 100%. * The icon should persist on hover to maintain visibility. * The badge background opacity should be a minimum of 75%. * The badge background should have a border that is at least 5% opacity of the icon's colour. For example: ![](https://shopify.dev/assets/assets/images/themes/product-media/button-opacity-DGV7A2Le.png) *** ## 3D model viewers There are the following aspects to consider with 3D model viewers: * [The general behavior](#general-behavior) * [Accessibility](#3d-model-viewer-accessibility) * [The display elements](#display-elements) * [Focus order](#focus-order) ### Accessibility You should consider the following accessibility guidelines: * 3D model content should default to inactive on page load as it can be unexpected, overwhelming, and distracting when defaulted to active. * 3D models should allow for panning with only the keyboard, in addition to mouse and swipe gestures. * Add dedicated button controls, with appropriate labels, to control the model positioning. * Ensure keyboard focus states are visible for sighted keyboard-only or voice dictation users. * Refrain from shifting keyboard focus when interacting with a button control so customers can navigate away when they're ready. * Allow for text descriptions of models for each stage view. * Announce the current state of the model via ARIA live status element when button controls are interacted with. * Test your implementation with a variety of assistive technologies. For example, keyboard alone, and multiple screen readers. ### Display elements 3D model viewers should have the following display elements: * [3D model viewer controls](#3d-model-viewer-controls) * [3D model viewer progress bar](#3d-model-viewer-progress-bar) #### 3D model viewer controls These controls should follow the [badge and button styling](#styling) suggestions, however [the icons](#icons) can be set to a minimum of 55% opacity. For example: ![](https://shopify.dev/assets/assets/images/themes/product-media/3d-model-styling-C-a9b7uM.png) These controls should be placed in the bottom right corner of the media element, either with even, or no padding: ![](https://shopify.dev/assets/assets/images/themes/product-media/3d-model-control-padding-wE1VwGL_.png) ![](https://shopify.dev/assets/assets/images/themes/product-media/3d-model-control-no-padding-DO6PPqmE.png) You should keep visual consistency among all UI elements, so the corners of the control display shouldn't be rounded unless the icons and buttons in the theme are also rounded. For example: ![](https://shopify.dev/assets/assets/images/themes/product-media/3d-model-control-rounded-Dxht7E0v.png) #### 3D model viewer progress bar The progress bar is to show the load progress of the model. Similar to the controls, the progress bar should following the [badge and button styling](#styling) practices, however it should have 100% opacity, and should be placed at the top of the media element. For example: ![](https://shopify.dev/assets/assets/images/themes/product-media/3d-model-progress-bar-C2Z5Ssom.png) ### Focus order In order to facilitate keyboard interaction, 3D model viewers should have a specific focus order on the related elements. There are two main states to consider: * [Inactive](#inactive) * [Active](#active) #### Inactive When the viewer is inactive, the focus order should be as follows: 1. Viewer controls #### Active When the viewer is active, the focus order should be as follows: 1. Viewer container 2. Zoom in 3. Zoom out 4. Fullscreen *** ## Video players There are the following aspects to consider with video players: * [The general behavior](#general-behavior) * [Accessibility](#video-player-accessibility) * [Styling and placement](#styling-and-placement) ### Accessibility * Video content should default to paused on page load as it can be unexpected, overwhelming, and distracting when defaulted to playing. * If a video plays on page load, it should be muted by default. * Test your implementation with a variety of assistive technologies. For example, keyboard alone, and multiple screen readers. ### Styling and placement In addition to the [badge and button styling](#styling) suggestions, video players should adhere to the following: * They should be placed at the bottom of the featured media, either with even, or no padding: ![](https://shopify.dev/assets/assets/images/themes/product-media/video-player-padding-BMP3mC9e.png) ![](https://shopify.dev/assets/assets/images/themes/product-media/video-player-no-padding-C57ZVcO0.png) * If the theme uses custom focus states, then you should maintain consistency. Otherwise, the default browser focus state should be used. * You should keep visual consistency among all UI elements, so the corners of the control display shouldn't be rounded unless the icons and buttons in the theme are also rounded. For example: ![](https://shopify.dev/assets/assets/images/themes/product-media/video-player-corners-D6vdRCs9.png) *** ## General behavior Note The following uses the terms "active" and "inactive". In the context of videos, this would be equivalent to "playing" and "paused". In general, video players and 3D model viewers should be set to inactive while advancing through media galleries as videos and models that aren't visible shouldn't be active. If more than one media element is displaying at a time, then all media should be inactive by default, requiring the customer to initiate activity. If only one media element is visible at once, then you should adhere to the following: * **Desktop** - The first media element on page load should be set to inactive, however as the media changes, the current media should automatically be set to active. * **Tablet/Mobile** - All media elements should default to inactive, requiring the customer to initiate activity. *** ## Slideshows If your theme uses a slideshow media gallery, then you shouldn't rely solely on swipe gestures for navigation as video players and 3D model viewers can interfere. For example: ![](https://shopify.dev/assets/assets/images/themes/product-media/slideshow-navigation-ClYjD0cp.png) *** * [Badges and buttons](https://shopify.dev/docs/storefronts/themes/product-merchandising/media/media-ux.md#badges-and-buttons) * [3D model viewers](https://shopify.dev/docs/storefronts/themes/product-merchandising/media/media-ux.md#3d-model-viewers) * [Video players](https://shopify.dev/docs/storefronts/themes/product-merchandising/media/media-ux.md#video-players) * [General behavior](https://shopify.dev/docs/storefronts/themes/product-merchandising/media/media-ux.md#general-behavior) * [Slideshows](https://shopify.dev/docs/storefronts/themes/product-merchandising/media/media-ux.md#slideshows)