欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

海创软件组--20200712--axios上传文件获取进度--js对多个四边形的点对象数组分别按顺时针排序--定义上传视频并可预览

程序员文章站 2022-04-19 13:32:28
文章目录1:axios上传文件获取进度2:js对多个四边形的点对象数组分别按顺时针排序1:axios上传文件获取进度最近在做上传视频,因为视频比较大,耗时较长,要是没有个进度的话,用户漫长等待,体验不好,所以就想实时显示上传进度。要点是发送请求是配置onUploadProgress: onUploadProgress: progressEvent => { let persent = (progressEvent.loaded / progressEvent.total * 100...

1:axios上传文件获取进度

最近在做上传视频,因为视频比较大,耗时较长,要是没有个进度的话,用户漫长等待,体验不好,所以就想实时显示上传进度。

要点是发送请求是配置onUploadProgress

 onUploadProgress: progressEvent => {
     let persent = (progressEvent.loaded / progressEvent.total * 100 | 0)
      console.log(persent)
    },

完整上传代码如下:

//上传视频
async uploadVideo () {
  const {uploadFile} = this
  if(uploadFile){
    let param = new FormData() //创建form对象,私有,无法直接获取,只能通过get来查看其中的元素
    param.append('file',uploadFile)
    let config = {
      headers:{
        'Content-Type':'multipart/form-data',
      },
      transformRequest: [function (data) {
        return data
      }],
      onUploadProgress: progressEvent => {
        let persent = (progressEvent.loaded / progressEvent.total * 100 | 0)		//上传进度百分比
        console.log(persent)
      },
    }
    axios.post('http://xxxxxxxx/video/upload',param,config)	//地址写你们自己的接口
      .then(response=>{
        var result = response.data
        if(result.status == 0){
          console.log(result)
        }else{
          this.$message({
            message: '上传失败',
            type: 'error',
            duration:'1000'
          });
        }
      }).catch(err => {
        console.log(err)
      })
    }
},

效果:

打印输出百分比:
海创软件组--20200712--axios上传文件获取进度--js对多个四边形的点对象数组分别按顺时针排序--定义上传视频并可预览
配合element-ui的进度条:
海创软件组--20200712--axios上传文件获取进度--js对多个四边形的点对象数组分别按顺时针排序--定义上传视频并可预览

希望能够帮到你们一点哈。


2:js对多个四边形的点对象数组分别按顺时针排序

最近做了个给图片标注的东西,我采取的思路是标注的同时将坐标全部存入一个数组,然后对该数组按X,Y分别进行排序,从而得到每个四边形的四个坐标。

其中的要点就是如何对对象数组按属性大小进行排序,这里采用的是js数组提供的sort()方法,只是要稍加改一下:技术有限,只能采用最笨的方法,一层层比较。

注意:我这里只适用四边形间是按x轴分布的,没考虑x,y轴重叠的四边形。
例如如下图四边形分布(点为四边形的点,圈起来为一个四边形):
海创软件组--20200712--axios上传文件获取进度--js对多个四边形的点对象数组分别按顺时针排序--定义上传视频并可预览

  1. 对所有坐标按横坐标x的大小进行排序,确定哪四个点围成一个四边形
  2. 对每个四边形数组按纵坐标y的大小进行排序,确定四边形上下点坐标
  3. 比较第一第二个点的x坐标大小,第三第四个点x坐标的大小,从而确定四边形坐标按顺时针排序

1:对所有坐标按横坐标x的大小进行排序,确定哪四个点围成一个四边形
代码:

数组排序:

//这里用js数组提供的sort()进行排序,因为自定义排序规则,所以需要自定义规则,这里将规则放入函数sortByX中
this.banMa1.sort(this.sortByX)      //对所有坐标数组按x轴从左往右排序,每四个为一个四边形

sortByX函数:

sortByX(a,b){
  if(a.x == b.x)
     return a.x - b.x
   return a.x - b.x
 },

2. 对每个四边形数组按纵坐标y的大小进行排序,确定四边形上下点坐标

var num = this.banMa1.length/4				//确定有几个四边形
var banMa2 = []										//用于存储每个四边形数组
var banMa1 = this.banMa1						//this.banMa1为第一步按x大小排序后的坐标数组
for(var i = 0;i < num;i++){
  var newBanMa = banMa1.slice(i*4,(i+1)*4).sort(this.sortByY)	//每四个点为一个四边形,并按y轴大小确定四边形上下各两点坐标
  banMa2.push(newBanMa)
 }

this.sortByY函数代码:

sortByY(a,b){
  if(a.y == b.y)
    return a.y - b.y
  return a.y - b.y
},

3. 比较第一第二个点的x坐标大小,第三第四个点x坐标的大小,从而确定四边形坐标按顺时针排序

代码(这里需要更改一下第二步的代码,直接替换即可):

for(var i = 0;i < num;i++){
  var newBanMa = banMa1.slice(i*4,(i+1)*4).sort(this.sortByY)
  var point1
  var point2
  var point3
  var point4
  if(newBanMa[0].x>newBanMa[1].x){
    point1 = newBanMa[0]
    point4 = newBanMa[1]
  }else{
    point1 = newBanMa[1]
    point4 = newBanMa[0]
  }
  if(newBanMa[2].x>newBanMa[3].x){
    point2 = newBanMa[2]
    point3 = newBanMa[3]
  }else{
    point2 = newBanMa[3]
    point3 = newBanMa[2]
  }
  newBanMa[0] = point1
  newBanMa[1] = point2
  newBanMa[2] = point3
  newBanMa[3] = point4
  banMa2.push(newBanMa)
}

大致就是分为三步走就可以实现对各个四边形左边进行顺时针排序了。话不多说,直接贴完整代码吧:
函数代码:

methods: {
 //点数组按x,y排序
  sortByX(a,b){
    if(a.x == b.x)
      return a.x - b.x
    return a.x - b.x
  },
  sortByY(a,b){
    if(a.y == b.y)
      return a.y - b.y
    return a.y - b.y
  },
  //排序
  paiXu(){
      this.banMa1.sort(this.sortByX)      //对所有坐标数组按x轴从左往右排序,每四个为一个四边形
      var num = this.banMa1.length/4
      var banMa2 = []
      var banMa1 = this.banMa1
      for(var i = 0;i < num;i++){
        var newBanMa = banMa1.slice(i*4,(i+1)*4).sort(this.sortByY)
        var point1
        var point2
        var point3
        var point4
        if(newBanMa[0].x>newBanMa[1].x){
          point1 = newBanMa[0]
          point4 = newBanMa[1]
        }else{
          point1 = newBanMa[1]
          point4 = newBanMa[0]
        }
        if(newBanMa[2].x>newBanMa[3].x){
          point2 = newBanMa[2]
          point3 = newBanMa[3]
        }else{
          point2 = newBanMa[3]
          point3 = newBanMa[2]
        }
        newBanMa[0] = point1
        newBanMa[1] = point2
        newBanMa[2] = point3
        newBanMa[3] = point4
        banMa2.push(newBanMa)
      }
      console.log(banMa2)
      console.log(this.banMa1)
  },
},

3:定义上传视频组件并可预览

平时做东西少不了需要上传视频,所以自己就加以改装element-ui的上传组件,做到可以预览视频,但由于采用的是video来播放预览视频所以有些局限,avi等格式不能播放,这也让我有点苦恼,但又解决不了,难受。

代码:

<template>
	<el-input v-model="ruleForm.video" v-if="false"></el-input>
	  <el-upload
	    class="avatar-uploader"
	    style="float: left"
	    ref="upload"
	    :show-file-list="false"
	    action="#"
	    :before-upload="beforeUpload"
	    :on-change="handleChange"
	    :auto-upload="false"
	    accept="video/*"
	    :data="ruleForm">
	    <i class="el-icon-plus avatar-uploader-icon"></i>
	  </el-upload>
	  <video
	    controls
	    aspectRatio="16:9"
	    fluid
	    width="200px"
	    height="180px"
	    ref="video"
	    :style="{'display':isShow}"
	  >
	</video>
</template>

<script>
	export default {
		data() {
	      return {
	        isShow:'none',
	        ruleForm: {
	          video:'',
	          uploadFile: '',
	        },
	     }
	   },
	   methods: {
	      handleChange (file, fileList) {
	        this.$refs.video.src= URL.createObjectURL(file.raw)
	        this.$refs.video.load()
	        this.isShow = 'block'
	        this.ruleForm.uploadFile = file.raw;
	      },
	
	      beforeUpload (file) {
	      },
	    },
	}
</script>

<style>
  video:focus{
    outline: 0;
  }
  .manage_textarea{
    width: 600px;
  }
  input[type="file"] {
    display: none;
  }
  .upload-element{
    width: 100%;
  }
  .avatar-uploader .el-upload {
    border: 1px dashed #d9d9d9;
    border-radius: 6px;
    cursor: pointer;
    position: relative;
    overflow: hidden;
  }

  .avatar-uploader .el-upload:hover {
    border-color: #409EFF;
  }

  .avatar-uploader-icon {
    font-size: 28px;
    color: #8c939d;
    width: 178px;
    height: 178px;
    line-height: 178px;
    text-align: center;
  }

  .avatar {
    width: 178px;
    height: 178px;
    display: block;
  }

  .manage_input{
    width: 300px;
  }
  .manage_textarea{
    width: 800px;
  }
</style>

本文地址:https://blog.csdn.net/m0_46627730/article/details/107285076