PreviewImages.vue 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  1. <!--
  2. # @Date: 2024-10-11 14:37:11
  3. # @Author: WANGKANG
  4. # @Blog:
  5. # @Email:
  6. # @Filepath: src\views\demo\components\PreviewImages.vue
  7. # @Description: PreviewImages.vue
  8. # Copyright 2024 WANGKANG, All Rights Reserved.
  9. -->
  10. <template>
  11. <el-dialog
  12. v-model="dialogVisible"
  13. :title="'预览 - 共' + currentImageUrls.length + '张 当前第' + (imageIdx + 1) + '张'"
  14. width="80%"
  15. @open="handleOpen"
  16. :before-close="handleClose"
  17. >
  18. <el-form :inline="true">
  19. <el-form-item label="帧率">
  20. <el-select v-model="imageFps" placeholder="选择帧率" style="width: 200px" @change="changeFps">
  21. <el-option label="0" value="0"></el-option>
  22. <el-option label="5" value="5"></el-option>
  23. <el-option label="15" value="15"></el-option>
  24. <el-option label="30" value="30"></el-option>
  25. </el-select>
  26. </el-form-item>
  27. <el-form-item label="跳转至">
  28. <el-input v-model="newImageIdx" type="number" style="width: 100px"/>
  29. <el-button type="primary" @click="confirmNewImageIdx" style="margin-left: 10px">确认</el-button>
  30. </el-form-item>
  31. </el-form>
  32. <div class="image-dialog">
  33. <el-image :src="currentImageUrls[imageIdx]" style="width: 40%"></el-image>
  34. </div>
  35. <div class="image-dialog-btn" v-if="imageFps == 0">
  36. <el-button type="primary" @click="pre_picture" :disabled="imageIdx <= 0">上一个</el-button>
  37. <el-button type="primary" @click="next_picture" :disabled="imageIdx >= currentImageUrls.length - 1">下一个</el-button>
  38. </div>
  39. </el-dialog>
  40. </template>
  41. <script setup lang="ts">
  42. import {ElMessageBox} from "element-plus";
  43. import {ref, watch} from "vue";
  44. const props = defineProps({
  45. visible: {
  46. type: Boolean, //接受的数据类型
  47. default: false //接受默认数据
  48. },
  49. urls: {
  50. type: Array,
  51. default: ()=>[]
  52. }
  53. })
  54. watch(() => props.visible, (val) => {
  55. dialogVisible.value = val
  56. })
  57. const handleOpen = () => {
  58. currentImageUrls.value = props.urls
  59. imageIdx.value = 0
  60. imageFps.value = 0
  61. }
  62. const dialogVisible = ref(false)
  63. const imageFps = ref(0)
  64. const intervalChangeFps: any = ref()
  65. const imageIdx = ref(0)
  66. const currentImageUrls = ref<any[]>([])
  67. const newImageIdx = ref()
  68. const handleClose = (done: () => void) => {
  69. console.log('handleClose')
  70. if (intervalChangeFps.value) {
  71. clearInterval(intervalChangeFps.value)
  72. }
  73. done()
  74. }
  75. const confirmNewImageIdx = () => {
  76. const val = parseInt(newImageIdx.value)
  77. if (val > 0 && val <= currentImageUrls.value.length) {
  78. imageIdx.value = val - 1
  79. } else {
  80. ElMessageBox.alert('跳转索引有误,请检查!')
  81. }
  82. }
  83. const changeFps = () => {
  84. console.log('changeFps')
  85. if (intervalChangeFps.value) {
  86. clearInterval(intervalChangeFps.value)
  87. }
  88. if (imageFps.value == 0) {
  89. return
  90. }
  91. intervalChangeFps.value = setInterval(() => {
  92. next_picture()
  93. }, 1000 / imageFps.value)
  94. }
  95. const next_picture = () => {
  96. if (imageIdx.value <= currentImageUrls.value.length - 1) {
  97. imageIdx.value += 1
  98. }
  99. }
  100. const pre_picture = () => {
  101. if (imageIdx.value > 0) {
  102. imageIdx.value -= 1
  103. }
  104. }
  105. </script>
  106. <style scoped lang="scss">
  107. .image-dialog {
  108. display: flex;
  109. justify-content: center;
  110. .el-image {
  111. margin-right: 20px;
  112. margin-bottom: 20px;
  113. }
  114. }
  115. .image-dialog-btn {
  116. display: flex;
  117. justify-content: center;
  118. margin-top: 20px;
  119. }
  120. </style>