1.1.956 • Published 3 years ago

video-template v1.1.956

Weekly downloads
-
License
ISC
Repository
-
Last release
3 years ago

Video Template

Template model describing video structure

Installing

$ npm install video-template

Example

parse template

const Template = require("video-template").Template;
const template = Template.parse("...XML Content...");
template.toXML(true);  //export pretty XML

build template

const { Template, Scene, elements: { Text } } = require("video-template");
const template = new Template({ width: 1920, height: 1080, aspectRatio: "16:9" });
const scene = new Scene({ width: 1920, height: 1080, duration: 5000 });
const text = new Text({ value: "Hello World" });
scene.appendChild(text);
template.appendChild(scene);
template.toXML(true);  //export pretty XML
JSON.stringify(template);  //export JSON

compile template

Add the compile attribute to the template tag.

<template ... compile>
const Template = require("video-template").Template;
const template = Template.parse("...Raw XML Content...");
template.toXML(true);  //export compiled pretty XML

raw xml:

<?xml version="1.0"?>
<data>
    <base>/files/</base>
    <name>Test Video</name>
    <mode>scene</mode>
    <width>1080</width>
    <height>1920</height>
    <aspectRatio>9:16</aspectRatio>
    <fps>60</fps>
    <date>2022-03-02</date>
    <text>Hello World</text>
</data>
<vars>

</vars>
<template name="{{name}}" mode="{{mode}}" poster="{{base}}cover.png" width="{{width}}" height="{{height}}" aspectRatio="{{aspectRatio}}" fps="{{fps}}" compile>
    <audio src="{{base}}audios/bgm.mp3" volume="0.2" loop="true"/>
    <scene width="{{width}}" height="{{height}}" duration="5000" transition-type="wipeLeft" transition-duration="300" for="{{2}}">
        <video x="0" y="0" width="{{width}}" height="{{height}}" src="{{base}}videos/pt.mp4" volume="1" loop="false" muted="false"/>
        <image x="270" y="220" width="70" height="60" zIndex="2" src="{{base}}images/left_jt.png"/>
        <image x="740" y="220" width="70" height="60" zIndex="2" src="{{base}}images/left_jt.png"/>
        <text x="393" y="200" width="295" height="80" zIndex="2" enterEffect-type="fadeInUp" enterEffect-duration="500" startTime="500" fontFamily="HarmonyOS_Sans_SC_Regular" fontSize="80" fontWeight="400" fontColor="#000000">Test</text>
        <text x="0" y="1640" width="1080" height="32" textAlign="center" zIndex="2" enterEffect-type="fadeInUp" enterEffect-duration="500" startTime="500" fontFamily="HarmonyOS_Sans_SC_Regular" fontSize="32" fontWeight="400" fontColor="#FFFFFF">{{date}}</text>
        <voice startTime="500" volume="100" loop="false" playbackRate="1" muted="false" provider="microsoft" text="{{text}}" declaimer="xiaoxiao" speechRate="0"/>
    </scene>
</template>

compiled xml:

