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.
- package/dist/fl-web-component.common.js +649 -504
- package/dist/fl-web-component.common.js.map +1 -1
- package/dist/fl-web-component.css +1 -1
- package/package.json +1 -1
- package/packages/components/com-flcanvas/components/entityFormatting.js +11 -6
- package/packages/components/com-flcanvas/index.vue +37 -3
- package/packages/components/com-graphics/index.vue +122 -11
|
@@ -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
|
@@ -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
|
-
|
|
822
|
-
|
|
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 =
|
|
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 =
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
2107
|
-
|
|
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
|
-
|
|
2216
|
+
sourceEntries.forEach(({ id: idA, box: boxA }) => {
|
|
2112
2217
|
if (!this._isCollisionBoxAvailable(boxA)) return;
|
|
2113
2218
|
|
|
2114
|
-
const hits = this.
|
|
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),
|