@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/dist/index.mjs CHANGED
@@ -87,14 +87,13 @@ var css = `@charset "UTF-8";
87
87
  width: 100%;
88
88
  height: 100%;
89
89
  }
90
- .editor .main .controls-box {
90
+ .editor .controls-box {
91
+ position: relative;
91
92
  height: 12vw;
92
- position: absolute;
93
- bottom: 0;
94
93
  width: 100%;
95
94
  border-radius: 3.2vw;
96
95
  }
97
- .editor .main .player-controls {
96
+ .editor .player-controls {
98
97
  display: flex;
99
98
  align-items: center;
100
99
  width: 100%;
@@ -103,20 +102,20 @@ var css = `@charset "UTF-8";
103
102
  box-sizing: border-box;
104
103
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.6) 100%);
105
104
  }
106
- .editor .main .player-controls .mr-16 {
105
+ .editor .player-controls .mr-16 {
107
106
  margin-right: 2.13vw;
108
107
  }
109
- .editor .main .player-controls .player-controls-toggle > img {
108
+ .editor .player-controls .player-controls-toggle > img {
110
109
  display: block;
111
110
  width: 4.8vw;
112
111
  height: 4.8vw;
113
112
  cursor: pointer;
114
113
  }
115
- .editor .main .player-controls .player-controls-seekbar {
114
+ .editor .player-controls .player-controls-seekbar {
116
115
  flex: 1;
117
116
  position: relative;
118
117
  }
119
- .editor .main .player-controls .player-controls-seekbar .seekbar-container {
118
+ .editor .player-controls .player-controls-seekbar .seekbar-container {
120
119
  height: 100%;
121
120
  user-select: none;
122
121
  touch-action: none;
@@ -124,32 +123,32 @@ var css = `@charset "UTF-8";
124
123
  cursor: pointer;
125
124
  box-sizing: border-box;
126
125
  }
127
- .editor .main .player-controls .player-controls-seekbar .seekbar-container .seekbar-background {
126
+ .editor .player-controls .player-controls-seekbar .seekbar-container .seekbar-background {
128
127
  user-select: none;
129
128
  height: 1.6vw;
130
129
  width: 100%;
131
130
  background-color: rgba(255, 255, 255, 0.2);
132
131
  border-radius: 1vw;
133
132
  }
134
- .editor .main .player-controls .player-controls-seekbar .seekbar-container .seekbar-background .seekbar-fill {
133
+ .editor .player-controls .player-controls-seekbar .seekbar-container .seekbar-background .seekbar-fill {
135
134
  position: absolute;
136
135
  user-select: none;
137
136
  width: 100%;
138
137
  height: 100%;
139
138
  border-radius: 1vw;
140
139
  }
141
- .editor .main .player-controls .player-controls-seekbar .seekbar-container .seekbar-background .seekbar-line {
140
+ .editor .player-controls .player-controls-seekbar .seekbar-container .seekbar-background .seekbar-line {
142
141
  height: 100%;
143
142
  border-radius: 1vw;
144
143
  background-color: #eeeeee;
145
144
  }
146
- .editor .main .player-controls .player-controls-seekbar .seekbar-container .seekbar-background .seekbar-sign {
145
+ .editor .player-controls .player-controls-seekbar .seekbar-container .seekbar-background .seekbar-sign {
147
146
  width: 10px;
148
147
  position: absolute;
149
148
  top: 50%;
150
149
  margin-top: -6px;
151
150
  }
152
- .editor .main .player-controls .player-controls-seekbar .seekbar-container .seekbar-background .seekbar-cirle {
151
+ .editor .player-controls .player-controls-seekbar .seekbar-container .seekbar-background .seekbar-cirle {
153
152
  position: absolute;
154
153
  top: -0.8vw;
155
154
  width: 3.2vw;
@@ -157,23 +156,23 @@ var css = `@charset "UTF-8";
157
156
  border-radius: 50%;
158
157
  background: #eeeeee;
159
158
  }
160
- .editor .main .player-controls .player-controls-time {
159
+ .editor .player-controls .player-controls-time {
161
160
  width: 10vw;
162
161
  color: #fff;
163
162
  }
164
- .editor .main .play-btn {
163
+ .editor .play-btn {
165
164
  position: absolute;
166
165
  bottom: 4vw;
167
166
  left: 3vw;
168
167
  width: 4.8vw;
169
168
  height: 4.8vw;
170
169
  }
171
- .editor .main .play-btn img {
170
+ .editor .play-btn img {
172
171
  width: 100%;
173
172
  height: 100%;
174
173
  display: block;
175
174
  }
176
- .editor .main .opacity-06 {
175
+ .editor .opacity-06 {
177
176
  opacity: 0.6;
178
177
  }
179
178
  .editor .footer {
@@ -308,7 +307,7 @@ var css = `@charset "UTF-8";
308
307
  width: 60px !important;
309
308
  }
310
309
  }
311
- /*# 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"]} */`;
310
+ /*# 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"]} */`;
312
311
  document.head.appendChild(document.createElement("style")).appendChild(document.createTextNode(css));
313
312
 
314
313
  // src/utils/const.ts
@@ -1010,7 +1009,7 @@ function usePeekControl(canvas, hideConfig) {
1010
1009
  return canvas;
1011
1010
  }
1012
1011
  var EditorCanvas = forwardRef(
1013
- ({ previewState, showCanvas, canvasSize, enterPreview, intoTextEdit, frame, vmml, dragState, initFcObjs, editClips = [], onVideoChange, isBatchModify, hideConfig }, ref) => {
1012
+ ({ previewState, showCanvas, canvasSize, enterPreview, intoTextEdit, frame, vmml, dragState, initFcObjs, editClips = [], onVideoChange, isBatchModify, hideConfig, textWarapCenter }, ref) => {
1014
1013
  const [fc, setFc] = useState(null);
1015
1014
  const [history, setHistory] = useState(null);
1016
1015
  const [canvasReady, setCanvasReady] = useState(false);
@@ -1452,6 +1451,7 @@ var EditorCanvas = forwardRef(
1452
1451
  lines.forEach((line) => {
1453
1452
  const p = document.createElement("p");
1454
1453
  p.style.position = "relative";
1454
+ p.style.display = "flex";
1455
1455
  p.style.fontSize = "22px";
1456
1456
  p.style.lineHeight = "22px";
1457
1457
  p.style.fontFamily = fontFamily;
@@ -1460,6 +1460,7 @@ var EditorCanvas = forwardRef(
1460
1460
  p.style.padding = "0";
1461
1461
  if (letterSpacing) p.style.letterSpacing = `${letterSpacing}px`;
1462
1462
  p.style.zIndex = "2";
1463
+ if (textWarapCenter) p.style.justifyContent = "center";
1463
1464
  const fill = document.createElement("span");
1464
1465
  fill.textContent = line || " ";
1465
1466
  fill.style.color = textColor;
@@ -1468,11 +1469,17 @@ var EditorCanvas = forwardRef(
1468
1469
  const stroke = document.createElement("span");
1469
1470
  stroke.textContent = line || " ";
1470
1471
  stroke.style.position = "absolute";
1471
- stroke.style.left = "0";
1472
- stroke.style.top = "0";
1473
1472
  stroke.style.color = "transparent";
1474
1473
  stroke.style.webkitTextStrokeWidth = `${strokeW}px`;
1475
1474
  stroke.style.webkitTextStrokeColor = stColor;
1475
+ if (textWarapCenter) {
1476
+ stroke.style.left = "50%";
1477
+ stroke.style.top = "50%";
1478
+ stroke.style.transform = "translate(-50%, -50%)";
1479
+ } else {
1480
+ stroke.style.left = "0";
1481
+ stroke.style.top = "0";
1482
+ }
1476
1483
  stroke.style.zIndex = "-1";
1477
1484
  p.appendChild(fill);
1478
1485
  p.appendChild(stroke);
@@ -2418,6 +2425,7 @@ var EditorFn = ({
2418
2425
  height = "100vh",
2419
2426
  pauseWhenBuffering = false,
2420
2427
  isBatchModify = false,
2428
+ textWarapCenter = false,
2421
2429
  hideConfig = null
2422
2430
  // { hideDelete: false, hideEdit: false, hideMute: false, hideVolume: false }
2423
2431
  }, ref) => {
@@ -2704,15 +2712,6 @@ var EditorFn = ({
2704
2712
  initCanEditClips(vmmlState.template.tracks);
2705
2713
  }
2706
2714
  }, [editableArray, refreshEdit, vmmlState]);
2707
- useEffect(() => {
2708
- var _a2;
2709
- if (propVmml) {
2710
- const convertedVmml = convertVmmlTextScaleByForbidden(propVmml);
2711
- setVmmlState(convertedVmml);
2712
- setDurationInFrames(getFrames(((_a2 = propVmml == null ? void 0 : propVmml.template) == null ? void 0 : _a2.duration) || 1, fps));
2713
- setRefreshEdit(Date.now());
2714
- }
2715
- }, [propVmml]);
2716
2715
  useEffect(() => {
2717
2716
  if (vmmlState) {
2718
2717
  initFcObjects(vmmlState.template.tracks);
@@ -2722,8 +2721,10 @@ var EditorFn = ({
2722
2721
  if (player) {
2723
2722
  const parent = player.getContainerNode();
2724
2723
  if (!canvasSize.width) {
2724
+ console.log(parent, "parent>>>>");
2725
2725
  const playerElement = parent == null ? void 0 : parent.children[0];
2726
2726
  const { width, height: height2 } = (playerElement == null ? void 0 : playerElement.getBoundingClientRect()) || {};
2727
+ console.log(height2);
2727
2728
  setCanvasSize({ width, height: height2, top: playerElement.offsetTop });
2728
2729
  }
2729
2730
  player.addEventListener("play", onPlay);
@@ -2760,31 +2761,30 @@ var EditorFn = ({
2760
2761
  setPreviewState(false);
2761
2762
  }
2762
2763
  }, [dragState]);
2763
- const updateVmml = (v, checkFrame) => {
2764
- var _a2, _b;
2764
+ const updateEditor = (v, checkFrame) => {
2765
+ var _a2, _b, _c, _d;
2765
2766
  const { current: playerCurrent } = vmmlPlayerRef;
2766
2767
  const { current: canvasCurrent } = canvasRef;
2767
2768
  if (!playerCurrent) return;
2768
- (_b = (_a2 = canvasCurrent == null ? void 0 : canvasCurrent.getCanvasCtx()) == null ? void 0 : _a2.clear) == null ? void 0 : _b.call(_a2);
2769
+ const isSame = JSON.stringify(v) === JSON.stringify(vmmlState);
2770
+ console.log(v, vmmlState, isSame, "\u5224\u65ADvmml\u662F\u5426\u76F8\u540C");
2769
2771
  needPlay.current = false;
2770
- const currentFrame = checkFrame ?? pauseFrame;
2771
- requestAnimationFrame(() => {
2772
- var _a3;
2773
- const convertedVmml = convertVmmlTextScaleByForbidden(v);
2772
+ const convertedVmml = convertVmmlTextScaleByForbidden(v);
2773
+ if (!isSame) {
2774
+ (_b = (_a2 = canvasCurrent == null ? void 0 : canvasCurrent.getCanvasCtx()) == null ? void 0 : _a2.clear) == null ? void 0 : _b.call(_a2);
2774
2775
  setVmmlState(convertedVmml);
2775
- setDurationInFrames(getFrames(((_a3 = v == null ? void 0 : v.template) == null ? void 0 : _a3.duration) || 1, fps));
2776
- playerCurrent.setVmml(convertedVmml, currentFrame);
2776
+ setDurationInFrames(getFrames(((_c = v == null ? void 0 : v.template) == null ? void 0 : _c.duration) || 1, fps));
2777
2777
  setRefreshEdit(Date.now());
2778
- if (canvasCurrent) {
2779
- canvasCurrent.checkObjectInPoint(currentFrame);
2780
- }
2781
- });
2778
+ }
2779
+ const currentFrame = checkFrame ?? pauseFrame;
2780
+ playerCurrent.setVmml(convertedVmml, currentFrame);
2781
+ (_d = canvasCurrent == null ? void 0 : canvasCurrent.checkObjectInPoint) == null ? void 0 : _d.call(canvasCurrent, currentFrame);
2782
2782
  };
2783
2783
  const getCurrentFrame = () => {
2784
2784
  if (!player) return 0;
2785
2785
  return player.getCurrentFrame();
2786
2786
  };
2787
- const EditorSeekTo = (frame2) => {
2787
+ const editorSeekTo = (frame2) => {
2788
2788
  var _a2;
2789
2789
  (_a2 = player == null ? void 0 : player.seekTo) == null ? void 0 : _a2.call(player, frame2 ?? 0);
2790
2790
  const { current: canvasCurrent } = canvasRef;
@@ -2797,13 +2797,20 @@ var EditorFn = ({
2797
2797
  () => ({
2798
2798
  getActions,
2799
2799
  getfcObject,
2800
+ // 获取画布上所有对象
2800
2801
  getCurrentFrame,
2802
+ // 获取当前帧
2801
2803
  getVmml,
2802
- EditorSeekTo,
2804
+ // 获取vmml
2803
2805
  getPlayer,
2806
+ // 获取player实例
2804
2807
  texteditClose,
2805
2808
  textFinish,
2806
- updateVmml
2809
+ // 完成按钮事件
2810
+ editorSeekTo,
2811
+ // editor的seek事件 入参:frame
2812
+ updateEditor
2813
+ // 更新editor 入参:vmml, frame
2807
2814
  }),
2808
2815
  [vmmlState, player]
2809
2816
  );
@@ -2843,7 +2850,8 @@ var EditorFn = ({
2843
2850
  onPlayerReady,
2844
2851
  premountFor: 40,
2845
2852
  pauseWhenBuffering,
2846
- filterIds
2853
+ filterIds,
2854
+ textWarapCenter
2847
2855
  }
2848
2856
  ) }),
2849
2857
  /* @__PURE__ */ jsx(
@@ -2862,26 +2870,27 @@ var EditorFn = ({
2862
2870
  editClips,
2863
2871
  onVideoChange,
2864
2872
  isBatchModify,
2865
- hideConfig
2873
+ hideConfig,
2874
+ textWarapCenter
2866
2875
  }
2867
2876
  ),
2868
- /* @__PURE__ */ jsx("div", { className: "controls-box", children: /* @__PURE__ */ jsx(
2869
- Controls_default,
2870
- {
2871
- player,
2872
- vmmlRef: vmmlPlayerRef,
2873
- fps,
2874
- durationInFrames,
2875
- intoEdit,
2876
- frame,
2877
- isPlaying,
2878
- setDragState,
2879
- onControlsClick,
2880
- signList
2881
- }
2882
- ) }),
2883
2877
  /* @__PURE__ */ jsx(Loading_default, { show: loading })
2884
2878
  ] }) }),
2879
+ /* @__PURE__ */ jsx("div", { className: "controls-box", children: /* @__PURE__ */ jsx(
2880
+ Controls_default,
2881
+ {
2882
+ player,
2883
+ vmmlRef: vmmlPlayerRef,
2884
+ fps,
2885
+ durationInFrames,
2886
+ intoEdit,
2887
+ frame,
2888
+ isPlaying,
2889
+ setDragState,
2890
+ onControlsClick,
2891
+ signList
2892
+ }
2893
+ ) }),
2885
2894
  /* @__PURE__ */ jsx("div", { className: "padding-box" }),
2886
2895
  (maxText > 0 || maxVideo > 0) && /* @__PURE__ */ jsxs("section", { style: menuStyles, className: `footer ${menuState === "text" ? "text-style" : ""}`, children: [
2887
2896
  maxText > 0 && /* @__PURE__ */ jsxs(