<?xml version="1.0"?>
<template version="2.0.0" id="1bb0da20b6df11ecb40a272b48f69d94" name="Test Video" mode="scene" poster="/files/cover.png" width="1080" height="1920" aspectRatio="9:16" fps="60" duration="10000" volume="1" createTime="1649382990" updateTime="1649382990" buildBy="system">
  <audio id="1u4EA6WQNpbLUbuJ" src="/files/audios/bgm.mp3" volume="0.2" loop="true" muted="false"/>
  <scene id="1U4ea6OYPg24XOFQ" width="1080" height="1920" duration="5000" transition-type="wipeLeft" transition-duration="300">
    <video id="1U4Ea65wvvMlLooU" x="0" y="0" width="1080" height="1920" src="/files/videos/pt.mp4" volume="1" loop="false" muted="false"/>
    <image id="1U4Ea6lbmxlbtWi8" x="270" y="220" width="70" height="60" zIndex="2" src="/files/images/left_jt.png" mode="scaleToFill"/>
    <image id="1u4EA6pcZTp317rE" x="740" y="220" width="70" height="60" zIndex="2" src="/files/images/left_jt.png" mode="scaleToFill"/>
    <text id="1u4eA6zA6iISnMjX" x="393" y="200" width="295" height="80" zIndex="2" enterEffect-type="fadeInUp" enterEffect-duration="500" enterEffect-easing="0" startTime="500" fontFamily="HarmonyOS_Sans_SC_Regular" fontSize="80" fontWeight="400" fontColor="#000000" lineHeight="1" wordSpacing="0" lineWrap="false">Test</text>
    <text id="1U4eA62BmlWhk4nT" x="0" y="1640" width="1080" height="32" zIndex="2" enterEffect-type="fadeInUp" enterEffect-duration="500" enterEffect-easing="0" startTime="500" fontFamily="HarmonyOS_Sans_SC_Regular" fontSize="32" fontWeight="400" fontColor="#FFFFFF" lineHeight="1" wordSpacing="0" textAlign="center" lineWrap="false">2022-03-02</text>
    <voice id="1U4EA6ylkOofmQQF" startTime="500" volume="100" loop="false" playbackRate="1" muted="false" provider="microsoft" text="Hello World" declaimer="xiaoxiao" speechRate="0"/>
  </scene>
  <scene id="1u4eA64X3zD0D33P" width="1080" height="1920" duration="5000" transition-type="wipeLeft" transition-duration="300">
    <video id="1u4eA6GChkjJYXuL" x="0" y="0" width="1080" height="1920" src="/files/videos/pt.mp4" volume="1" loop="false" muted="false"/>
    <image id="1u4eA6PgFzKBvjut" x="270" y="220" width="70" height="60" zIndex="2" src="/files/images/left_jt.png" mode="scaleToFill"/>
    <image id="1U4eA66yCPZbzgDO" x="740" y="220" width="70" height="60" zIndex="2" src="/files/images/left_jt.png" mode="scaleToFill"/>
    <text id="1U4eA6GO1B7v8kXb" x="393" y="200" width="295" height="80" zIndex="2" enterEffect-type="fadeInUp" enterEffect-duration="500" enterEffect-easing="0" startTime="500" fontFamily="HarmonyOS_Sans_SC_Regular" fontSize="80" fontWeight="400" fontColor="#000000" lineHeight="1" wordSpacing="0" lineWrap="false">Test</text>
    <text id="1U4Ea6SqCMZXUZS1" x="0" y="1640" width="1080" height="32" zIndex="2" enterEffect-type="fadeInUp" enterEffect-duration="500" enterEffect-easing="0" startTime="500" fontFamily="HarmonyOS_Sans_SC_Regular" fontSize="32" fontWeight="400" fontColor="#FFFFFF" lineHeight="1" wordSpacing="0" textAlign="center" lineWrap="false">2022-03-02</text>
    <voice id="1u4ea6waczrOHFIJ" startTime="500" volume="100" loop="false" playbackRate="1" muted="false" provider="microsoft" text="Hello World" declaimer="xiaoxiao" speechRate="0"/>
  </scene>
</template>
1.1.92

3 years ago

1.1.91

3 years ago

1.1.95

3 years ago

1.1.94

3 years ago

1.1.93

3 years ago

1.1.921

3 years ago

1.1.892

3 years ago

1.1.891

3 years ago

1.1.89

3 years ago

1.1.88

3 years ago

1.1.87

3 years ago

1.1.8833

3 years ago

1.1.8832

3 years ago

1.1.8831

3 years ago

1.1.9

3 years ago

1.1.881

3 years ago

1.1.884

3 years ago

1.1.883

3 years ago

1.1.882

3 years ago

1.1.944

3 years ago

1.1.943

3 years ago

1.1.942

3 years ago

1.1.941

3 years ago

1.1.933

3 years ago

1.1.932

3 years ago

1.1.931

3 years ago

1.1.956

3 years ago

1.1.948

3 years ago

1.1.947

3 years ago

1.1.946

3 years ago

1.1.945

3 years ago

1.1.955

3 years ago

1.1.954

3 years ago

1.1.953

3 years ago

1.1.952

3 years ago

1.1.951

3 years ago

1.1.8681

3 years ago

1.1.8652

3 years ago

1.1.8651

3 years ago

1.1.8691

3 years ago

1.1.8581

3 years ago

1.1.858

3 years ago

1.1.857

3 years ago

1.1.867

3 years ago

1.1.866

3 years ago

1.1.865

3 years ago

1.1.864

3 years ago

1.1.863

3 years ago

1.1.862

3 years ago

1.1.861

3 years ago

1.1.860

3 years ago

1.1.856

3 years ago

1.1.855

3 years ago

1.1.869

3 years ago

1.1.868

3 years ago

1.1.8631

3 years ago

1.1.694

4 years ago

1.1.693

4 years ago

1.1.692

4 years ago

1.1.691

4 years ago

1.1.698

4 years ago

1.1.697

4 years ago

1.1.696

4 years ago

1.1.695

4 years ago

1.1.3999

4 years ago

1.1.8531

3 years ago

1.1.3881

4 years ago

1.1.419

4 years ago

1.1.418

4 years ago

1.1.417

4 years ago

1.1.661

4 years ago

1.1.74

3 years ago

1.1.73

3 years ago

1.1.72

3 years ago

1.1.8471

3 years ago

1.1.71

3 years ago

1.1.78

3 years ago

1.1.77

3 years ago

1.1.76

3 years ago

1.1.75

3 years ago

1.1.79

3 years ago

1.1.81

3 years ago

1.1.771

3 years ago

1.1.83

3 years ago

1.1.82

3 years ago

1.1.779

3 years ago

1.1.416

4 years ago

