zoukankan      html  css  js  c++  java
  • 双层拖拽事件,用鼠标画矩形,拖动右下角可以再次改变矩形大小,方案一 有BUG

    <template>
      <div class="mycanvas-container">
        <vue-drag-resize :isActive = 'true'/>>
        <div class="left">
          <p>展示视口</p>
          <div class="myshow">
            <img :src="mysrc" alt width="100%" />
            <!-- <div id="canvas" style="100%;height:100%" class="mycanvas"></div> -->
          </div>
        </div>
        <div class="center">
          <p>操作视口</p>
          <div class="myedit" ref="myedit"  
          @mousedown.prevent="" 
          @mousemove.prevent="" 
          @mouseup.prevent=""
          @contextmenu.prevent="">
            <!-- <img src="@/assets/jia.svg" alt=""> -->
            <img :src="mysrc"  @mousedown.prevent="onMousedown" @mousemove="onMousemove" />
            <div
              class="myedit-span"
              v-for="(item, index) in mydata"
              :key="index"
              :style="getSpanStyle(item)"
              @contextmenu.prevent="onContextmenu(item, $event)">
              <div class="br" 
              @mousedown.prevent="onMousedownbr(item,$event)"
              @mousemove="onMousemovebr(item,$event)"
              @mouseup="onMouseupbr(item,$event)"
              ></div>
            </div>
            <!-- <div id="canvas" style="100%;height:100%" class="mycanvas"></div> -->
          </div>
        </div>
        <div class="right">
          <img src alt class="mybutton" />
          <input v-show="0" ref="file" type="file" class="mybutton" @change="onChange" />
          <button class="mybutton" @click="selectFile">导入图片</button>
          <button class="mybutton">新增标注</button>
          <button class="mybutton">修改标注</button>
          <button class="mybutton">删除</button>
          <button class="mybutton">保存</button>
        </div>
        <div class="myMenu" v-show="mymenu.current" :style="mymenu.style">
          <!-- <button @click="onRemoveItem">删除</button> -->
          <ui-button type="primary" @click="onRemoveItem">删除</ui-button>
          <ui-select></ui-select>
          <select name="" id="">
            <option value="1">ceshi</option>
          </select>
        </div>
      </div>
    </template>
    
    <script>
    
    import jiaIcon from "./jia.svg";
    export default {
      data() {
        return {
          mysrc: "",
          mydata: [],
          mymenu: { current: null, style: { left: 0, top: 0 } }
        };
      },
      mounted() {
        document.addEventListener('mouseup', this.onMouseup)
        this.getData()
      },
      beforeDestroy() {
        document.removeEventListener('mouseup', this.onMouseup)
      },
      methods: {
        getData(){
          let url='/index'
          this.axios(url,{params:{status:1}}).then(data=>{
            console.log(data)
          }).catch(err => this.$Message.error(err.message))
        },
        getXY(e) {
          let rect = this.$refs.myedit.getBoundingClientRect()
          return {
            x: e.clientX - rect.left,
            y: e.clientY - rect.top
          }
        },
        // 上传图片1
        onChange(e) {
          this.mysrc = window.URL.createObjectURL(e.target.files[0]);
          e.target.value = ''
        },
        // 上传图片2,
        selectFile() {
          this.$refs.file.click();
        },
        // 矩形右下角拖动事件1
        onMousedownbr(item,e){
          e.target.removeEventListener('mousemove',this.onMousemove)
          e.target.removeEventListener('mouseup',this.onMouseup)
          this.canmove=true
          console.log(1)
          console.log(this.getXY(e))
          this.startPosbr=this.getXY(e)
          console.log(2)
          console.log(this.startPosbr)
          e.target.addEventListener('mousemove',this.onMousemovebr)
          e.target.addEventListener('mouseup',this.onMouseupbr)
        },
        onMousemovebr(item,e){
          if(this.canmove){
          let { x, y } = this.getXY(e)
          console.log(3)
          console.log(this.getXY(e))
          item.w=item.w+(x-this.startPosbr.x)
          item.h=item.h+(y-this.startPosbr.y)
          console.log(4)
          console.log(item.w)
          // Math.sqrt(9)
          // 9**.5
          }
        },
        onMouseupbr(item,e){
          this.canmove=false
          this.startPos =this.startPosbr= null;
          e.target.removeEventListener('mousemove',this.onMousemovebr)
          e.target.removeEventListener('mouseup',this.onMouseupbr)
        },
        // 矩形右下角拖动事件2
        onMousedown(e) {
          e.target.addEventListener('mousemove',this.onMousemove)
          e.target.addEventListener('mouseup',this.onMouseup)
          this.mymenu.current = null
          let { x, y } = this.getXY(e)
          this.currentItem = { x, y, w: 0, h: 0, now: Date.now() }
          this.startPos = { x, y }
          this.mydata.push(this.currentItem)
        },
        onMousemove(e) {
          if (!this.currentItem) return;
          let { x, y } = this.getXY(e)
          this.currentItem.w = Math.abs(x - this.startPos.x)
          this.currentItem.h = Math.abs(y - this.startPos.y)
        },
        onMouseup(e) {
          this.currentItem = this.startPos =this.startPosbr= null;
          // this.mydata = this.mydata.filter(_ => _.w > 10 && _.h > 10)
          e.target.removeEventListener('mousemove',this.onMousemove)
          e.target.removeEventListener('mouseup',this.onMouseup)
        },
        onContextmenu(item, e) {
          this.mymenu = {
            current: item,
            style: {
              top: e.clientY + 'px',
              left: e.clientX + 'px'
            }
          }
        },
        onRemoveItem() {
          this.mydata.splice(this.mydata.indexOf(this.mymenu.current), 1)
          this.mymenu = { ...this.mymenu, current: null }
        },
        getSpanStyle(item) {
          return {
             `${item.w}px`,
            height: `${item.h}px`,
            top: `${item.y}px`,
            left: `${item.x}px`
          };
        }
      }
    };
    </script>
    <style lang="less" scoped>
    // 设置绘图样式1
    body {
      user-select: none;
    }
    
    .myMenu {
      position: fixed;
      top: 400px;
      left: 400px;
      width: 100px;
      padding: 8px 0;
      background-color: #fff;
      > * {
        width: 100%;
      }
    }
    
    #canvas > div {
      /* border: 2px solid green; */
      position: absolute;
      background-color: transparent;
    }
    
    #canvas > div > span {
      position: absolute;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%);
      font-family: simsun;
      font-size: 9pt;
    }
    
    // 设置绘图样式2
    
    .mycanvas-container {
      display: flex;
      justify-content: center;
      align-items: center;
    
      .left,
      .center,
      .right {
        width: 300px;
        // height: 520px;
        margin: 20px;
    
        p {
          text-align: center;
        }
    
        .myshow,
        .myedit {
          width: 300px;
          // height: 500px;
          border: 1px solid #000;
          position: relative;
          .myedit-span {
            position: absolute;
            border: 1px dashed #fff;
            // background: url("./jia.svg") no-repeat center center;
            background-size: contain;
          }
          .br,.divcenter{
            width: 10px;
            height: 10px;
            position: absolute;
            border: 1px solid #f00;
            background: #fff;
            border-radius: 50%;
            bottom:-5px;
            right:-5px;
            cursor:nwse-resize;
          }
          .divcenter{
            top:50%;
            left:50%;
            transform:translate(-5px ,-5px);
            cursor:move;
          }
          .mycanvas {
            border: 1px solid pink;
            position: absolute;
            top: 0;
            left: 0;
          }
    
          img {
            width: 100%;
          }
        }
      }
    
      .right {
        width: 150px;
        display: flex;
        justify-content: center;
        align-items: left;
        flex-direction: column;
    
        .mybutton {
          margin-top: 20px;
          display: block;
        }
      }
    }
    </style>

  • 相关阅读:
    django模型系统(二)
    css基础
    css进阶
    django模型系统(一)
    自定义过滤器及标签
    django模板标签
    模板变量及模板过滤器
    第六章 异常
    第三章:多态
    第三章:提高系统性能:从数据访问开始
  • 原文地址:https://www.cnblogs.com/sugartang/p/11560240.html
Copyright © 2011-2022 走看看