VOD’s watermarking feature allows the adding of simple image or text watermarks, but cannot meet more sophisticated needs such as adding text-image watermarks or applying filters to watermarks. Given this, VOD has supported Scalable Vector Graphics (SVG) watermarks, allowing you to design text and image layout as you like, draw your own images, and apply filters, gradients, and other special effects.
Note:
- You can find on the internet different free, web-based SVG editors. Use them to draw the graphics you want and export them as XML files.
- Before getting the final XML code, you can manually fine-tune your image, for example, align element attributes or change font size, and check the result in an editor.
Note:
If you need to align different elements, we recommend that you make flexible use of the elements’ alignable attributes and check if the alignment is effective by changing the values of the elements, for example, placing images next to text, or reducing/increasing text length. For detailed instructions, see this SVG tutorial. An example is offered below.
Call the CreateWatermarkTemplate
API and specify parameters including the watermark coordinates and dimensions. After the creation, you get a watermark template ID.
For how to start a video processing task and get the result, see Video Processing Task System.
Take the ProcessMedia
API as an example. In Example2 Initiating a transcoding task, you should set WatermarkSet.N.Definition
to the template ID obtained in step 2 and, as an SVG watermark is used, pass the XML code obtained in step 1 in WatermarkSet.N.SvgContent
.
This section uses an example to guide you through the process of adding a complex watermark that contains an image and replaceable text.
A client wants to watermark videos and has the following requirements:
Below is the XML source code for the SVG watermark:
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1" width="1000px" height="1000px">
<defs>
<filter id="filter" x="0" y="0">
<feGaussianBlur stdDeviation="2"/>
<feOffset dx="0" dy="3"/>
</filter>
</defs>
<image id="img_watermark" xlink:href=""
x="74.4%" y="0px" height="185px" width="256px"/>
<text id="text_watermark_shadow" text-anchor="end" font-family="SimHei" font-style="Regular" font-size="50px"
x="100%" y="245px" style="opacity:1;" fill="black" filter="url(#filter)">@Tencent</text>
<text id="text_watermark" text-anchor="end" font-family="SimHei" font-style="Regular" font-size="50px"
x="100%" y="245px" fill="white">@Tencent</text>
</svg>
Result checking:
Figure 1: Transparent Background | Figure 2: White Background | Figure 3: Black Background |
---|---|---|
Parameter | Description | Attribute |
---|---|---|
<svg> |
Define the SVG canvas | width="1000px" height="1000px" : both height and are 1000 px. Just make sure that the canvas is large enough to include all the elements of the watermark. |
<filter id="filter"> |
Define the filter to be used | - |
<feGaussianBlur> |
Set the Gaussian blur filter | stdDeviation="2" |
<feOffset> |
Set the filter offset | dx="0" dy="3" : offset the filter by 3 px down. |
<image id="img_watermark"> |
Brand logo | xlink:href="data:image/png;base64,{Base64-encoded image data}" : reference a local image.height="185px" width="256px" : set the original aspect ratio.x="74.4%" y="0px" : as the logo is above the text, set the Y-axis offset to 0 px. Keep adjusting the X-axis offset until the expected result is achieved (x="74.4%" ). |
<text id="text_watermark_shadow"> |
Add a shadow to text | font-family="SimHei" font-style="Regular" font-size="50px" : set font and font size.text-anchor="end" : set the end of the text as its original position for alignment.x="100%" : set text-anchor and x to pin the last character of the text to the right of the canvas so as to adjust the position of the brand logo (x attribute of <image id="img_watermark"> ).style="opacity:1;": set the opacity.</li><li> fill="black": set the shadow-fill-color to black.</li><li> filter="url(#filter): apply the filter whose idis filter.</li><li> y="245px": set the Y-axis offset. The height of the brand logo is 185 px, and the font size 50 px, which is basically equivalent to the font height, so ymust not be smaller than 185+50=235. After ***testing***, the value is set to 245`. |
<text id="text_watermark"> |
Text | Most of this parameter’s attributes are the same as those of <text id="text_watermark_shadow"> , but it does not use a filter(without the filter attribute), and the text-fill-color is white (fill="white" ). |
@Tencent
with @Tencent is a kind person
to see if the result still meets the requirements.<text>
in the SVG code.https://vod.tencentcloudapi.com/?Action=CreateWatermarkTemplate
&Type=svg
&Name=Test
&CoordinateOrigin=TopRight
&XPos=2%
&YPos=5%
&SvgTemplate.Width=30S%
&SvgTemplate.Height=0px
&<Common request parameters>
Parameter description:
Parameter | Description |
---|---|
Type=svg | Set the watermark type to SVG. |
Name=Test | Set the name of the template (optional). |
CoordinateOrigin=TopRight | Pin the watermark to the top right of the video. |
XPos=2% | Set the distance between the watermark origin and the right border of videos to 2% of video width. |
YPos=5% | Set the distance between the watermark origin and the top border of videos to 5% of video height. |
SvgTemplate.Width=30S% | Set the watermark width to 30% of video width. |
SvgTemplate.Height=0px | The height of the watermark scales proportionally. |
Suppose the ID of the SVG watermark template created is 12345.
Initiates a video processing task:
https://vod.tencentcloudapi.com/?Action=ProcessMedia
&FileId=5285485487985271487
&MediaProcessTask.TranscodeTaskSet.0.Definition=30
&MediaProcessTask.TranscodeTaskSet.0.WatermarkSet.0.Definition=12345
&MediaProcessTask.TranscodeTaskSet.0.WatermarkSet.0.SvgContent={the XML code in step 1}
&<Common request parameters>
Contact us if you want other fonts supported.
Was this page helpful?