SharePoint 2013: Programmatically Generate EmbedCode for Uploaded Video
In this article I will post a code example to generate a SharePoint embedCode for the uploaded videos. In SharePoint you can add three different types of video files
- Upload video
- Provide link to the video
- Using EmbedCode
If you use the third option, the field VideoSetEmbedCode will contain the embed iframe of the video, but if you use the first option, the Field VideoSetEmbedCode will remain empty, although you can get the embed code any time manually as you play the video.
The question is how to get the EmbedCode Programatically? Let us first check the format of the automatically generated embed code by SharePoint.
It's simply Iframe with Src attribute with different set of parameters
- Player Url "/_layouts/15/videoembedplayer.aspx"
- Some Parameter like:
- Site: Site ID
- Web: Web ID
- Folder: Actually this is the current video Item ID, not the parent Folder ID (Don't know why it's named as Folder)
- img: Thumbnail image of the Video
- lowner: if it equals 1 the owner name will be displayed
- lTitle: if it equals 1 the title will be displayed
The question is how to construct this from the VideoItem. The code below will do the trick
/// <summary>
/// the below method constructs the video embed code
/// </summary>
/// <param name="videoItem"></param>
/// <returns></returns>
public static string GetEmbedCode(SPListItem videoItem)
{
if(videoItem.Fields.ContainsField(Constants.FieldNames.VideoSetEmbedCode)&&videoItem[Constants.FieldNames.VideoSetEmbedCode]!=null)
{
return videoItem[Constants.FieldNames.VideoSetEmbedCode].ToString().Replace("'", "\\'");
}
string width = videoItem[Constants.FieldNames.VideoWidthInPixels] == null ? string.Empty : "width=\\'" + videoItem[Constants.FieldNames.VideoWidthInPixels] + "\\'";
string height = videoItem[Constants.FieldNames.VideoHeightInPixels] == null ? string.Empty : "height=\\'" + videoItem[Constants.FieldNames.VideoHeightInPixels] + "\\'";
string playerUrl = SPContext.Current.Site.Url + Constants.PlayerRelativeUrl;
string site = videoItem.Web.Site.ID.ToString().Replace("{", "").Replace("}", "");
string web = videoItem.Web.ID.ToString().Replace("{", "").Replace("}", "");
string folder=videoItem.Folder.UniqueId.ToString().Replace("{", "").Replace("}", "");
string image = videoItem[Constants.FieldNames.EncodedAbsThumbnailUrl] == null ? string.Empty : "img="+videoItem[Constants.FieldNames.EncodedAbsThumbnailUrl].ToString();
string embedCode = string.Format(@"<iframe type=\'text/html\' {0} {1} src=\'{2}?site={3}&web={4}&folder={5}&{6}&title=1&lHome=1&lOwner=1\'></iframe>",
width, height, playerUrl, site, web, folder, image);
return embedCode;
}
It first checks if the VideoSetEmbedCode is not empty, then if it's empty, it constructs the EmbedCode in the same manner SharePoint does.