1.1.778

3 years ago

1.1.415

4 years ago

1.1.777

3 years ago

1.1.414

4 years ago

1.1.776

3 years ago

1.1.413

4 years ago

1.1.775

3 years ago

1.1.412

4 years ago

1.1.774

3 years ago

1.1.411

4 years ago

1.1.773

3 years ago

1.1.410

4 years ago

1.1.772

3 years ago

1.1.52

4 years ago

1.1.8451

3 years ago

1.1.51

4 years ago

1.1.56

4 years ago

1.1.55

4 years ago

1.1.54

4 years ago

1.1.53

4 years ago

1.1.59

4 years ago

1.1.58

4 years ago

1.1.57

4 years ago

1.1.63

4 years ago

1.1.8462

3 years ago

1.1.62

4 years ago

1.1.8461

3 years ago

1.1.61

4 years ago

1.1.67

4 years ago

1.1.66

4 years ago

1.1.65

4 years ago

1.1.64

4 years ago

1.1.69

4 years ago

1.1.68

4 years ago

1.1.849

3 years ago

1.1.848

3 years ago

1.1.847

3 years ago

1.1.846

3 years ago

1.1.3951

4 years ago

1.1.854

3 years ago

1.1.853

3 years ago

1.1.852

3 years ago

1.1.851

3 years ago

1.1.850

3 years ago

1.1.8

3 years ago

1.1.7

3 years ago

1.1.6

4 years ago

1.1.5

4 years ago

1.1.4

4 years ago

1.1.3982

4 years ago

1.1.386

4 years ago

1.1.3983

4 years ago

1.1.385

4 years ago

1.1.384

4 years ago

1.1.3981

4 years ago

1.1.383

4 years ago

1.1.389

4 years ago

1.1.388

4 years ago

1.1.387

4 years ago

1.1.3993

4 years ago

1.1.3994

4 years ago

1.1.3991

4 years ago

1.1.3992

4 years ago

1.1.3997

4 years ago

1.1.3998

4 years ago

1.1.3995

4 years ago

1.1.3996

4 years ago

1.1.836

3 years ago

1.1.835

3 years ago

1.1.3961

4 years ago

1.1.3962

4 years ago

1.1.845

3 years ago

1.1.844

3 years ago

1.1.843

3 years ago

1.1.842

3 years ago

1.1.841

3 years ago

1.1.840

3 years ago

1.1.397

4 years ago

1.1.396

4 years ago

1.1.395

4 years ago

1.1.393

4 years ago

1.1.392

4 years ago

1.1.391

4 years ago

1.1.390

4 years ago

1.1.834

3 years ago

1.1.833

3 years ago

1.1.832

3 years ago

1.1.831

3 years ago

1.1.399

4 years ago

1.1.398

4 years ago

1.0.9

4 years ago

1.0.8

4 years ago

1.0.7

4 years ago

1.0.862

4 years ago

1.0.861

4 years ago

1.1.382

4 years ago

1.1.381

4 years ago

1.1.34

4 years ago

1.1.33

4 years ago

1.1.32

4 years ago

1.1.31

4 years ago

1.1.38

4 years ago

1.1.37

4 years ago

1.1.36

4 years ago

1.1.35

4 years ago

1.1.375

4 years ago

1.1.374

4 years ago

1.1.373

4 years ago

1.1.372

4 years ago

1.1.371

4 years ago

1.0.73

4 years ago

1.0.72

4 years ago

1.0.71

4 years ago

1.0.77

4 years ago

1.0.76

4 years ago

1.0.75

4 years ago

1.1.379

4 years ago

1.1.378

4 years ago

1.1.377

4 years ago

1.0.79

4 years ago

1.1.376

4 years ago

1.0.78

4 years ago

1.1.1

4 years ago

1.1.0

4 years ago

1.1.3

4 years ago

1.1.2

4 years ago

1.1.364

4 years ago

1.1.363

4 years ago

1.1.362

4 years ago

1.1.361

4 years ago

1.0.84

4 years ago

1.0.83

4 years ago

1.0.82

4 years ago

1.0.81

4 years ago

1.0.88

4 years ago

1.0.87

4 years ago

1.0.86

4 years ago

1.1.369

4 years ago

1.0.85

4 years ago

1.1.368

4 years ago

1.1.367

4 years ago

1.1.366

4 years ago

1.1.365

4 years ago

1.0.89

4 years ago

1.0.91

4 years ago

1.0.95

4 years ago

1.0.94

4 years ago

1.0.93

4 years ago

1.0.92

4 years ago

1.0.99

4 years ago

1.0.98

4 years ago

1.0.97

4 years ago

1.0.96

4 years ago

1.0.61

4 years ago

1.0.6

4 years ago

1.0.5

4 years ago

1.0.4

4 years ago

1.0.3

4 years ago

1.0.2

4 years ago

1.0.1

4 years ago

1.0.0

4 years ago