@versa_ai/vmml-editor 1.0.48 → 1.0.49
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/index.js +111 -26
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +111 -26
- package/dist/index.mjs.map +1 -1
- package/package.json +1 -1
- package/src/assets/css/index.scss +1 -1
- package/src/components/Controls.tsx +2 -2
- package/src/components/EditorCanvas.tsx +61 -23
- package/src/index.tsx +62 -6
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.49 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
|
-
[
|
|
128
|
-
[
|
|
129
|
-
[
|
|
130
|
-
[
|
|
131
|
-
[
|
|
132
|
-
[
|
|
133
|
-
[32mDTS[39m ⚡️ Build success in
|
|
127
|
+
[32mCJS[39m [1mdist\index.js [22m[32m121.82 KB[39m
|
|
128
|
+
[32mCJS[39m [1mdist\index.js.map [22m[32m233.81 KB[39m
|
|
129
|
+
[32mCJS[39m ⚡️ Build success in 666ms
|
|
130
|
+
[32mESM[39m [1mdist\index.mjs [22m[32m119.95 KB[39m
|
|
131
|
+
[32mESM[39m [1mdist\index.mjs.map [22m[32m233.51 KB[39m
|
|
132
|
+
[32mESM[39m ⚡️ Build success in 666ms
|
|
133
|
+
[32mDTS[39m ⚡️ Build success in 1560ms
|
|
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
|
package/dist/index.js
CHANGED
|
@@ -86,7 +86,6 @@ var css = `@charset "UTF-8";
|
|
|
86
86
|
position: relative;
|
|
87
87
|
display: flex;
|
|
88
88
|
justify-content: center;
|
|
89
|
-
border-radius: 3.2vw;
|
|
90
89
|
overflow: hidden;
|
|
91
90
|
}
|
|
92
91
|
.editor .main .vessel {
|
|
@@ -313,7 +312,7 @@ var css = `@charset "UTF-8";
|
|
|
313
312
|
width: 60px !important;
|
|
314
313
|
}
|
|
315
314
|
}
|
|
316
|
-
/*# 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: 8px !important;\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"]} */`;
|
|
315
|
+
/*# 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;EAEA;;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: 8px !important;\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"]} */`;
|
|
317
316
|
document.head.appendChild(document.createElement("style")).appendChild(document.createTextNode(css));
|
|
318
317
|
|
|
319
318
|
// src/utils/const.ts
|
|
@@ -428,7 +427,7 @@ var SeekBar = ({ player, vmmlRef, frame, durationInFrames, intoEdit, setDragStat
|
|
|
428
427
|
] }) });
|
|
429
428
|
};
|
|
430
429
|
var SeekBar_default = SeekBar;
|
|
431
|
-
var Controls = ({ player, vmmlRef, frame, fps, durationInFrames, intoEdit, isPlaying, setDragState, onControlsClick, signList }) => {
|
|
430
|
+
var Controls = ({ player, vmmlRef, frame, fps, durationInFrames, intoEdit, isPlaying, setDragState, onControlsClick, signList, backgroundColor }) => {
|
|
432
431
|
const onClickToggle = (e) => {
|
|
433
432
|
if (isPlaying) {
|
|
434
433
|
intoEdit();
|
|
@@ -436,7 +435,7 @@ var Controls = ({ player, vmmlRef, frame, fps, durationInFrames, intoEdit, isPla
|
|
|
436
435
|
onControlsClick();
|
|
437
436
|
}
|
|
438
437
|
};
|
|
439
|
-
return /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "player-controls", children: [
|
|
438
|
+
return /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "player-controls", style: { backgroundColor }, children: [
|
|
440
439
|
/* @__PURE__ */ jsxRuntime.jsx("div", { className: "player-controls-toggle mr-16 opacity-06", onClick: onClickToggle, children: isPlaying ? /* @__PURE__ */ jsxRuntime.jsx("img", { src: pauseIcon, alt: "\u6682\u505C" }) : /* @__PURE__ */ jsxRuntime.jsx("img", { src: playIcon, alt: "\u64AD\u653E" }) }),
|
|
441
440
|
/* @__PURE__ */ jsxRuntime.jsx("div", { className: "player-controls-time opacity-06", children: vmmlUtils.formatTime(frame / fps) }),
|
|
442
441
|
/* @__PURE__ */ jsxRuntime.jsx("div", { className: "player-controls-seekbar mr-16", children: /* @__PURE__ */ jsxRuntime.jsx(SeekBar_default, { player, vmmlRef, frame, durationInFrames, intoEdit, setDragState, signList }) }),
|
|
@@ -1240,6 +1239,7 @@ var EditorCanvas = react.forwardRef(
|
|
|
1240
1239
|
}
|
|
1241
1240
|
};
|
|
1242
1241
|
const createEditObjes = async (canvas, time) => {
|
|
1242
|
+
setCanvasScale(vmml);
|
|
1243
1243
|
const promises = editClips.map((clip) => {
|
|
1244
1244
|
if (clip.videoClip) {
|
|
1245
1245
|
return createImageFromClip(clip);
|
|
@@ -1370,11 +1370,11 @@ var EditorCanvas = react.forwardRef(
|
|
|
1370
1370
|
lines.forEach((line, idx) => {
|
|
1371
1371
|
const y = -groupHeight / 2 + lineHeight / 2 + idx * lineHeight;
|
|
1372
1372
|
let originX = textBasicInfo.textAlign;
|
|
1373
|
-
let left = paddingX;
|
|
1373
|
+
let left = -groupWidth / 2 + paddingX;
|
|
1374
1374
|
if (originX === "center") {
|
|
1375
|
-
left =
|
|
1375
|
+
left = 0;
|
|
1376
1376
|
} else if (originX === "right") {
|
|
1377
|
-
left = groupWidth - paddingX;
|
|
1377
|
+
left = groupWidth / 2 - paddingX;
|
|
1378
1378
|
}
|
|
1379
1379
|
const strokeText = new fabric.fabric.Text(line || " ", {
|
|
1380
1380
|
fontFamily,
|
|
@@ -1386,7 +1386,6 @@ var EditorCanvas = react.forwardRef(
|
|
|
1386
1386
|
originY: "center",
|
|
1387
1387
|
left,
|
|
1388
1388
|
top: y,
|
|
1389
|
-
textAlign: "left",
|
|
1390
1389
|
objectCaching: false
|
|
1391
1390
|
});
|
|
1392
1391
|
const fillText = new fabric.fabric.Text(line || " ", {
|
|
@@ -1399,7 +1398,6 @@ var EditorCanvas = react.forwardRef(
|
|
|
1399
1398
|
strokeWidth: 0,
|
|
1400
1399
|
left,
|
|
1401
1400
|
top: y,
|
|
1402
|
-
textAlign: "left",
|
|
1403
1401
|
objectCaching: false
|
|
1404
1402
|
});
|
|
1405
1403
|
if (letterSpace) {
|
|
@@ -1413,7 +1411,7 @@ var EditorCanvas = react.forwardRef(
|
|
|
1413
1411
|
height: groupHeight + paddingY * 2,
|
|
1414
1412
|
// padddingY: 6.5
|
|
1415
1413
|
fill: bgColor,
|
|
1416
|
-
originX: "
|
|
1414
|
+
originX: "center",
|
|
1417
1415
|
originY: "center",
|
|
1418
1416
|
rx: round,
|
|
1419
1417
|
ry: round
|
|
@@ -1423,6 +1421,17 @@ var EditorCanvas = react.forwardRef(
|
|
|
1423
1421
|
fontFamily
|
|
1424
1422
|
};
|
|
1425
1423
|
};
|
|
1424
|
+
const getOrigin = (posParam, fontSize) => {
|
|
1425
|
+
const scaleX = posParam.scaleX * fontSize / 22 / widthScaleRef.current;
|
|
1426
|
+
const scaleY = posParam.scaleY * fontSize / 22 / heightScaleRef.current;
|
|
1427
|
+
const left = canvasSize.width * posParam.centerX;
|
|
1428
|
+
const top = canvasSize.height * posParam.centerY;
|
|
1429
|
+
return { scaleX, scaleY, top, left };
|
|
1430
|
+
};
|
|
1431
|
+
const setCanvasScale = (vmml2) => {
|
|
1432
|
+
heightScaleRef.current = vmml2.template.dimension.height / canvasSize.height;
|
|
1433
|
+
widthScaleRef.current = vmml2.template.dimension.width / canvasSize.width;
|
|
1434
|
+
};
|
|
1426
1435
|
const createTextFromClipCanvas = async (clip, fc2) => {
|
|
1427
1436
|
return new Promise(async (resolve) => {
|
|
1428
1437
|
const canvas = fc || fc2;
|
|
@@ -1430,10 +1439,7 @@ var EditorCanvas = react.forwardRef(
|
|
|
1430
1439
|
const { width, height } = vmml.template.dimension;
|
|
1431
1440
|
const fontSize = vmmlUtils.getFontSize(width, height);
|
|
1432
1441
|
const { textContent, backgroundColor, textColor, posParam, fontAssetUrl, alignType, strokeColor, strokeWidth, letterSpacing } = clip.textClip;
|
|
1433
|
-
const
|
|
1434
|
-
const scaleY = posParam.scaleY * fontSize / 22 / heightScaleRef.current;
|
|
1435
|
-
const left = canvasSize.width * posParam.centerX;
|
|
1436
|
-
const top = canvasSize.height * posParam.centerY;
|
|
1442
|
+
const { left, top, scaleX, scaleY } = getOrigin(posParam, fontSize);
|
|
1437
1443
|
const bgColor = backgroundColor ? vmmlUtils.argbToRgba(backgroundColor) : "transparent";
|
|
1438
1444
|
const strokeW = strokeColor && strokeWidth ? strokeWidth * 30 * 1.5 / fontSize : 0;
|
|
1439
1445
|
const stColor = strokeColor ? vmmlUtils.argbToRgba(strokeColor) : "transparent";
|
|
@@ -1571,42 +1577,69 @@ var EditorCanvas = react.forwardRef(
|
|
|
1571
1577
|
resolve(true);
|
|
1572
1578
|
});
|
|
1573
1579
|
};
|
|
1574
|
-
const updateText = async ({ id, textContent, bgColor, textColor, textBasicInfo, fontAssetUrl }) => {
|
|
1580
|
+
const updateText = async ({ id, textContent, bgColor, textColor, strokeColor, letterSpacing, strokeWidth, textBasicInfo, fontAssetUrl, posParam = null, alignType }) => {
|
|
1575
1581
|
var _a;
|
|
1582
|
+
const { width, height } = vmml.template.dimension;
|
|
1583
|
+
const fontSize = vmmlUtils.getFontSize(width, height);
|
|
1576
1584
|
const target = fc.getObjects().find((item) => {
|
|
1577
1585
|
var _a2;
|
|
1578
1586
|
return ((_a2 = item.clipData) == null ? void 0 : _a2.id) === id;
|
|
1579
1587
|
});
|
|
1580
|
-
const
|
|
1581
|
-
const originClip = (_a = target.clipData) == null ? void 0 : _a.originClip;
|
|
1588
|
+
const originClip = ((_a = target == null ? void 0 : target.clipData) == null ? void 0 : _a.originClip) ?? null;
|
|
1582
1589
|
if (originClip && (target == null ? void 0 : target.type) === "group") {
|
|
1590
|
+
const center = target.getCenterPoint();
|
|
1583
1591
|
const objects = target.getObjects();
|
|
1584
1592
|
const strokeText = objects[1];
|
|
1585
1593
|
target._objects.length = 0;
|
|
1586
|
-
const
|
|
1594
|
+
const stColor = strokeColor ?? "";
|
|
1595
|
+
const strokeW = strokeColor && strokeWidth ? strokeWidth * 30 * 1.5 / fontSize : strokeText.strokeWidth;
|
|
1596
|
+
const letterSpace = letterSpacing ? letterSpacing * 22 / fontSize * 45 : strokeText.charSpacing;
|
|
1597
|
+
const { objects: textObjects, fontFamily } = await createTextObjs({ strokeW: strokeW ?? 0, stColor, fontAssetUrl, letterSpace: letterSpace ?? 0, bgColor, textContent, textBasicInfo, textColor });
|
|
1598
|
+
let top = target.top;
|
|
1599
|
+
let left = target.left;
|
|
1600
|
+
let scaleX = target.scaleX;
|
|
1601
|
+
let scaleY = target.scaleY;
|
|
1602
|
+
if (posParam) {
|
|
1603
|
+
const obj = getOrigin(posParam, fontSize);
|
|
1604
|
+
({ left, top, scaleX, scaleY } = obj);
|
|
1605
|
+
}
|
|
1587
1606
|
textObjects.forEach((obj) => {
|
|
1588
1607
|
target.addWithUpdate(obj);
|
|
1589
1608
|
});
|
|
1609
|
+
const inFrame = vmmlUtils.getFrames(originClip.inPoint, 30);
|
|
1610
|
+
const durationFrame = vmmlUtils.getFrames(originClip.duration, 30);
|
|
1590
1611
|
target.set({
|
|
1591
|
-
visible:
|
|
1612
|
+
visible: frame >= inFrame && frame < inFrame + durationFrame,
|
|
1592
1613
|
clipData: {
|
|
1593
1614
|
...target.clipData,
|
|
1594
1615
|
textBasicInfo,
|
|
1595
1616
|
textColor,
|
|
1596
1617
|
text: textContent,
|
|
1597
1618
|
bgColor,
|
|
1619
|
+
fontAssetUrl,
|
|
1620
|
+
fontFamily,
|
|
1598
1621
|
isAiError: false
|
|
1599
1622
|
}
|
|
1600
1623
|
});
|
|
1601
|
-
target._calcBounds();
|
|
1602
|
-
target._updateObjectsCoords();
|
|
1603
1624
|
target.setPositionByOrigin(center, "center", "center");
|
|
1625
|
+
target.set({
|
|
1626
|
+
visible: frame >= inFrame && frame < inFrame + durationFrame,
|
|
1627
|
+
top,
|
|
1628
|
+
left,
|
|
1629
|
+
scaleY,
|
|
1630
|
+
scaleX
|
|
1631
|
+
});
|
|
1604
1632
|
originClip.textClip = {
|
|
1605
1633
|
...originClip.textClip,
|
|
1606
1634
|
textContent,
|
|
1635
|
+
letterSpacing: letterSpacing ?? 0,
|
|
1636
|
+
strokeWidth: strokeWidth ?? 0,
|
|
1637
|
+
alignType: alignType ?? (originClip == null ? void 0 : originClip.alignType) ?? 0,
|
|
1638
|
+
posParam: posParam ?? originClip.posParam,
|
|
1607
1639
|
backgroundColor: bgColor,
|
|
1608
1640
|
textColor,
|
|
1609
|
-
|
|
1641
|
+
fontAssetUrl,
|
|
1642
|
+
strokeColor: stColor
|
|
1610
1643
|
};
|
|
1611
1644
|
target.setCoords();
|
|
1612
1645
|
fc == null ? void 0 : fc.requestRenderAll();
|
|
@@ -2482,6 +2515,8 @@ var EditorFn = ({
|
|
|
2482
2515
|
pauseWhenBuffering = false,
|
|
2483
2516
|
isBatchModify = false,
|
|
2484
2517
|
textWarapCenter = false,
|
|
2518
|
+
backgroundColor = "#000",
|
|
2519
|
+
existenceBorderRadio = true,
|
|
2485
2520
|
hideConfig = { hideDelete: false, hideEdit: false, hideMute: false, hideVolume: false }
|
|
2486
2521
|
// { hideDelete: false, hideEdit: false, hideMute: false, hideVolume: false }
|
|
2487
2522
|
}, ref) => {
|
|
@@ -2512,9 +2547,9 @@ var EditorFn = ({
|
|
|
2512
2547
|
const vmmlConverterRef = react.useRef(null);
|
|
2513
2548
|
const [initFcObjs, setInitFcObjs] = react.useState([]);
|
|
2514
2549
|
const [editClips, setEditClips] = react.useState([]);
|
|
2515
|
-
const [refreshEdit, setRefreshEdit] = react.useState(0);
|
|
2516
2550
|
const vmmlFlag = react.useRef(false);
|
|
2517
2551
|
const needPlay = react.useRef(true);
|
|
2552
|
+
const needFreshEdit = react.useRef(true);
|
|
2518
2553
|
const setVmml = () => {
|
|
2519
2554
|
const { current } = vmmlPlayerRef;
|
|
2520
2555
|
if (!current) return;
|
|
@@ -2773,7 +2808,7 @@ var EditorFn = ({
|
|
|
2773
2808
|
}
|
|
2774
2809
|
}, [canvasSize, vmmlState]);
|
|
2775
2810
|
react.useEffect(() => {
|
|
2776
|
-
if (editableArray.length && (vmmlState == null ? void 0 : vmmlState.template)) {
|
|
2811
|
+
if (editableArray.length && (vmmlState == null ? void 0 : vmmlState.template) && needFreshEdit.current) {
|
|
2777
2812
|
initCanEditClips(vmmlState.template.tracks);
|
|
2778
2813
|
}
|
|
2779
2814
|
}, [editableArray, vmmlState]);
|
|
@@ -2838,12 +2873,58 @@ var EditorFn = ({
|
|
|
2838
2873
|
if (!isSame) {
|
|
2839
2874
|
const currentV = cloneDeep__default.default(convertedVmml);
|
|
2840
2875
|
(_e = (_d = canvasCurrent == null ? void 0 : canvasCurrent.getCanvasCtx()) == null ? void 0 : _d.clear) == null ? void 0 : _e.call(_d);
|
|
2876
|
+
needFreshEdit.current = true;
|
|
2841
2877
|
setVmmlState(currentV);
|
|
2842
2878
|
setDurationInFrames(vmmlUtils.getFrames(((_f = currentV == null ? void 0 : currentV.template) == null ? void 0 : _f.duration) || 1, fps));
|
|
2843
2879
|
}
|
|
2844
2880
|
playerCurrent.setVmml(convertedVmml, currentFrame);
|
|
2845
2881
|
if (isSame) (_g = canvasCurrent == null ? void 0 : canvasCurrent.checkObjectInPoint) == null ? void 0 : _g.call(canvasCurrent, currentFrame);
|
|
2846
2882
|
};
|
|
2883
|
+
const updateEditorTextClips = (v, checkFrame) => {
|
|
2884
|
+
var _a2, _b, _c, _d, _e, _f;
|
|
2885
|
+
const { current: playerCurrent } = vmmlPlayerRef;
|
|
2886
|
+
const { current: canvasCurrent } = canvasRef;
|
|
2887
|
+
if (!playerCurrent) return;
|
|
2888
|
+
const playing = ((_b = (_a2 = playerCurrent == null ? void 0 : playerCurrent.playerRef) == null ? void 0 : _a2.isPlaying) == null ? void 0 : _b.call(_a2)) ?? false;
|
|
2889
|
+
if (!playing) needPlay.current = false;
|
|
2890
|
+
const currentFrame = checkFrame ?? (((_c = player == null ? void 0 : player.getCurrentFrame) == null ? void 0 : _c.call(player)) ?? frame ?? pauseFrame);
|
|
2891
|
+
setFrame(currentFrame);
|
|
2892
|
+
const convertedVmml = v;
|
|
2893
|
+
const currentV = cloneDeep__default.default(convertedVmml);
|
|
2894
|
+
needFreshEdit.current = false;
|
|
2895
|
+
setVmmlState(currentV);
|
|
2896
|
+
const tracks = (_e = (_d = currentV == null ? void 0 : currentV.template) == null ? void 0 : _d.tracks) == null ? void 0 : _e.filter((track) => track.type === 2);
|
|
2897
|
+
tracks == null ? void 0 : tracks.forEach((track) => {
|
|
2898
|
+
var _a3;
|
|
2899
|
+
(_a3 = track == null ? void 0 : track.clips) == null ? void 0 : _a3.forEach((clip) => {
|
|
2900
|
+
const { textClip = null } = clip;
|
|
2901
|
+
if (textClip) {
|
|
2902
|
+
const { textContent, backgroundColor: backgroundColor2, textColor, fontAssetUrl, alignType, letterSpacing, strokeWidth, strokeColor, posParam } = textClip;
|
|
2903
|
+
const textFill = vmmlUtils.argbToRgba(textColor || "#ffffffff");
|
|
2904
|
+
const textBasicInfo = {
|
|
2905
|
+
isBack: backgroundColor2 ? true : false,
|
|
2906
|
+
colorValue: textFill,
|
|
2907
|
+
colorName: "custom",
|
|
2908
|
+
textAlign: alignType === 1 ? "center" : alignType === 2 ? "right" : "left"
|
|
2909
|
+
};
|
|
2910
|
+
canvasCurrent == null ? void 0 : canvasCurrent.updateText({
|
|
2911
|
+
id: clip.id,
|
|
2912
|
+
textContent,
|
|
2913
|
+
letterSpacing,
|
|
2914
|
+
strokeWidth,
|
|
2915
|
+
strokeColor: vmmlUtils.argbToRgba(strokeColor),
|
|
2916
|
+
bgColor: vmmlUtils.argbToRgba(backgroundColor2),
|
|
2917
|
+
textColor: vmmlUtils.argbToRgba(textColor),
|
|
2918
|
+
fontAssetUrl,
|
|
2919
|
+
textBasicInfo,
|
|
2920
|
+
posParam
|
|
2921
|
+
});
|
|
2922
|
+
}
|
|
2923
|
+
});
|
|
2924
|
+
});
|
|
2925
|
+
playerCurrent.setVmml(convertedVmml, currentFrame);
|
|
2926
|
+
(_f = canvasCurrent == null ? void 0 : canvasCurrent.checkObjectInPoint) == null ? void 0 : _f.call(canvasCurrent, currentFrame);
|
|
2927
|
+
};
|
|
2847
2928
|
const getCurrentFrame = () => {
|
|
2848
2929
|
if (!player) return 0;
|
|
2849
2930
|
return player.getCurrentFrame();
|
|
@@ -2874,7 +2955,9 @@ var EditorFn = ({
|
|
|
2874
2955
|
// 完成按钮事件
|
|
2875
2956
|
editorSeekTo,
|
|
2876
2957
|
// editor的seek事件 入参:frame
|
|
2877
|
-
updateEditor
|
|
2958
|
+
updateEditor,
|
|
2959
|
+
// 更新editor 入参:vmml, frame
|
|
2960
|
+
updateEditorTextClips
|
|
2878
2961
|
// 更新editor 入参:vmml, frame
|
|
2879
2962
|
}),
|
|
2880
2963
|
[vmmlState, player]
|
|
@@ -2906,9 +2989,10 @@ var EditorFn = ({
|
|
|
2906
2989
|
/* @__PURE__ */ jsxRuntime.jsx("div", { className: "vessel", onClick: onClickMain, children: /* @__PURE__ */ jsxRuntime.jsx(
|
|
2907
2990
|
vmmlPlayer.VmmlPlayer,
|
|
2908
2991
|
{
|
|
2992
|
+
backgroundColor,
|
|
2909
2993
|
ref: vmmlPlayerRef,
|
|
2910
2994
|
vmml: vmmlState,
|
|
2911
|
-
existenceBorderRadio
|
|
2995
|
+
existenceBorderRadio,
|
|
2912
2996
|
moveToBeginningWhenEnded: true,
|
|
2913
2997
|
muted: true,
|
|
2914
2998
|
fps,
|
|
@@ -2944,6 +3028,7 @@ var EditorFn = ({
|
|
|
2944
3028
|
/* @__PURE__ */ jsxRuntime.jsx("div", { className: "controls-box", children: /* @__PURE__ */ jsxRuntime.jsx(
|
|
2945
3029
|
Controls_default,
|
|
2946
3030
|
{
|
|
3031
|
+
backgroundColor,
|
|
2947
3032
|
player,
|
|
2948
3033
|
vmmlRef: vmmlPlayerRef,
|
|
2949
3034
|
fps,
|