@versa_ai/vmml-editor 1.0.29 → 1.0.31
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.turbo/turbo-build.log +8 -8
- package/dist/canvas-JILBIABC.node +0 -0
- package/dist/index.js +72 -63
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +72 -63
- package/dist/index.mjs.map +1 -1
- package/package.json +1 -1
- package/src/assets/css/index.scss +78 -75
- package/src/components/EditorCanvas.tsx +12 -5
- package/src/index.tsx +88 -62
package/.turbo/turbo-build.log
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
|
|
2
|
-
> @versa_ai/vmml-editor@1.0.
|
|
2
|
+
> @versa_ai/vmml-editor@1.0.31 build D:\code\work\vmml-player\packages\editor
|
|
3
3
|
> tsup
|
|
4
4
|
|
|
5
5
|
[34mCLI[39m Building entry: src/index.tsx
|
|
@@ -124,12 +124,12 @@ More info and automated migrator: https://sass-lang.com/d/slash-div[0m [1m[35
|
|
|
124
124
|
|
|
125
125
|
|
|
126
126
|
[34mDTS[39m Build start
|
|
127
|
-
[32mESM[39m [1mdist\index.mjs [22m[32m114.
|
|
128
|
-
[32mESM[39m [1mdist\index.mjs.map [22m[
|
|
129
|
-
[32mESM[39m ⚡️ Build success in
|
|
130
|
-
[32mCJS[39m [1mdist\index.js [22m[32m115.
|
|
131
|
-
[32mCJS[39m [1mdist\index.js.map [22m[
|
|
132
|
-
[32mCJS[39m ⚡️ Build success in
|
|
133
|
-
[32mDTS[39m ⚡️ Build success in
|
|
127
|
+
[32mESM[39m [1mdist\index.mjs [22m[32m114.31 KB[39m
|
|
128
|
+
[32mESM[39m [1mdist\index.mjs.map [22m[32m220.87 KB[39m
|
|
129
|
+
[32mESM[39m ⚡️ Build success in 852ms
|
|
130
|
+
[32mCJS[39m [1mdist\index.js [22m[32m115.92 KB[39m
|
|
131
|
+
[32mCJS[39m [1mdist\index.js.map [22m[32m221.16 KB[39m
|
|
132
|
+
[32mCJS[39m ⚡️ Build success in 853ms
|
|
133
|
+
[32mDTS[39m ⚡️ Build success in 7106ms
|
|
134
134
|
[32mDTS[39m [1mdist\index.d.ts [22m[32m158.00 B[39m
|
|
135
135
|
[32mDTS[39m [1mdist\index.d.mts [22m[32m158.00 B[39m
|
|
Binary file
|
package/dist/index.js
CHANGED
|
@@ -89,14 +89,13 @@ var css = `@charset "UTF-8";
|
|
|
89
89
|
width: 100%;
|
|
90
90
|
height: 100%;
|
|
91
91
|
}
|
|
92
|
-
.editor .
|
|
92
|
+
.editor .controls-box {
|
|
93
|
+
position: relative;
|
|
93
94
|
height: 12vw;
|
|
94
|
-
position: absolute;
|
|
95
|
-
bottom: 0;
|
|
96
95
|
width: 100%;
|
|
97
96
|
border-radius: 3.2vw;
|
|
98
97
|
}
|
|
99
|
-
.editor .
|
|
98
|
+
.editor .player-controls {
|
|
100
99
|
display: flex;
|
|
101
100
|
align-items: center;
|
|
102
101
|
width: 100%;
|
|
@@ -105,20 +104,20 @@ var css = `@charset "UTF-8";
|
|
|
105
104
|
box-sizing: border-box;
|
|
106
105
|
background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.6) 100%);
|
|
107
106
|
}
|
|
108
|
-
.editor .
|
|
107
|
+
.editor .player-controls .mr-16 {
|
|
109
108
|
margin-right: 2.13vw;
|
|
110
109
|
}
|
|
111
|
-
.editor .
|
|
110
|
+
.editor .player-controls .player-controls-toggle > img {
|
|
112
111
|
display: block;
|
|
113
112
|
width: 4.8vw;
|
|
114
113
|
height: 4.8vw;
|
|
115
114
|
cursor: pointer;
|
|
116
115
|
}
|
|
117
|
-
.editor .
|
|
116
|
+
.editor .player-controls .player-controls-seekbar {
|
|
118
117
|
flex: 1;
|
|
119
118
|
position: relative;
|
|
120
119
|
}
|
|
121
|
-
.editor .
|
|
120
|
+
.editor .player-controls .player-controls-seekbar .seekbar-container {
|
|
122
121
|
height: 100%;
|
|
123
122
|
user-select: none;
|
|
124
123
|
touch-action: none;
|
|
@@ -126,32 +125,32 @@ var css = `@charset "UTF-8";
|
|
|
126
125
|
cursor: pointer;
|
|
127
126
|
box-sizing: border-box;
|
|
128
127
|
}
|
|
129
|
-
.editor .
|
|
128
|
+
.editor .player-controls .player-controls-seekbar .seekbar-container .seekbar-background {
|
|
130
129
|
user-select: none;
|
|
131
130
|
height: 1.6vw;
|
|
132
131
|
width: 100%;
|
|
133
132
|
background-color: rgba(255, 255, 255, 0.2);
|
|
134
133
|
border-radius: 1vw;
|
|
135
134
|
}
|
|
136
|
-
.editor .
|
|
135
|
+
.editor .player-controls .player-controls-seekbar .seekbar-container .seekbar-background .seekbar-fill {
|
|
137
136
|
position: absolute;
|
|
138
137
|
user-select: none;
|
|
139
138
|
width: 100%;
|
|
140
139
|
height: 100%;
|
|
141
140
|
border-radius: 1vw;
|
|
142
141
|
}
|
|
143
|
-
.editor .
|
|
142
|
+
.editor .player-controls .player-controls-seekbar .seekbar-container .seekbar-background .seekbar-line {
|
|
144
143
|
height: 100%;
|
|
145
144
|
border-radius: 1vw;
|
|
146
145
|
background-color: #eeeeee;
|
|
147
146
|
}
|
|
148
|
-
.editor .
|
|
147
|
+
.editor .player-controls .player-controls-seekbar .seekbar-container .seekbar-background .seekbar-sign {
|
|
149
148
|
width: 10px;
|
|
150
149
|
position: absolute;
|
|
151
150
|
top: 50%;
|
|
152
151
|
margin-top: -6px;
|
|
153
152
|
}
|
|
154
|
-
.editor .
|
|
153
|
+
.editor .player-controls .player-controls-seekbar .seekbar-container .seekbar-background .seekbar-cirle {
|
|
155
154
|
position: absolute;
|
|
156
155
|
top: -0.8vw;
|
|
157
156
|
width: 3.2vw;
|
|
@@ -159,23 +158,23 @@ var css = `@charset "UTF-8";
|
|
|
159
158
|
border-radius: 50%;
|
|
160
159
|
background: #eeeeee;
|
|
161
160
|
}
|
|
162
|
-
.editor .
|
|
161
|
+
.editor .player-controls .player-controls-time {
|
|
163
162
|
width: 10vw;
|
|
164
163
|
color: #fff;
|
|
165
164
|
}
|
|
166
|
-
.editor .
|
|
165
|
+
.editor .play-btn {
|
|
167
166
|
position: absolute;
|
|
168
167
|
bottom: 4vw;
|
|
169
168
|
left: 3vw;
|
|
170
169
|
width: 4.8vw;
|
|
171
170
|
height: 4.8vw;
|
|
172
171
|
}
|
|
173
|
-
.editor .
|
|
172
|
+
.editor .play-btn img {
|
|
174
173
|
width: 100%;
|
|
175
174
|
height: 100%;
|
|
176
175
|
display: block;
|
|
177
176
|
}
|
|
178
|
-
.editor .
|
|
177
|
+
.editor .opacity-06 {
|
|
179
178
|
opacity: 0.6;
|
|
180
179
|
}
|
|
181
180
|
.editor .footer {
|
|
@@ -310,7 +309,7 @@ var css = `@charset "UTF-8";
|
|
|
310
309
|
width: 60px !important;
|
|
311
310
|
}
|
|
312
311
|
}
|
|
313
|
-
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sourceRoot":"D:\\code\\work\\vmml-player\\packages\\editor\\src\\assets\\css","sources":["index.scss"],"names":[],"mappings":";AAAA;EACE;EACA;EACA;EACA;EACA;;AACA;EACE;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AACA;EACE;EACA;;AACA;EACE;EACA;;AAGJ;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;AACA;EACE;EACA;;AAEF;EACE;;AAGJ;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAGJ;EACE;;AAGF;EACE;EAEA;;AAGF;EAEE;EACA;EAEA;EACA;EACA;EACA;EACA;EACA;;AACA;EACE;EACA;;AAEF;EACE;EACA;EACA;EACA;EACA;;AAEF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;AACA;EACE;;AAGA;EACE;EACA;EACA;EACA;;AAGJ;EACE;EACA;;AACA;EACE;EACA;EACA;EACA;EACA;EACA;;AACA;EACE;EACA;EACA;EACA;EACA;;AACA;EACE;EACA;EACA;EACA;EACA;;AAEF;EACE;EACA;EACA;;AAEF;EACE;EACA;EACA;EACA;;AAEF;EACE;EACA;EACA;EACA;EACA;EACA;;AAKR;EACE;EACA;;AAGJ;EACE;EACA;EACA;EACA;EACA;;AACA;EACE;EACA;EACA;;AAGJ;EACE;;AAKJ;EACE;EACA;EACA;EACA;EACA;;AACA;EACE;EACA;;AACA;EACE;EACA;EACA;EACA;;AAEF;EACE;EACA;EACA;EACA;;AAKN;EACE;;AAGF;EACE;EAEA;EACA;EACA;EACA;EACA;EACA;;AACA;EACE;;AAEF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;AACA;EACE;;AAEF;EACE;EACA;;AAEF;EACE;;AAGJ;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;AACA;EACE;EACA;EACA;;AACA;EACE;EACA;EACA;;;AAQV;EAEI;IACE;IACA;;EAEF;IACE;IACA;IACA;IACA;IACA;;EACA;IACE;;EAGA;IACE;IACA;IACA;IACA;;EAGJ;IACE;;EACA;IACE;;EACA;IACE;IACA;IACA;;EACA;IACE;IACA;IACA;;EAEF;IACE;IACA;;EAEF;IACE;IACA;IACA;;EAEF;IACE;IACA;IACA;;EAKR;IACE","sourcesContent":[".editor{\r\n  background: #000;\r\n  width: 100%;\r\n  overflow: hidden;\r\n  display: flex;\r\n  flex-direction: column;\r\n  .padding-box {\r\n    flex: 1;\r\n  }\r\n  // 顶部\r\n  &>.header{\r\n    width: 100%;\r\n    display: flex;\r\n    justify-content: space-between;\r\n    align-items: center;\r\n    height: 11.467vw;\r\n    padding-left: 4.4vw;\r\n    padding-right: 3.2vw;\r\n    box-sizing: border-box;\r\n    position: relative;\r\n    &>.close{\r\n      width: 4vw;\r\n      height: 4vw;\r\n      img{\r\n        width: 100%;\r\n        height: 100%;\r\n      }\r\n    }\r\n    &>.history-operate{\r\n      height: 7.2vw;\r\n      display: none;\r\n      align-items: center;\r\n      position: absolute;\r\n      left: 50%;\r\n      top: 50%;\r\n      transform: translate(-50%,-50%);\r\n      img{\r\n        width: 4.667vw;\r\n        height: 5.067vw;\r\n      }\r\n      &>img:last-child{\r\n        margin-left: 8vw;\r\n      }\r\n    }\r\n    &>.next-button{\r\n      width: 16vw;\r\n      height: 7.2vw;\r\n      line-height: 7.2vw;\r\n      background: #1677FF;\r\n      border-radius: 6.533vw;\r\n      text-align: center;\r\n      font-size: 3.2vw;\r\n      color: #fff;\r\n    }\r\n  }\r\n  .text-style{\r\n    filter:blur(10px)\r\n  }\r\n\r\n  .editor-vessel {\r\n    width: 100%;\r\n    // padding-top: 3.2vw;\r\n    height: 100%;\r\n  }\r\n  //player与画布\r\n  .main{\r\n    // width: 81.467vw;\r\n    width: 100%;\r\n    height: 100%;\r\n    // height: 144.8vw;\r\n    margin: auto;\r\n    position: relative;\r\n    display: flex;\r\n    justify-content: center;\r\n    border-radius: 3.2vw;\r\n    overflow: hidden;\r\n    .vessel {\r\n      width: 100%;\r\n      height: 100%;\r\n    }\r\n    .controls-box {\r\n      height: 12vw;\r\n      position: absolute;\r\n      bottom: 0;\r\n      width: 100%;\r\n      border-radius: 3.2vw;\r\n    }\r\n    .player-controls {\r\n      display: flex;\r\n      align-items: center;\r\n      width: 100%;\r\n      height: 100%;\r\n      padding: 0 2.13vw;\r\n      box-sizing: border-box;\r\n      background: linear-gradient( 180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,0.6) 100%);\r\n      .mr-16 {\r\n        margin-right: 2.13vw;\r\n      }\r\n      .player-controls-toggle {\r\n        >img {\r\n          display: block;\r\n          width: 4.8vw;\r\n          height: 4.8vw;\r\n          cursor: pointer;\r\n        }\r\n      }\r\n      .player-controls-seekbar {\r\n        flex: 1;\r\n        position: relative;\r\n        .seekbar-container {\r\n          height: 100%;\r\n          user-select: none;\r\n          touch-action: none;\r\n          position: relative;\r\n          cursor: pointer;\r\n          box-sizing: border-box;\r\n          .seekbar-background {\r\n            user-select: none;\r\n            height: 1.6vw;\r\n            width: 100%;\r\n            background-color: rgba(255, 255, 255, 0.2);\r\n            border-radius: 1vw;\r\n            .seekbar-fill {\r\n              position: absolute;\r\n              user-select: none;\r\n              width: 100%;\r\n              height: 100%;\r\n              border-radius: 1vw;\r\n            }\r\n            .seekbar-line {\r\n              height: 100%;\r\n              border-radius: 1vw;\r\n              background-color: #eeeeee;\r\n            }\r\n            .seekbar-sign {\r\n              width: 10px;\r\n              position: absolute;\r\n              top: 50%;\r\n              margin-top: -6px;\r\n            }\r\n            .seekbar-cirle {\r\n              position: absolute;\r\n              top: -0.8vw;\r\n              width: 3.2vw;\r\n              height: 3.2vw;\r\n              border-radius: 50%;\r\n              background: #eeeeee;\r\n            }\r\n          }\r\n        }\r\n      }\r\n      .player-controls-time {\r\n        width: 10vw;\r\n        color: #fff;\r\n      }\r\n    }\r\n    .play-btn {\r\n      position: absolute;\r\n      bottom: 4vw;\r\n      left: 3vw;\r\n      width: 4.8vw;\r\n      height: 4.8vw;\r\n      img {\r\n        width: 100%;\r\n        height: 100%;\r\n        display: block;\r\n      }\r\n    }\r\n    .opacity-06 {\r\n      opacity: 0.6;\r\n    }\r\n  }\r\n\r\n  //底部\r\n  .footer{\r\n    display: flex;\r\n    justify-content: center;\r\n    box-sizing: border-box;\r\n    width: 100%;\r\n    padding: 0 20.333vw 10.933vw;\r\n    &>div{\r\n      width: 30%;\r\n      margin: 0 15%;\r\n      img{\r\n        width: 6.4vw;\r\n        height: 6.4vw;\r\n        display: block;\r\n        margin: auto;\r\n      }\r\n      p{\r\n        font-size: 3.2vw;\r\n        color: #fff;\r\n        margin-top: 1.867vw;\r\n        text-align: center;\r\n      }\r\n    }\r\n  }\r\n\r\n  .not-show-text{\r\n    justify-content: space-around;\r\n  }\r\n\r\n  .editor-video-menu {\r\n    position: fixed;\r\n    // height: 38.13vh;\r\n    height: 0;\r\n    width: 100%;\r\n    background: #1E1E1E;\r\n    bottom: 0;\r\n    border-radius: 8px 8px 0 0;\r\n    transition: all 0.5s ease-in-out;  \r\n    &.active {\r\n      height: 38.13vh;\r\n    }\r\n    .editor-video-menu-header {\r\n      display: flex;\r\n      padding: 1.6vw 1.6vw 0;\r\n      height: 4.81vh;\r\n      line-height: 4.81vh;\r\n      color: rgba(255, 255, 255, 0.40);\r\n      overflow: hidden;\r\n      overflow-x: auto;\r\n      &::-webkit-scrollbar {\r\n        display: none; /* 隐藏滚动条 */\r\n      }\r\n      >div {\r\n        margin: 0 3.2vw;\r\n        white-space: nowrap;\r\n      }\r\n      .active {\r\n        color: #FFFFFF;\r\n      }\r\n    }\r\n    .editor-video-menu-itmes {\r\n      padding: 0 3.33vw;\r\n      max-height: calc(100% - 4.81vh - 1.6vw);\r\n      display: grid;\r\n      grid-template-columns: repeat(4, 1fr);\r\n      row-gap: 3.2vw;\r\n      column-gap: 2.6vw;\r\n      overflow: auto;\r\n      >div {\r\n        width: 21.33vw;\r\n        height: 21.33vw;\r\n        background-color: #1e1e1e;\r\n        img {\r\n          width: 100%;\r\n          height: 100%;\r\n          object-fit: contain;\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n}\r\n\r\n@media screen and (min-width: 750px) {\r\n  .editor {\r\n    .controls-box {\r\n      height: 20% !important;\r\n      border-radius: 3.2vw;\r\n    }\r\n    .player-controls {\r\n      display: flex;\r\n      align-items: center;\r\n      width: 100%;\r\n      height: 100%;\r\n      padding: 0 1%;\r\n      .mr-16 {\r\n        margin-right: 2.13vw;\r\n      }\r\n      .player-controls-toggle {\r\n        >img {\r\n          display: block;\r\n          width: 30px !important;\r\n          height: 30px !important;\r\n          cursor: pointer;\r\n        }\r\n      }\r\n      .player-controls-seekbar {\r\n        flex: 1;\r\n        .seekbar-container {\r\n          height: 2px !important;\r\n          .seekbar-background {\r\n            height: 8px !important;\r\n            width: 100%;\r\n            border-radius: 1vw;\r\n            .seekbar-fill {\r\n              width: 100%;\r\n              height: 80%;\r\n              border-radius: 1vw;\r\n            }\r\n            .seekbar-line {\r\n              height: 100%;\r\n              border-radius: 1vw;\r\n            }\r\n            .seekbar-sign {\r\n              width: 10px;\r\n              top: 50%;\r\n              margin-top: -6px;\r\n            }\r\n            .seekbar-cirle {\r\n              top: -5px !important;\r\n              width: 20px !important;\r\n              height: 20px !important;\r\n            }\r\n          }\r\n        }\r\n      }\r\n      .player-controls-time {\r\n        width: 60px !important;\r\n      }\r\n    }\r\n  }\r\n}\r\n\r\n"]} */`;
|
|
312
|
+
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sourceRoot":"D:\\code\\work\\vmml-player\\packages\\editor\\src\\assets\\css","sources":["index.scss"],"names":[],"mappings":";AAAA;EACE;EACA;EACA;EACA;EACA;;AACA;EACE;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AACA;EACE;EACA;;AACA;EACE;EACA;;AAGJ;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;AACA;EACE;EACA;;AAEF;EACE;;AAGJ;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAGJ;EACE;;AAGF;EACE;EAEA;;AAGF;EAEE;EACA;EAEA;EACA;EACA;EACA;EACA;EACA;;AACA;EACE;EACA;;AAKJ;EACI;EACA;EAGA;EACA;;AAEJ;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;AACA;EACE;;AAGA;EACE;EACA;EACA;EACA;;AAGJ;EACE;EACA;;AACA;EACE;EACA;EACA;EACA;EACA;EACA;;AACA;EACE;EACA;EACA;EACA;EACA;;AACA;EACE;EACA;EACA;EACA;EACA;;AAEF;EACE;EACA;EACA;;AAEF;EACE;EACA;EACA;EACA;;AAEF;EACE;EACA;EACA;EACA;EACA;EACA;;AAKR;EACE;EACA;;AAGJ;EACE;EACA;EACA;EACA;EACA;;AACA;EACE;EACA;EACA;;AAGJ;EACE;;AAIF;EACE;EACA;EACA;EACA;EACA;;AACA;EACE;EACA;;AACA;EACE;EACA;EACA;EACA;;AAEF;EACE;EACA;EACA;EACA;;AAKN;EACE;;AAGF;EACE;EAEA;EACA;EACA;EACA;EACA;EACA;;AACA;EACE;;AAEF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;AACA;EACE;;AAEF;EACE;EACA;;AAEF;EACE;;AAGJ;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;AACA;EACE;EACA;EACA;;AACA;EACE;EACA;EACA;;;AAQV;EAEI;IACE;IACA;;EAEF;IACE;IACA;IACA;IACA;IACA;;EACA;IACE;;EAGA;IACE;IACA;IACA;IACA;;EAGJ;IACE;;EACA;IACE;;EACA;IACE;IACA;IACA;;EACA;IACE;IACA;IACA;;EAEF;IACE;IACA;;EAEF;IACE;IACA;IACA;;EAEF;IACE;IACA;IACA;;EAKR;IACE","sourcesContent":[".editor{\r\n  background: #000;\r\n  width: 100%;\r\n  overflow: hidden;\r\n  display: flex;\r\n  flex-direction: column;\r\n  .padding-box {\r\n    flex: 1;\r\n  }\r\n  // 顶部\r\n  &>.header{\r\n    width: 100%;\r\n    display: flex;\r\n    justify-content: space-between;\r\n    align-items: center;\r\n    height: 11.467vw;\r\n    padding-left: 4.4vw;\r\n    padding-right: 3.2vw;\r\n    box-sizing: border-box;\r\n    position: relative;\r\n    &>.close{\r\n      width: 4vw;\r\n      height: 4vw;\r\n      img{\r\n        width: 100%;\r\n        height: 100%;\r\n      }\r\n    }\r\n    &>.history-operate{\r\n      height: 7.2vw;\r\n      display: none;\r\n      align-items: center;\r\n      position: absolute;\r\n      left: 50%;\r\n      top: 50%;\r\n      transform: translate(-50%,-50%);\r\n      img{\r\n        width: 4.667vw;\r\n        height: 5.067vw;\r\n      }\r\n      &>img:last-child{\r\n        margin-left: 8vw;\r\n      }\r\n    }\r\n    &>.next-button{\r\n      width: 16vw;\r\n      height: 7.2vw;\r\n      line-height: 7.2vw;\r\n      background: #1677FF;\r\n      border-radius: 6.533vw;\r\n      text-align: center;\r\n      font-size: 3.2vw;\r\n      color: #fff;\r\n    }\r\n  }\r\n  .text-style{\r\n    filter:blur(10px)\r\n  }\r\n\r\n  .editor-vessel {\r\n    width: 100%;\r\n    // padding-top: 3.2vw;\r\n    height: 100%;\r\n  }\r\n  //player与画布\r\n  .main{\r\n    // width: 81.467vw;\r\n    width: 100%;\r\n    height: 100%;\r\n    // height: 144.8vw;\r\n    margin: auto;\r\n    position: relative;\r\n    display: flex;\r\n    justify-content: center;\r\n    border-radius: 3.2vw;\r\n    overflow: hidden;\r\n    .vessel {\r\n      width: 100%;\r\n      height: 100%;\r\n    }\r\n    \r\n  }\r\n\r\n  .controls-box {\r\n      position: relative;\r\n      height: 12vw;\r\n      // position: absolute;\r\n      // bottom: 0;\r\n      width: 100%;\r\n      border-radius: 3.2vw;\r\n  }\r\n  .player-controls {\r\n    display: flex;\r\n    align-items: center;\r\n    width: 100%;\r\n    height: 100%;\r\n    padding: 0 2.13vw;\r\n    box-sizing: border-box;\r\n    background: linear-gradient( 180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,0.6) 100%);\r\n    .mr-16 {\r\n      margin-right: 2.13vw;\r\n    }\r\n    .player-controls-toggle {\r\n      >img {\r\n        display: block;\r\n        width: 4.8vw;\r\n        height: 4.8vw;\r\n        cursor: pointer;\r\n      }\r\n    }\r\n    .player-controls-seekbar {\r\n      flex: 1;\r\n      position: relative;\r\n      .seekbar-container {\r\n        height: 100%;\r\n        user-select: none;\r\n        touch-action: none;\r\n        position: relative;\r\n        cursor: pointer;\r\n        box-sizing: border-box;\r\n        .seekbar-background {\r\n          user-select: none;\r\n          height: 1.6vw;\r\n          width: 100%;\r\n          background-color: rgba(255, 255, 255, 0.2);\r\n          border-radius: 1vw;\r\n          .seekbar-fill {\r\n            position: absolute;\r\n            user-select: none;\r\n            width: 100%;\r\n            height: 100%;\r\n            border-radius: 1vw;\r\n          }\r\n          .seekbar-line {\r\n            height: 100%;\r\n            border-radius: 1vw;\r\n            background-color: #eeeeee;\r\n          }\r\n          .seekbar-sign {\r\n            width: 10px;\r\n            position: absolute;\r\n            top: 50%;\r\n            margin-top: -6px;\r\n          }\r\n          .seekbar-cirle {\r\n            position: absolute;\r\n            top: -0.8vw;\r\n            width: 3.2vw;\r\n            height: 3.2vw;\r\n            border-radius: 50%;\r\n            background: #eeeeee;\r\n          }\r\n        }\r\n      }\r\n    }\r\n    .player-controls-time {\r\n      width: 10vw;\r\n      color: #fff;\r\n    }\r\n  }\r\n  .play-btn {\r\n    position: absolute;\r\n    bottom: 4vw;\r\n    left: 3vw;\r\n    width: 4.8vw;\r\n    height: 4.8vw;\r\n    img {\r\n      width: 100%;\r\n      height: 100%;\r\n      display: block;\r\n    }\r\n  }\r\n  .opacity-06 {\r\n    opacity: 0.6;\r\n  }\r\n\r\n  //底部\r\n  .footer{\r\n    display: flex;\r\n    justify-content: center;\r\n    box-sizing: border-box;\r\n    width: 100%;\r\n    padding: 0 20.333vw 10.933vw;\r\n    &>div{\r\n      width: 30%;\r\n      margin: 0 15%;\r\n      img{\r\n        width: 6.4vw;\r\n        height: 6.4vw;\r\n        display: block;\r\n        margin: auto;\r\n      }\r\n      p{\r\n        font-size: 3.2vw;\r\n        color: #fff;\r\n        margin-top: 1.867vw;\r\n        text-align: center;\r\n      }\r\n    }\r\n  }\r\n\r\n  .not-show-text{\r\n    justify-content: space-around;\r\n  }\r\n\r\n  .editor-video-menu {\r\n    position: fixed;\r\n    // height: 38.13vh;\r\n    height: 0;\r\n    width: 100%;\r\n    background: #1E1E1E;\r\n    bottom: 0;\r\n    border-radius: 8px 8px 0 0;\r\n    transition: all 0.5s ease-in-out;  \r\n    &.active {\r\n      height: 38.13vh;\r\n    }\r\n    .editor-video-menu-header {\r\n      display: flex;\r\n      padding: 1.6vw 1.6vw 0;\r\n      height: 4.81vh;\r\n      line-height: 4.81vh;\r\n      color: rgba(255, 255, 255, 0.40);\r\n      overflow: hidden;\r\n      overflow-x: auto;\r\n      &::-webkit-scrollbar {\r\n        display: none; /* 隐藏滚动条 */\r\n      }\r\n      >div {\r\n        margin: 0 3.2vw;\r\n        white-space: nowrap;\r\n      }\r\n      .active {\r\n        color: #FFFFFF;\r\n      }\r\n    }\r\n    .editor-video-menu-itmes {\r\n      padding: 0 3.33vw;\r\n      max-height: calc(100% - 4.81vh - 1.6vw);\r\n      display: grid;\r\n      grid-template-columns: repeat(4, 1fr);\r\n      row-gap: 3.2vw;\r\n      column-gap: 2.6vw;\r\n      overflow: auto;\r\n      >div {\r\n        width: 21.33vw;\r\n        height: 21.33vw;\r\n        background-color: #1e1e1e;\r\n        img {\r\n          width: 100%;\r\n          height: 100%;\r\n          object-fit: contain;\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n}\r\n\r\n@media screen and (min-width: 750px) {\r\n  .editor {\r\n    .controls-box {\r\n      height: 20% !important;\r\n      border-radius: 3.2vw;\r\n    }\r\n    .player-controls {\r\n      display: flex;\r\n      align-items: center;\r\n      width: 100%;\r\n      height: 100%;\r\n      padding: 0 1%;\r\n      .mr-16 {\r\n        margin-right: 2.13vw;\r\n      }\r\n      .player-controls-toggle {\r\n        >img {\r\n          display: block;\r\n          width: 30px !important;\r\n          height: 30px !important;\r\n          cursor: pointer;\r\n        }\r\n      }\r\n      .player-controls-seekbar {\r\n        flex: 1;\r\n        .seekbar-container {\r\n          height: 2px !important;\r\n          .seekbar-background {\r\n            height: 8px !important;\r\n            width: 100%;\r\n            border-radius: 1vw;\r\n            .seekbar-fill {\r\n              width: 100%;\r\n              height: 80%;\r\n              border-radius: 1vw;\r\n            }\r\n            .seekbar-line {\r\n              height: 100%;\r\n              border-radius: 1vw;\r\n            }\r\n            .seekbar-sign {\r\n              width: 10px;\r\n              top: 50%;\r\n              margin-top: -6px;\r\n            }\r\n            .seekbar-cirle {\r\n              top: -5px !important;\r\n              width: 20px !important;\r\n              height: 20px !important;\r\n            }\r\n          }\r\n        }\r\n      }\r\n      .player-controls-time {\r\n        width: 60px !important;\r\n      }\r\n    }\r\n  }\r\n}\r\n\r\n"]} */`;
|
|
314
313
|
document.head.appendChild(document.createElement("style")).appendChild(document.createTextNode(css));
|
|
315
314
|
|
|
316
315
|
// src/utils/const.ts
|
|
@@ -1012,7 +1011,7 @@ function usePeekControl(canvas, hideConfig) {
|
|
|
1012
1011
|
return canvas;
|
|
1013
1012
|
}
|
|
1014
1013
|
var EditorCanvas = react.forwardRef(
|
|
1015
|
-
({ previewState, showCanvas, canvasSize, enterPreview, intoTextEdit, frame, vmml, dragState, initFcObjs, editClips = [], onVideoChange, isBatchModify, hideConfig }, ref) => {
|
|
1014
|
+
({ previewState, showCanvas, canvasSize, enterPreview, intoTextEdit, frame, vmml, dragState, initFcObjs, editClips = [], onVideoChange, isBatchModify, hideConfig, textWarapCenter }, ref) => {
|
|
1016
1015
|
const [fc, setFc] = react.useState(null);
|
|
1017
1016
|
const [history, setHistory] = react.useState(null);
|
|
1018
1017
|
const [canvasReady, setCanvasReady] = react.useState(false);
|
|
@@ -1454,6 +1453,7 @@ var EditorCanvas = react.forwardRef(
|
|
|
1454
1453
|
lines.forEach((line) => {
|
|
1455
1454
|
const p = document.createElement("p");
|
|
1456
1455
|
p.style.position = "relative";
|
|
1456
|
+
p.style.display = "flex";
|
|
1457
1457
|
p.style.fontSize = "22px";
|
|
1458
1458
|
p.style.lineHeight = "22px";
|
|
1459
1459
|
p.style.fontFamily = fontFamily;
|
|
@@ -1462,6 +1462,7 @@ var EditorCanvas = react.forwardRef(
|
|
|
1462
1462
|
p.style.padding = "0";
|
|
1463
1463
|
if (letterSpacing) p.style.letterSpacing = `${letterSpacing}px`;
|
|
1464
1464
|
p.style.zIndex = "2";
|
|
1465
|
+
if (textWarapCenter) p.style.justifyContent = "center";
|
|
1465
1466
|
const fill = document.createElement("span");
|
|
1466
1467
|
fill.textContent = line || " ";
|
|
1467
1468
|
fill.style.color = textColor;
|
|
@@ -1470,11 +1471,17 @@ var EditorCanvas = react.forwardRef(
|
|
|
1470
1471
|
const stroke = document.createElement("span");
|
|
1471
1472
|
stroke.textContent = line || " ";
|
|
1472
1473
|
stroke.style.position = "absolute";
|
|
1473
|
-
stroke.style.left = "0";
|
|
1474
|
-
stroke.style.top = "0";
|
|
1475
1474
|
stroke.style.color = "transparent";
|
|
1476
1475
|
stroke.style.webkitTextStrokeWidth = `${strokeW}px`;
|
|
1477
1476
|
stroke.style.webkitTextStrokeColor = stColor;
|
|
1477
|
+
if (textWarapCenter) {
|
|
1478
|
+
stroke.style.left = "50%";
|
|
1479
|
+
stroke.style.top = "50%";
|
|
1480
|
+
stroke.style.transform = "translate(-50%, -50%)";
|
|
1481
|
+
} else {
|
|
1482
|
+
stroke.style.left = "0";
|
|
1483
|
+
stroke.style.top = "0";
|
|
1484
|
+
}
|
|
1478
1485
|
stroke.style.zIndex = "-1";
|
|
1479
1486
|
p.appendChild(fill);
|
|
1480
1487
|
p.appendChild(stroke);
|
|
@@ -2420,6 +2427,7 @@ var EditorFn = ({
|
|
|
2420
2427
|
height = "100vh",
|
|
2421
2428
|
pauseWhenBuffering = false,
|
|
2422
2429
|
isBatchModify = false,
|
|
2430
|
+
textWarapCenter = false,
|
|
2423
2431
|
hideConfig = null
|
|
2424
2432
|
// { hideDelete: false, hideEdit: false, hideMute: false, hideVolume: false }
|
|
2425
2433
|
}, ref) => {
|
|
@@ -2706,15 +2714,6 @@ var EditorFn = ({
|
|
|
2706
2714
|
initCanEditClips(vmmlState.template.tracks);
|
|
2707
2715
|
}
|
|
2708
2716
|
}, [editableArray, refreshEdit, vmmlState]);
|
|
2709
|
-
react.useEffect(() => {
|
|
2710
|
-
var _a2;
|
|
2711
|
-
if (propVmml) {
|
|
2712
|
-
const convertedVmml = vmmlUtils.convertVmmlTextScaleByForbidden(propVmml);
|
|
2713
|
-
setVmmlState(convertedVmml);
|
|
2714
|
-
setDurationInFrames(vmmlUtils.getFrames(((_a2 = propVmml == null ? void 0 : propVmml.template) == null ? void 0 : _a2.duration) || 1, fps));
|
|
2715
|
-
setRefreshEdit(Date.now());
|
|
2716
|
-
}
|
|
2717
|
-
}, [propVmml]);
|
|
2718
2717
|
react.useEffect(() => {
|
|
2719
2718
|
if (vmmlState) {
|
|
2720
2719
|
initFcObjects(vmmlState.template.tracks);
|
|
@@ -2724,8 +2723,10 @@ var EditorFn = ({
|
|
|
2724
2723
|
if (player) {
|
|
2725
2724
|
const parent = player.getContainerNode();
|
|
2726
2725
|
if (!canvasSize.width) {
|
|
2726
|
+
console.log(parent, "parent>>>>");
|
|
2727
2727
|
const playerElement = parent == null ? void 0 : parent.children[0];
|
|
2728
2728
|
const { width, height: height2 } = (playerElement == null ? void 0 : playerElement.getBoundingClientRect()) || {};
|
|
2729
|
+
console.log(height2);
|
|
2729
2730
|
setCanvasSize({ width, height: height2, top: playerElement.offsetTop });
|
|
2730
2731
|
}
|
|
2731
2732
|
player.addEventListener("play", onPlay);
|
|
@@ -2762,31 +2763,30 @@ var EditorFn = ({
|
|
|
2762
2763
|
setPreviewState(false);
|
|
2763
2764
|
}
|
|
2764
2765
|
}, [dragState]);
|
|
2765
|
-
const
|
|
2766
|
-
var _a2, _b;
|
|
2766
|
+
const updateEditor = (v, checkFrame) => {
|
|
2767
|
+
var _a2, _b, _c, _d;
|
|
2767
2768
|
const { current: playerCurrent } = vmmlPlayerRef;
|
|
2768
2769
|
const { current: canvasCurrent } = canvasRef;
|
|
2769
2770
|
if (!playerCurrent) return;
|
|
2770
|
-
|
|
2771
|
+
const isSame = JSON.stringify(v) === JSON.stringify(vmmlState);
|
|
2772
|
+
console.log(v, vmmlState, isSame, "\u5224\u65ADvmml\u662F\u5426\u76F8\u540C");
|
|
2771
2773
|
needPlay.current = false;
|
|
2772
|
-
const
|
|
2773
|
-
|
|
2774
|
-
|
|
2775
|
-
const convertedVmml = vmmlUtils.convertVmmlTextScaleByForbidden(v);
|
|
2774
|
+
const convertedVmml = vmmlUtils.convertVmmlTextScaleByForbidden(v);
|
|
2775
|
+
if (!isSame) {
|
|
2776
|
+
(_b = (_a2 = canvasCurrent == null ? void 0 : canvasCurrent.getCanvasCtx()) == null ? void 0 : _a2.clear) == null ? void 0 : _b.call(_a2);
|
|
2776
2777
|
setVmmlState(convertedVmml);
|
|
2777
|
-
setDurationInFrames(vmmlUtils.getFrames(((
|
|
2778
|
-
playerCurrent.setVmml(convertedVmml, currentFrame);
|
|
2778
|
+
setDurationInFrames(vmmlUtils.getFrames(((_c = v == null ? void 0 : v.template) == null ? void 0 : _c.duration) || 1, fps));
|
|
2779
2779
|
setRefreshEdit(Date.now());
|
|
2780
|
-
|
|
2781
|
-
|
|
2782
|
-
|
|
2783
|
-
|
|
2780
|
+
}
|
|
2781
|
+
const currentFrame = checkFrame ?? pauseFrame;
|
|
2782
|
+
playerCurrent.setVmml(convertedVmml, currentFrame);
|
|
2783
|
+
(_d = canvasCurrent == null ? void 0 : canvasCurrent.checkObjectInPoint) == null ? void 0 : _d.call(canvasCurrent, currentFrame);
|
|
2784
2784
|
};
|
|
2785
2785
|
const getCurrentFrame = () => {
|
|
2786
2786
|
if (!player) return 0;
|
|
2787
2787
|
return player.getCurrentFrame();
|
|
2788
2788
|
};
|
|
2789
|
-
const
|
|
2789
|
+
const editorSeekTo = (frame2) => {
|
|
2790
2790
|
var _a2;
|
|
2791
2791
|
(_a2 = player == null ? void 0 : player.seekTo) == null ? void 0 : _a2.call(player, frame2 ?? 0);
|
|
2792
2792
|
const { current: canvasCurrent } = canvasRef;
|
|
@@ -2799,13 +2799,20 @@ var EditorFn = ({
|
|
|
2799
2799
|
() => ({
|
|
2800
2800
|
getActions,
|
|
2801
2801
|
getfcObject,
|
|
2802
|
+
// 获取画布上所有对象
|
|
2802
2803
|
getCurrentFrame,
|
|
2804
|
+
// 获取当前帧
|
|
2803
2805
|
getVmml,
|
|
2804
|
-
|
|
2806
|
+
// 获取vmml
|
|
2805
2807
|
getPlayer,
|
|
2808
|
+
// 获取player实例
|
|
2806
2809
|
texteditClose,
|
|
2807
2810
|
textFinish,
|
|
2808
|
-
|
|
2811
|
+
// 完成按钮事件
|
|
2812
|
+
editorSeekTo,
|
|
2813
|
+
// editor的seek事件 入参:frame
|
|
2814
|
+
updateEditor
|
|
2815
|
+
// 更新editor 入参:vmml, frame
|
|
2809
2816
|
}),
|
|
2810
2817
|
[vmmlState, player]
|
|
2811
2818
|
);
|
|
@@ -2845,7 +2852,8 @@ var EditorFn = ({
|
|
|
2845
2852
|
onPlayerReady,
|
|
2846
2853
|
premountFor: 40,
|
|
2847
2854
|
pauseWhenBuffering,
|
|
2848
|
-
filterIds
|
|
2855
|
+
filterIds,
|
|
2856
|
+
textWarapCenter
|
|
2849
2857
|
}
|
|
2850
2858
|
) }),
|
|
2851
2859
|
/* @__PURE__ */ jsxRuntime.jsx(
|
|
@@ -2864,26 +2872,27 @@ var EditorFn = ({
|
|
|
2864
2872
|
editClips,
|
|
2865
2873
|
onVideoChange,
|
|
2866
2874
|
isBatchModify,
|
|
2867
|
-
hideConfig
|
|
2875
|
+
hideConfig,
|
|
2876
|
+
textWarapCenter
|
|
2868
2877
|
}
|
|
2869
2878
|
),
|
|
2870
|
-
/* @__PURE__ */ jsxRuntime.jsx("div", { className: "controls-box", children: /* @__PURE__ */ jsxRuntime.jsx(
|
|
2871
|
-
Controls_default,
|
|
2872
|
-
{
|
|
2873
|
-
player,
|
|
2874
|
-
vmmlRef: vmmlPlayerRef,
|
|
2875
|
-
fps,
|
|
2876
|
-
durationInFrames,
|
|
2877
|
-
intoEdit,
|
|
2878
|
-
frame,
|
|
2879
|
-
isPlaying,
|
|
2880
|
-
setDragState,
|
|
2881
|
-
onControlsClick,
|
|
2882
|
-
signList
|
|
2883
|
-
}
|
|
2884
|
-
) }),
|
|
2885
2879
|
/* @__PURE__ */ jsxRuntime.jsx(Loading_default, { show: loading })
|
|
2886
2880
|
] }) }),
|
|
2881
|
+
/* @__PURE__ */ jsxRuntime.jsx("div", { className: "controls-box", children: /* @__PURE__ */ jsxRuntime.jsx(
|
|
2882
|
+
Controls_default,
|
|
2883
|
+
{
|
|
2884
|
+
player,
|
|
2885
|
+
vmmlRef: vmmlPlayerRef,
|
|
2886
|
+
fps,
|
|
2887
|
+
durationInFrames,
|
|
2888
|
+
intoEdit,
|
|
2889
|
+
frame,
|
|
2890
|
+
isPlaying,
|
|
2891
|
+
setDragState,
|
|
2892
|
+
onControlsClick,
|
|
2893
|
+
signList
|
|
2894
|
+
}
|
|
2895
|
+
) }),
|
|
2887
2896
|
/* @__PURE__ */ jsxRuntime.jsx("div", { className: "padding-box" }),
|
|
2888
2897
|
(maxText > 0 || maxVideo > 0) && /* @__PURE__ */ jsxRuntime.jsxs("section", { style: menuStyles, className: `footer ${menuState === "text" ? "text-style" : ""}`, children: [
|
|
2889
2898
|
maxText > 0 && /* @__PURE__ */ jsxRuntime.jsxs(
|