fl-web-component 2.1.1-beta.1 → 2.1.1-beta.3

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.
@@ -1 +1 @@
1
- @charset "UTF-8";.fl-model-containor[data-v-d40d4870]{width:100%;height:100%;position:relative;cursor:pointer}[data-v-d40d4870] .tips-label{width:60px;color:#000;font:12px Helvetica;margin-top:-3em;padding:5px;text-align:center;vertical-align:middle;background-color:khaki}[data-v-d40d4870] .measure-label{max-width:100px;margin-top:-1em;border:10px;border-radius:5px;padding:3px 10px;cursor:pointer;color:#009bea;background-color:#f4f4f4;-webkit-box-shadow:0 1px 3px 1px rgba(0,0,0,.25);box-shadow:0 1px 3px 1px rgba(0,0,0,.25)}[data-v-d40d4870] .circle-tag{width:10px;height:10px;margin-top:5px;border-radius:50%;background-color:#ff5000}[data-v-d40d4870] .measure-label-font{word-break:break-all}[data-v-d40d4870] .mark-label-img{padding-top:5px;width:20px;height:20px}.loading-overlay[data-v-d40d4870]{position:absolute;top:0;left:0;right:0;bottom:0;background-color:rgba(0,0,0,.7);display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;z-index:1000;opacity:0;visibility:hidden;-webkit-transition:opacity .3s ease,visibility .3s ease;transition:opacity .3s ease,visibility .3s ease}.loading-overlay--visible[data-v-d40d4870]{opacity:1;visibility:visible}.loading-content[data-v-d40d4870]{background:#fff;border-radius:12px;padding:30px;text-align:center;-webkit-box-shadow:0 8px 32px rgba(0,0,0,.3);box-shadow:0 8px 32px rgba(0,0,0,.3);min-width:300px;max-width:400px}.loading-spinner[data-v-d40d4870]{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #409eff;border-radius:50%;-webkit-animation:spin-d40d4870 1s linear infinite;animation:spin-d40d4870 1s linear infinite;margin:0 auto 20px}@-webkit-keyframes spin-d40d4870{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}to{-webkit-transform:rotate(1turn);transform:rotate(1turn)}}@keyframes spin-d40d4870{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}to{-webkit-transform:rotate(1turn);transform:rotate(1turn)}}.loading-text[data-v-d40d4870]{font-size:16px;font-weight:500;color:#333;margin-bottom:20px}.loading-this.progress-bar[data-v-d40d4870]{width:100%;height:8px;background-color:#f0f0f0;border-radius:4px;overflow:hidden;margin-bottom:15px}.loading-this.progress-fill[data-v-d40d4870]{height:100%;background:-webkit-gradient(linear,left top,right top,from(#409eff),to(#67c23a));background:linear-gradient(90deg,#409eff,#67c23a);border-radius:4px;-webkit-transition:width .3s ease;transition:width .3s ease}.loading-details[data-v-d40d4870]{font-size:12px;color:#666;line-height:1.5}.lil-this.gui{background:hsla(0,0%,100%,.95)!important;border:1px solid #e0e0e0!important;border-radius:8px!important;-webkit-box-shadow:0 4px 12px rgba(0,0,0,.15)!important;box-shadow:0 4px 12px rgba(0,0,0,.15)!important;backdrop-filter:blur(10px)!important;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif!important}.lil-this.gui .title{background:linear-gradient(135deg,#f8f9fa,#e9ecef)!important;color:#495057!important;border-bottom:1px solid #dee2e6!important;font-weight:600!important;padding:0 12px!important;border-radius:8px 8px 0 0!important}.lil-this.gui .controller{border-bottom:1px solid #f1f3f4!important;background:transparent!important}.lil-this.gui .controller:last-child{border-bottom:none!important}.lil-this.gui .controller .name{color:#495057!important;font-weight:500!important;font-size:12px!important}.lil-this.gui .controller .widget{background:#f8f9fa!important;border:1px solid #ced4da!important;border-radius:4px!important;color:#495057!important}.lil-this.gui .controller .widget:focus,.lil-this.gui .controller .widget:hover{border-color:#80bdff!important;-webkit-box-shadow:0 0 0 2px rgba(0,123,255,.25)!important;box-shadow:0 0 0 2px rgba(0,123,255,.25)!important}.lil-this.gui .controller .widget:focus{outline:none!important}.lil-this.gui .controller input[type=range]{background:#e9ecef!important;height:4px!important;-webkit-appearance:none!important;-moz-appearance:none!important;appearance:none!important;border-radius:2px!important}.lil-this.gui .controller.number .fill{border-right:solid #008de9}.lil-this.gui .controller input[type=range]::-webkit-slider-thumb{background:#007bff!important;border:2px solid #fff!important;-webkit-box-shadow:0 2px 4px rgba(0,0,0,.2)!important;box-shadow:0 2px 4px rgba(0,0,0,.2)!important;width:16px!important;height:16px!important;border-radius:50%!important;-webkit-appearance:none!important;appearance:none!important;cursor:pointer!important}.lil-this.gui .controller input[type=range]::-moz-range-thumb{background:#007bff!important;border:2px solid #fff!important;box-shadow:0 2px 4px rgba(0,0,0,.2)!important;width:16px!important;height:16px!important;border-radius:50%!important;cursor:pointer!important}.lil-this.gui .controller .option{background:#fff!important;color:#495057!important;border-bottom:1px solid #f1f3f4!important}.lil-this.gui .controller .option:hover{background:#f8f9fa!important}.lil-this.gui .controller .option:last-child{border-bottom:none!important}.lil-this.gui input:active{background:#e6eff4}.lil-this.gui .controller button{background:linear-gradient(135deg,#007bff,#0056b3)!important;color:#fff!important;border:none!important;border-radius:4px!important;font-weight:500!important;-webkit-transition:all .2s ease!important;transition:all .2s ease!important}.lil-this.gui .controller button:hover{background:linear-gradient(135deg,#0056b3,#004085)!important;-webkit-transform:translateY(-1px)!important;transform:translateY(-1px)!important;-webkit-box-shadow:0 4px 8px rgba(0,123,255,.3)!important;box-shadow:0 4px 8px rgba(0,123,255,.3)!important}.lil-this.gui .controller .color{border:2px solid #fff!important;border-radius:4px!important;-webkit-box-shadow:0 2px 4px rgba(0,0,0,.1)!important;box-shadow:0 2px 4px rgba(0,0,0,.1)!important}.lil-this.gui .controller.number .slider,.lil-this.gui .controller.number .slider:hover{background-color:#e6eff4}.lil-this.gui input,.lil-this.gui input:hover,.lil-this.gui input[type=number]:focus,.lil-this.gui input[type=text]:focus{background:#e6eff4}.lil-this.gui .controller>.name{min-width:25px}.lil-this.gui .controller.number input{color:#2e3136}.lil-this.gui .controller.number .slider:active{background-color:#e6eff4}.lil-this.gui .folder>.title{background:linear-gradient(135deg,#f1f3f4,#e9ecef)!important;color:#495057!important;border-bottom:1px solid #dee2e6!important}.lil-this.gui .folder>.title:before{color:#6c757d!important}.lil-this.gui .folder.closed>.children{display:none!important}#konva-container[data-v-e2de7752]{z-index:3;width:100%;height:100%;cursor:pointer;overflow:hidden}span[data-v-f547d5c6]{font-weight:bolder}.text[data-v-f547d5c6]{margin-top:20px}.line[data-v-f547d5c6]{border-bottom:1px solid #dcdfe6;margin:20px 0}.center[data-v-f547d5c6]{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-align:center;-ms-flex-align:center;align-items:center}.center .cen span[data-v-f547d5c6],.center .top span[data-v-f547d5c6]{color:"#53a8ff";display:inline-block;width:30px;height:30px;text-align:center;line-height:30px;border:1px solid;padding:5px;margin-bottom:10px;background-color:#e9f3ff}.center .cen span[data-v-f547d5c6]{margin:10px}.button[data-v-f547d5c6]{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-pack:end;-ms-flex-pack:end;justify-content:end;margin-top:20px}@font-face{font-family:iconfont;src:url(//at.alicdn.com/t/font_3226805_qqvo3ag3r8.woff2?t=1646635700216) format("woff2"),url(//at.alicdn.com/t/font_3226805_qqvo3ag3r8.woff?t=1646635700216) format("woff"),url(//at.alicdn.com/t/font_3226805_qqvo3ag3r8.ttf?t=1646635700216) format("truetype")}.iconfont[data-v-f547d5c6]{font-family:iconfont!important;font-size:50px;font-style:normal;color:"#53a8ff";-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.icon-shubiao[data-v-f547d5c6]:before{content:""}.main_body[data-v-4b17bce0]{position:relative;width:100%;height:100%;-webkit-box-sizing:border-box;box-sizing:border-box;overflow:hidden}.classification_title[data-v-4b17bce0]{margin:0 0 10px 0;color:#fff;font-size:14px;cursor:default}.toolbar[data-v-4b17bce0]{z-index:10;position:absolute;width:520px;padding:8px 16px;border-radius:6px;-webkit-box-shadow:0 2px 10px 0 rgba(6,29,44,.25);box-shadow:0 2px 10px 0 rgba(6,29,44,.25);background-color:#fff;top:10px;left:50%;-webkit-box-sizing:border-box;box-sizing:border-box;-webkit-transform:translateX(-50%);transform:translateX(-50%);display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-pack:distribute;justify-content:space-around}.icon_toolbar[data-v-4b17bce0],.text_toolbar[data-v-4b17bce0]{float:left;width:32px;height:32px;padding:0!important;background-repeat:no-repeat;background-size:24px;background-position:50%}.icon_active[data-v-4b17bce0],.icon_toolbar[data-v-4b17bce0]:hover,.text_toolbar[data-v-4b17bce0]:hover{background-color:#eee}[data-v-4b17bce0].icon_color .el-color-picker__trigger{height:24px;margin-top:4px;width:24px!important}[data-v-4b17bce0].el-color-picker--medium,[data-v-4b17bce0].el-color-picker--medium .el-color-picker__trigger{width:24px!important;height:24px!important}.canvas_container[data-v-4b17bce0]{position:relative;width:100%;height:100%;overflow:auto;-webkit-box-sizing:border-box;box-sizing:border-box}.canvas_container canvas[data-v-4b17bce0]{position:absolute;left:0}.canvas_container #ctx_front[data-v-4b17bce0]{z-index:5;background-color:transparent}.canvas_container #ctx_back[data-v-4b17bce0]{z-index:3}.canvas_container #ctx_base[data-v-4b17bce0]{z-index:1}#text[data-v-4b17bce0]{position:absolute;z-index:-1;resize:none;outline:none;border:1px dashed #9c9c9c;overflow:hidden;background:transparent;line-height:30px;display:none}#text[data-v-4b17bce0]:hover{border:1px dashed #53a8ff}#svg-component[data-v-2572c0e2],#svg-tigger[data-v-2572c0e2]{cursor:pointer;height:100%;width:100%;position:relative}#toolbar-show[data-v-2572c0e2]{z-index:20;position:absolute;width:100%;height:100%;top:0;left:0;overflow:hidden;background:#fff}
1
+ @charset "UTF-8";.fl-model-containor[data-v-e9e4a7c2]{width:100%;height:100%;position:relative;cursor:pointer}[data-v-e9e4a7c2] .tips-label{width:60px;color:#000;font:12px Helvetica;margin-top:-3em;padding:5px;text-align:center;vertical-align:middle;background-color:khaki}[data-v-e9e4a7c2] .measure-label{max-width:100px;margin-top:-1em;border:10px;border-radius:5px;padding:3px 10px;cursor:pointer;color:#009bea;background-color:#f4f4f4;-webkit-box-shadow:0 1px 3px 1px rgba(0,0,0,.25);box-shadow:0 1px 3px 1px rgba(0,0,0,.25)}[data-v-e9e4a7c2] .circle-tag{width:10px;height:10px;margin-top:5px;border-radius:50%;background-color:#ff5000}[data-v-e9e4a7c2] .measure-label-font{word-break:break-all}[data-v-e9e4a7c2] .mark-label-img{padding-top:5px;width:20px;height:20px}.loading-overlay[data-v-e9e4a7c2]{position:absolute;top:0;left:0;right:0;bottom:0;background-color:rgba(0,0,0,.7);display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;z-index:1000;opacity:0;visibility:hidden;-webkit-transition:opacity .3s ease,visibility .3s ease;transition:opacity .3s ease,visibility .3s ease}.loading-overlay--visible[data-v-e9e4a7c2]{opacity:1;visibility:visible}.loading-content[data-v-e9e4a7c2]{background:#fff;border-radius:12px;padding:30px;text-align:center;-webkit-box-shadow:0 8px 32px rgba(0,0,0,.3);box-shadow:0 8px 32px rgba(0,0,0,.3);min-width:300px;max-width:400px}.loading-spinner[data-v-e9e4a7c2]{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #409eff;border-radius:50%;-webkit-animation:spin-e9e4a7c2 1s linear infinite;animation:spin-e9e4a7c2 1s linear infinite;margin:0 auto 20px}@-webkit-keyframes spin-e9e4a7c2{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}to{-webkit-transform:rotate(1turn);transform:rotate(1turn)}}@keyframes spin-e9e4a7c2{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}to{-webkit-transform:rotate(1turn);transform:rotate(1turn)}}.loading-text[data-v-e9e4a7c2]{font-size:16px;font-weight:500;color:#333;margin-bottom:20px}.loading-this.progress-bar[data-v-e9e4a7c2]{width:100%;height:8px;background-color:#f0f0f0;border-radius:4px;overflow:hidden;margin-bottom:15px}.loading-this.progress-fill[data-v-e9e4a7c2]{height:100%;background:-webkit-gradient(linear,left top,right top,from(#409eff),to(#67c23a));background:linear-gradient(90deg,#409eff,#67c23a);border-radius:4px;-webkit-transition:width .3s ease;transition:width .3s ease}.loading-details[data-v-e9e4a7c2]{font-size:12px;color:#666;line-height:1.5}.lil-this.gui{background:hsla(0,0%,100%,.95)!important;border:1px solid #e0e0e0!important;border-radius:8px!important;-webkit-box-shadow:0 4px 12px rgba(0,0,0,.15)!important;box-shadow:0 4px 12px rgba(0,0,0,.15)!important;backdrop-filter:blur(10px)!important;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif!important}.lil-this.gui .title{background:linear-gradient(135deg,#f8f9fa,#e9ecef)!important;color:#495057!important;border-bottom:1px solid #dee2e6!important;font-weight:600!important;padding:0 12px!important;border-radius:8px 8px 0 0!important}.lil-this.gui .controller{border-bottom:1px solid #f1f3f4!important;background:transparent!important}.lil-this.gui .controller:last-child{border-bottom:none!important}.lil-this.gui .controller .name{color:#495057!important;font-weight:500!important;font-size:12px!important}.lil-this.gui .controller .widget{background:#f8f9fa!important;border:1px solid #ced4da!important;border-radius:4px!important;color:#495057!important}.lil-this.gui .controller .widget:focus,.lil-this.gui .controller .widget:hover{border-color:#80bdff!important;-webkit-box-shadow:0 0 0 2px rgba(0,123,255,.25)!important;box-shadow:0 0 0 2px rgba(0,123,255,.25)!important}.lil-this.gui .controller .widget:focus{outline:none!important}.lil-this.gui .controller input[type=range]{background:#e9ecef!important;height:4px!important;-webkit-appearance:none!important;-moz-appearance:none!important;appearance:none!important;border-radius:2px!important}.lil-this.gui .controller.number .fill{border-right:solid #008de9}.lil-this.gui .controller input[type=range]::-webkit-slider-thumb{background:#007bff!important;border:2px solid #fff!important;-webkit-box-shadow:0 2px 4px rgba(0,0,0,.2)!important;box-shadow:0 2px 4px rgba(0,0,0,.2)!important;width:16px!important;height:16px!important;border-radius:50%!important;-webkit-appearance:none!important;appearance:none!important;cursor:pointer!important}.lil-this.gui .controller input[type=range]::-moz-range-thumb{background:#007bff!important;border:2px solid #fff!important;box-shadow:0 2px 4px rgba(0,0,0,.2)!important;width:16px!important;height:16px!important;border-radius:50%!important;cursor:pointer!important}.lil-this.gui .controller .option{background:#fff!important;color:#495057!important;border-bottom:1px solid #f1f3f4!important}.lil-this.gui .controller .option:hover{background:#f8f9fa!important}.lil-this.gui .controller .option:last-child{border-bottom:none!important}.lil-this.gui input:active{background:#e6eff4}.lil-this.gui .controller button{background:linear-gradient(135deg,#007bff,#0056b3)!important;color:#fff!important;border:none!important;border-radius:4px!important;font-weight:500!important;-webkit-transition:all .2s ease!important;transition:all .2s ease!important}.lil-this.gui .controller button:hover{background:linear-gradient(135deg,#0056b3,#004085)!important;-webkit-transform:translateY(-1px)!important;transform:translateY(-1px)!important;-webkit-box-shadow:0 4px 8px rgba(0,123,255,.3)!important;box-shadow:0 4px 8px rgba(0,123,255,.3)!important}.lil-this.gui .controller .color{border:2px solid #fff!important;border-radius:4px!important;-webkit-box-shadow:0 2px 4px rgba(0,0,0,.1)!important;box-shadow:0 2px 4px rgba(0,0,0,.1)!important}.lil-this.gui .controller.number .slider,.lil-this.gui .controller.number .slider:hover{background-color:#e6eff4}.lil-this.gui input,.lil-this.gui input:hover,.lil-this.gui input[type=number]:focus,.lil-this.gui input[type=text]:focus{background:#e6eff4}.lil-this.gui .controller>.name{min-width:25px}.lil-this.gui .controller.number input{color:#2e3136}.lil-this.gui .controller.number .slider:active{background-color:#e6eff4}.lil-this.gui .folder>.title{background:linear-gradient(135deg,#f1f3f4,#e9ecef)!important;color:#495057!important;border-bottom:1px solid #dee2e6!important}.lil-this.gui .folder>.title:before{color:#6c757d!important}.lil-this.gui .folder.closed>.children{display:none!important}#konva-container[data-v-0f76e7f4]{z-index:3;width:100%;height:100%;cursor:pointer;overflow:hidden}span[data-v-f547d5c6]{font-weight:bolder}.text[data-v-f547d5c6]{margin-top:20px}.line[data-v-f547d5c6]{border-bottom:1px solid #dcdfe6;margin:20px 0}.center[data-v-f547d5c6]{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-align:center;-ms-flex-align:center;align-items:center}.center .cen span[data-v-f547d5c6],.center .top span[data-v-f547d5c6]{color:"#53a8ff";display:inline-block;width:30px;height:30px;text-align:center;line-height:30px;border:1px solid;padding:5px;margin-bottom:10px;background-color:#e9f3ff}.center .cen span[data-v-f547d5c6]{margin:10px}.button[data-v-f547d5c6]{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-pack:end;-ms-flex-pack:end;justify-content:end;margin-top:20px}@font-face{font-family:iconfont;src:url(//at.alicdn.com/t/font_3226805_qqvo3ag3r8.woff2?t=1646635700216) format("woff2"),url(//at.alicdn.com/t/font_3226805_qqvo3ag3r8.woff?t=1646635700216) format("woff"),url(//at.alicdn.com/t/font_3226805_qqvo3ag3r8.ttf?t=1646635700216) format("truetype")}.iconfont[data-v-f547d5c6]{font-family:iconfont!important;font-size:50px;font-style:normal;color:"#53a8ff";-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.icon-shubiao[data-v-f547d5c6]:before{content:""}.main_body[data-v-4b17bce0]{position:relative;width:100%;height:100%;-webkit-box-sizing:border-box;box-sizing:border-box;overflow:hidden}.classification_title[data-v-4b17bce0]{margin:0 0 10px 0;color:#fff;font-size:14px;cursor:default}.toolbar[data-v-4b17bce0]{z-index:10;position:absolute;width:520px;padding:8px 16px;border-radius:6px;-webkit-box-shadow:0 2px 10px 0 rgba(6,29,44,.25);box-shadow:0 2px 10px 0 rgba(6,29,44,.25);background-color:#fff;top:10px;left:50%;-webkit-box-sizing:border-box;box-sizing:border-box;-webkit-transform:translateX(-50%);transform:translateX(-50%);display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-pack:distribute;justify-content:space-around}.icon_toolbar[data-v-4b17bce0],.text_toolbar[data-v-4b17bce0]{float:left;width:32px;height:32px;padding:0!important;background-repeat:no-repeat;background-size:24px;background-position:50%}.icon_active[data-v-4b17bce0],.icon_toolbar[data-v-4b17bce0]:hover,.text_toolbar[data-v-4b17bce0]:hover{background-color:#eee}[data-v-4b17bce0].icon_color .el-color-picker__trigger{height:24px;margin-top:4px;width:24px!important}[data-v-4b17bce0].el-color-picker--medium,[data-v-4b17bce0].el-color-picker--medium .el-color-picker__trigger{width:24px!important;height:24px!important}.canvas_container[data-v-4b17bce0]{position:relative;width:100%;height:100%;overflow:auto;-webkit-box-sizing:border-box;box-sizing:border-box}.canvas_container canvas[data-v-4b17bce0]{position:absolute;left:0}.canvas_container #ctx_front[data-v-4b17bce0]{z-index:5;background-color:transparent}.canvas_container #ctx_back[data-v-4b17bce0]{z-index:3}.canvas_container #ctx_base[data-v-4b17bce0]{z-index:1}#text[data-v-4b17bce0]{position:absolute;z-index:-1;resize:none;outline:none;border:1px dashed #9c9c9c;overflow:hidden;background:transparent;line-height:30px;display:none}#text[data-v-4b17bce0]:hover{border:1px dashed #53a8ff}#svg-component[data-v-2572c0e2],#svg-tigger[data-v-2572c0e2]{cursor:pointer;height:100%;width:100%;position:relative}#toolbar-show[data-v-2572c0e2]{z-index:20;position:absolute;width:100%;height:100%;top:0;left:0;overflow:hidden;background:#fff}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "fl-web-component",
3
- "version": "2.1.1-beta.1",
3
+ "version": "2.1.1-beta.3",
4
4
  "scripts": {
5
5
  "postinstall": "patch-package",
6
6
  "tip1": "仅调试本组件不涉及业务组件,请执行dev",
@@ -229,10 +229,11 @@ function drawArc(recordDxf, entity, group, key, configParams) {
229
229
  name: key.replace(/\s*/g, ''),
230
230
  entityId: key,
231
231
  stroke: hex,
232
- customColor: configParams ? configParams.color : '',
232
+ customColor: configParams ? configParams.color : hex,
233
233
  strokeWidth: width,
234
234
  visible: configParams ? configParams.visible : true,
235
235
  oldstrokeLength: width,
236
+ isGroup: false,
236
237
  });
237
238
  // if(group.attrs.isBlock){
238
239
  // let scale=group.scale();
@@ -290,10 +291,11 @@ function drawEllpse(recordDxf, entity, group, key, configParams) {
290
291
  name: key.replace(/\s*/g, ''),
291
292
  entityId: key,
292
293
  stroke: configParams ? configParams.color : '#000',
293
- customColor: configParams ? configParams.color : '',
294
+ customColor: configParams ? configParams.color : '#000',
294
295
  strokeWidth: width,
295
296
  visible: configParams ? configParams.visible : true,
296
297
  oldstrokeLength: width,
298
+ isGroup: false,
297
299
  });
298
300
  // let line = new Konva.Line({
299
301
  // name: key.replace(/\s*/g, ""),
@@ -331,7 +333,7 @@ function drawLine(recordDxf, entity, group, key, configParams) {
331
333
  entityId: key,
332
334
  isGroup: false,
333
335
  stroke: hex,
334
- customColor: configParams ? configParams.color : '',
336
+ customColor: configParams ? configParams.color : hex,
335
337
  strokeWidth: width,
336
338
  visible: configParams ? configParams.visible : true,
337
339
  oldstrokeLength: width,
@@ -385,13 +387,14 @@ function drawText(recordDxf, entity, group, key, configParams) {
385
387
  align: 'left',
386
388
  verticalAlign: 'top',
387
389
  fill: hex,
388
- customColor: configParams ? configParams.color : '',
390
+ customColor: configParams ? configParams.color : hex,
389
391
  name: key.replace(/\s*/g, ''),
390
392
  entityId: key,
391
393
  fontFamily: 'SimSun',
392
394
  visible: configParams ? configParams.visible : true,
393
395
  stroke: hex,
394
396
  strokeWidth: 0.1,
397
+ shapeType: 'text',
395
398
  });
396
399
 
397
400
  if (entity.xScale) {
@@ -451,6 +454,7 @@ function drawText(recordDxf, entity, group, key, configParams) {
451
454
  entityId: key,
452
455
  visible: configParams ? configParams.visible : true,
453
456
  customColor: configParams ? configParams.color : '',
457
+ isGroup: true,
454
458
  });
455
459
  g.add(dim);
456
460
 
@@ -491,9 +495,10 @@ function drawLwLine(recordDxf, entity, group, key, configParams) {
491
495
  points: list,
492
496
  closed: closed,
493
497
  name: key.replace(/\s*/g, ''),
498
+ isGroup: false,
494
499
  entityId: key,
495
500
  stroke: hex,
496
- customColor: configParams ? configParams.color : '',
501
+ customColor: configParams ? configParams.color : hex,
497
502
  strokeWidth: width,
498
503
  visible: configParams ? configParams.visible : true,
499
504
  oldstrokeLength: width,
@@ -534,7 +539,7 @@ function drawSpline(recordDxf, entity, group, key, configParams) {
534
539
  entityId: key,
535
540
  isGroup: false,
536
541
  stroke: configParams ? configParams : '#000',
537
- customColor: configParams ? configParams.color : '',
542
+ customColor: configParams ? configParams.color : '#000',
538
543
  strokeWidth: width,
539
544
  visible: configParams ? configParams.visible : true,
540
545
  oldstrokeLength: width,
@@ -457,7 +457,7 @@ export default {
457
457
  name: key.replace(/\s*/g, ''),
458
458
  entityId: key,
459
459
  stroke: group[0].stroke,
460
- customColor: configParams ? configParams.color : '',
460
+ customColor: configParams ? configParams.color : group[0].stroke,
461
461
  //visible: configParams ? configParams.visible :true,
462
462
  sceneFunc(context, shape) {
463
463
  context.beginPath();
@@ -520,6 +520,7 @@ export default {
520
520
  // context.closePath();
521
521
  context.fillStrokeShape(shape);
522
522
  },
523
+ shapeType: 'shape',
523
524
  });
524
525
  if (this.konvaLayer) this.konvaLayer.add(customShape);
525
526
  }
@@ -818,10 +819,43 @@ export default {
818
819
  this.konvaLayer = null;
819
820
  this.konvaStage = null;
820
821
  },
821
- beforeDestroy() {
822
- this.clearCache();
822
+ // 更改图纸的色系 区分明暗两种 darkness 暗色系 bright 明亮
823
+ setColorScheme(colorType) {
824
+ // const backgroundColor = colorType === "darkness" ? "#000" : "transparent";
825
+ const color = colorType === "darkness" ? "#fff" : "#000";
826
+ // konvaStage.container().style.background = backgroundColor;
827
+ this.konvaLayer.children.forEach((item) => {
828
+ this.traverseLayer(item, color);
829
+ });
830
+ },
831
+
832
+ traverseLayer(obj, color) {
833
+ if (!obj.attrs.isGroup) {
834
+ if (color === '#fff') {
835
+ let setColor = (obj.attrs.customColor === '#000' || obj.attrs.customColor === '#000000'|| obj.attrs.customColor === 'rgb(0, 0, 0)' || obj.attrs.customColor === 'rgba(0, 0, 0, 1)') ? color : obj.attrs.customColor
836
+ if (obj.attrs.shapeType === 'hatch' || obj.attrs.shapeType === 'text') {
837
+ obj.setFill(setColor);
838
+ }
839
+ obj.setStroke(setColor);
840
+ obj.attrs.oldCustomColor = obj.attrs.customColor
841
+ obj.attrs.customColor = setColor
842
+ } else {
843
+ obj.attrs.customColor = obj.attrs.oldCustomColor
844
+ if (obj.attrs.shapeType === 'hatch' || obj.attrs.shapeType === 'text') {
845
+ obj.setFill(obj.attrs.customColor);
846
+ }
847
+ obj.setStroke(obj.attrs.customColor);
848
+ }
849
+ } else {
850
+ obj.children.forEach((item) => {
851
+ this.traverseLayer(item, color);
852
+ });
853
+ }
823
854
  },
824
855
  },
856
+ beforeDestroy() {
857
+ this.clearCache();
858
+ }
825
859
  };
826
860
  </script>
827
861
  <style lang="scss" scoped>
@@ -165,7 +165,7 @@ import { onContextHandle } from './component/context';
165
165
 
166
166
  const isDebug = process.env.NODE_ENV !== 'production' || process.env.VUE_APP_IS_WATCH === true;
167
167
  // const isDebug = false;
168
- const COLLISION_PENETRATION_EPSILON = 10;
168
+ const COLLISION_PENETRATION_EPSILON = 1;
169
169
  const COLLISION_OBB_AXIS_EPSILON = 1e-8;
170
170
  const COLLISION_DEBUG_GROUP_NAME = '__collision_obb_debug_group__';
171
171
 
@@ -215,7 +215,8 @@ export default {
215
215
  isPaused: false,
216
216
  },
217
217
  isolateMode: false,
218
- collisionObbDebugEnabled: isDebug,
218
+ // collisionObbDebugEnabled: isDebug,
219
+ collisionObbDebugEnabled: false,
219
220
  };
220
221
  },
221
222
  watch: {
@@ -1805,6 +1806,53 @@ export default {
1805
1806
  }
1806
1807
  node.items.push({ id, box });
1807
1808
  },
1809
+ _buildCollisionOctreeFromEntries(entries) {
1810
+ if (!Array.isArray(entries) || entries.length === 0) {
1811
+ return null;
1812
+ }
1813
+
1814
+ let minX = Infinity;
1815
+ let minY = Infinity;
1816
+ let minZ = Infinity;
1817
+ let maxX = -Infinity;
1818
+ let maxY = -Infinity;
1819
+ let maxZ = -Infinity;
1820
+
1821
+ entries.forEach(item => {
1822
+ const box = item && item.box;
1823
+ if (!box || !box.isBox3) return;
1824
+ const mn = box.min;
1825
+ const mx = box.max;
1826
+ if (mn.x < minX) minX = mn.x;
1827
+ if (mn.y < minY) minY = mn.y;
1828
+ if (mn.z < minZ) minZ = mn.z;
1829
+ if (mx.x > maxX) maxX = mx.x;
1830
+ if (mx.y > maxY) maxY = mx.y;
1831
+ if (mx.z > maxZ) maxZ = mx.z;
1832
+ });
1833
+
1834
+ if (minX === Infinity) {
1835
+ return null;
1836
+ }
1837
+
1838
+ const rootBox = new this.THREE.Box3(
1839
+ new this.THREE.Vector3(minX, minY, minZ),
1840
+ new this.THREE.Vector3(maxX, maxY, maxZ)
1841
+ );
1842
+ const root = {
1843
+ box: rootBox,
1844
+ items: [],
1845
+ children: null,
1846
+ depth: 0,
1847
+ };
1848
+
1849
+ entries.forEach(item => {
1850
+ if (!item || !item.box) return;
1851
+ this._octreeInsert(root, String(item.id), item.box);
1852
+ });
1853
+
1854
+ return root;
1855
+ },
1808
1856
  _isCollisionBoxAvailable(box) {
1809
1857
  if (!box || !box.isBox3 || box.isEmpty()) return false;
1810
1858
  if (box.userData && box.userData.visible === false) return false;
@@ -1935,7 +1983,8 @@ export default {
1935
1983
  _buildCollisionPairMap() {
1936
1984
  const pairMap = new Map();
1937
1985
  const collisionPairs = this.getOctreeCollisionPairs();
1938
- const pairs = collisionPairs && Array.isArray(collisionPairs.pairs) ? collisionPairs.pairs : [];
1986
+ const pairs =
1987
+ collisionPairs && Array.isArray(collisionPairs.pairs) ? collisionPairs.pairs : [];
1939
1988
  for (let i = 0; i < pairs.length; i++) {
1940
1989
  const pair = pairs[i];
1941
1990
  if (!pair) continue;
@@ -2071,9 +2120,8 @@ export default {
2071
2120
  }
2072
2121
  return false;
2073
2122
  },
2074
- _queryOctreeByBox(box) {
2123
+ _queryOctreeByBoxWithRoot(root, box) {
2075
2124
  const results = [];
2076
- const root = this._octree;
2077
2125
  if (!root || !this._isCollisionBoxAvailable(box)) return results;
2078
2126
 
2079
2127
  const stack = [root];
@@ -2099,25 +2147,88 @@ export default {
2099
2147
 
2100
2148
  return results;
2101
2149
  },
2102
- getOctreeCollisionPairs() {
2150
+ _queryOctreeByBox(box) {
2151
+ return this._queryOctreeByBoxWithRoot(this._octree, box);
2152
+ },
2153
+ getOctreeCollisionPairs(options = {}) {
2103
2154
  const pairs = [];
2104
2155
  if (!this._boxIndex || this._boxIndex.size === 0) return { pairs };
2105
2156
 
2106
- if (!this._octree) {
2107
- this.buildOctreeFromBoxIndex();
2157
+ const normalizeIds = value =>
2158
+ Array.isArray(value)
2159
+ ? Array.from(
2160
+ new Set(
2161
+ value
2162
+ .map(item => (item === null || item === undefined ? '' : String(item)))
2163
+ .filter(item => item !== '')
2164
+ )
2165
+ )
2166
+ : [];
2167
+
2168
+ const getEntriesByIds = ids => {
2169
+ const entries = [];
2170
+ const idSet = new Set(ids);
2171
+ this._boxIndex.forEach((box, id) => {
2172
+ const key = String(id);
2173
+ if (idSet.has(key)) {
2174
+ entries.push({
2175
+ id: key,
2176
+ box,
2177
+ });
2178
+ }
2179
+ });
2180
+ return entries;
2181
+ };
2182
+
2183
+ const sourceIds = normalizeIds(options.sourceIds);
2184
+ const targetIds = normalizeIds(options.targetIds);
2185
+ const includeIds = Array.isArray(options.includeIds) ? normalizeIds(options.includeIds) : [];
2186
+
2187
+ let root = this._octree;
2188
+ let sourceEntries = [];
2189
+ let dedupePairKeySet = null;
2190
+
2191
+ if (sourceIds.length > 0 && targetIds.length > 0) {
2192
+ const targetEntries = getEntriesByIds(targetIds);
2193
+ sourceEntries = getEntriesByIds(sourceIds);
2194
+ if (sourceEntries.length === 0 || targetEntries.length === 0) return { pairs };
2195
+ root = this._buildCollisionOctreeFromEntries(targetEntries);
2196
+ if (!root) return { pairs };
2197
+ dedupePairKeySet = new Set();
2198
+ } else if (includeIds.length > 0) {
2199
+ sourceEntries = getEntriesByIds(includeIds);
2200
+ if (sourceEntries.length === 0) return { pairs };
2201
+ root = this._buildCollisionOctreeFromEntries(sourceEntries);
2202
+ if (!root) return { pairs };
2203
+ } else {
2204
+ if (!this._octree) {
2205
+ this.buildOctreeFromBoxIndex();
2206
+ }
2207
+ if (!this._octree) return { pairs };
2208
+ this._boxIndex.forEach((box, id) => {
2209
+ sourceEntries.push({
2210
+ id: String(id),
2211
+ box,
2212
+ });
2213
+ });
2108
2214
  }
2109
- if (!this._octree) return { pairs };
2110
2215
 
2111
- this._boxIndex.forEach((boxA, idA) => {
2216
+ sourceEntries.forEach(({ id: idA, box: boxA }) => {
2112
2217
  if (!this._isCollisionBoxAvailable(boxA)) return;
2113
2218
 
2114
- const hits = this._queryOctreeByBox(boxA);
2219
+ const hits = this._queryOctreeByBoxWithRoot(root, boxA);
2115
2220
  for (let i = 0; i < hits.length; i++) {
2116
2221
  const item = hits[i];
2117
2222
  if (!item || String(item.id) === String(idA)) continue;
2118
2223
  const boxB = item.box;
2119
2224
  if (!this._isCollisionBoxMatched(boxA, boxB)) continue;
2120
2225
 
2226
+ if (dedupePairKeySet) {
2227
+ const pairKey = `${String(idA)}__${String(item.id)}`;
2228
+ if (dedupePairKeySet.has(pairKey)) continue;
2229
+ dedupePairKeySet.add(pairKey);
2230
+ }
2231
+
2121
2232
  pairs.push({
2122
2233
  idA: this._formatCollisionPairId(idA),
2123
2234
  idB: this._formatCollisionPairId(item.id),