You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
247 lines
7.8 KiB
247 lines
7.8 KiB
<template>
|
|
<div
|
|
class="image_container"
|
|
v-if="cameraStore?.cameraState || imageStore.showImage"
|
|
>
|
|
<img
|
|
v-if="
|
|
(cameraStore?.cameraState && !imageStore.showImage) ||
|
|
!imageStore?.coreInfo?.resultImg ||
|
|
imageStore?.coreInfo?.result == 0
|
|
"
|
|
:src="photoUrl"
|
|
alt="图像"
|
|
class="img"
|
|
/>
|
|
<img v-else :src="imageStore?.coreInfo?.resultImg" alt="图像" class="img" />
|
|
<div class="top_info">
|
|
<p class="title">{{ imageStore.nuclearCoreName }}</p>
|
|
<div class="title_left">
|
|
<p class="sign">
|
|
{{ handleSerialNumber(imageStore?.coreInfo?.serialNumber) }}
|
|
</p>
|
|
<div class="tag_wrap">
|
|
<p>{{ imageStore?.coreInfo?.firstSign?.substr(-4) }}</p>
|
|
<p>{{ imageStore?.coreInfo?.secondSign?.substr(-4) }}</p>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div :class="getIdentifyClass()">
|
|
<div class="left_wrap">
|
|
<svg
|
|
xmlns="http://www.w3.org/2000/svg"
|
|
xmlns:xlink="http://www.w3.org/1999/xlink"
|
|
fill="none"
|
|
v-if="imageStore?.coreInfo?.result != 1"
|
|
version="1.1"
|
|
width="30"
|
|
height="29.999998092651367"
|
|
viewBox="0 0 30 29.999998092651367"
|
|
>
|
|
<g>
|
|
<path
|
|
d="M15,0C6.74916,0,0,6.74916,0,15C0,23.2508,6.74916,30,15,30C23.2508,30,30,23.2508,30,15C30,6.74916,23.2508,0,15,0ZM22.1672,20.1672C22.6689,20.6689,22.6689,21.5853,22.1672,22.0836C21.9164,22.3344,21.5853,22.5017,21.1672,22.5017C20.8328,22.5017,20.4181,22.3344,20.1672,22.0836L15.3344,17.2508L10.5017,22.0836C10,22.5853,9.08361,22.5853,8.58528,22.0836C8.08696,21.5819,8.08361,20.6656,8.58528,20.1672L13.4181,15.3344L8.58528,10.5017C8.33445,10.2508,8.16722,9.91973,8.16722,9.50167C8.16722,9.16722,8.33445,8.75251,8.58528,8.50167C9.08696,8,10.0033,8,10.5017,8.50167L15.3344,13.3344L20.1672,8.50167C20.4181,8.25084,20.7492,8.08361,21.1672,8.08361C21.5017,8.08361,21.9164,8.25084,22.1672,8.50167C22.4181,8.75251,22.5853,9.08361,22.5853,9.50167C22.5853,9.83612,22.4181,10.2508,22.1672,10.5017L17.3344,15.3344L22.1672,20.1672Z"
|
|
fill="#FFFFFF"
|
|
fill-opacity="1"
|
|
/>
|
|
</g>
|
|
</svg>
|
|
<svg
|
|
v-else
|
|
xmlns="http://www.w3.org/2000/svg"
|
|
xmlns:xlink="http://www.w3.org/1999/xlink"
|
|
fill="none"
|
|
version="1.1"
|
|
width="30"
|
|
height="30.000120162963867"
|
|
viewBox="0 0 30 30.000120162963867"
|
|
>
|
|
<g>
|
|
<path
|
|
d="M15,30.0001C6.71625,30.0001,0,23.2838,0,15.0001C0,6.71628,6.71625,0,15,0C23.2838,0,30,6.71628,30,15.0001C30,23.2838,23.2838,30.0001,15,30.0001ZM11.655,20.8901C12.2652,21.5005,13.2548,21.5005,13.865,20.8901L23.3375,11.4175C23.9478,10.8073,23.9478,9.81781,23.3375,9.20754C22.7272,8.59726,21.7378,8.59726,21.1275,9.20754L12.6925,17.5076L8.9175,13.7326C8.30736,13.1215,7.31725,13.1211,6.70665,13.7317C6.09604,14.3423,6.09642,15.3324,6.7075,15.9426L11.655,20.8901Z"
|
|
fill="#FFFFFF"
|
|
fill-opacity="1"
|
|
/>
|
|
</g>
|
|
</svg>
|
|
<!-- <p>A-8</p> -->
|
|
</div>
|
|
<div class="tag_wrap">
|
|
<p>
|
|
{{
|
|
imageStore?.coreInfo?.resultSerial?.split('-')[0]?.substr(-4)
|
|
? imageStore?.coreInfo?.resultSerial?.split('-')[0]?.substr(-4)
|
|
: '空结果'
|
|
}}
|
|
</p>
|
|
<p>
|
|
{{ imageStore?.coreInfo?.resultSerial?.split('-')[1]?.substr(-4) }}
|
|
</p>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="no_image" v-else>
|
|
<!-- 根据相机是否开启切换不同的icon -->
|
|
<svg
|
|
xmlns="http://www.w3.org/2000/svg"
|
|
xmlns:xlink="http://www.w3.org/1999/xlink"
|
|
fill="none"
|
|
version="1.1"
|
|
width="85.90400695800781"
|
|
height="76.7254638671875"
|
|
viewBox="0 0 85.90400695800781 76.7254638671875"
|
|
>
|
|
<g>
|
|
<path
|
|
d="M6.91322,0L78.9908,0C82.8088,0,85.904,3.2252,85.904,7.20367L85.904,69.6923C85.8151,73.6041,82.7458,76.7266,78.9908,76.7255L6.91322,76.7255C3.15816,76.7266,0.0888908,73.6041,0,69.6923L0,7.20367C0,3.22519,3.09515,0,6.91322,0ZM63.5689,38.8742C64.784,37.9363,66.4446,37.9363,67.6596,38.8742L78.9908,43.7761L78.9908,7.20367L6.91322,7.20367L6.91322,38.107L22.3351,21.7815C23.6974,20.2285,26.0451,20.2285,27.4074,21.7815L48.6381,49.3601L63.5689,38.8742ZM51.0912,24.6798C51.0912,19.1005,55.4317,14.5776,60.7861,14.5776C66.1404,14.5777,70.4809,19.1005,70.481,24.6798C70.481,30.2591,66.1404,34.7821,60.7861,34.7821C55.4317,34.7821,51.0912,30.2591,51.0912,24.6798ZM58.0045,24.4667C58.0045,26.0675,59.2498,27.3652,60.7861,27.3652L60.7861,27.5357C62.3886,27.5387,63.6621,26.1337,63.5678,24.4667C63.5678,22.8658,62.3224,21.5681,60.7862,21.5681C59.2499,21.5681,58.0045,22.8658,58.0045,24.4667Z"
|
|
fill-rule="evenodd"
|
|
fill="#5E5C5C"
|
|
fill-opacity="1"
|
|
/>
|
|
</g>
|
|
</svg>
|
|
</div>
|
|
</template>
|
|
|
|
<script setup>
|
|
import { onMounted, ref } from 'vue'
|
|
import { transNumberToEn } from '@/utils/common'
|
|
import { useTaskStore, useImageStore, useCameraStore } from '@/store'
|
|
const taskStore = useTaskStore()
|
|
const imageStore = useImageStore()
|
|
const cameraStore = useCameraStore()
|
|
const photoUrl = ref('')
|
|
setInterval(
|
|
() => {
|
|
photoUrl.value = `${
|
|
import.meta.env.VITE_HOST_URL
|
|
}app/core/realtime_photo/now.png?${Math.random()}`
|
|
},
|
|
500,
|
|
500,
|
|
)
|
|
|
|
const handleSerialNumber = serialNumber => {
|
|
if (serialNumber) {
|
|
const arr = serialNumber.split('-')
|
|
if (arr && arr.length == 2) {
|
|
return `${transNumberToEn(arr[0])} - ${arr[1]}`
|
|
}
|
|
}
|
|
return ''
|
|
}
|
|
|
|
const getIdentifyClass = () => {
|
|
const res = imageStore?.coreInfo?.result
|
|
if (res == 1) {
|
|
return 'identify_info success'
|
|
} else {
|
|
return 'identify_info'
|
|
}
|
|
}
|
|
</script>
|
|
|
|
<style lang="scss" scoped>
|
|
.no_image {
|
|
width: 100%;
|
|
height: 100%;
|
|
border-radius: 6px;
|
|
overflow: hidden;
|
|
background: #ebebeb;
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
}
|
|
.image_container {
|
|
width: 100%;
|
|
height: 100%;
|
|
border-radius: 6px;
|
|
overflow: hidden;
|
|
position: relative;
|
|
background: #ddd;
|
|
.top_info {
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: space-between;
|
|
position: absolute;
|
|
left: 20px;
|
|
top: 20px;
|
|
right: 20px;
|
|
box-sizing: border-box;
|
|
padding: 10px 34px;
|
|
border-radius: 28px;
|
|
background: rgba(76, 90, 224, 0.2);
|
|
.title {
|
|
font-size: 20px;
|
|
font-weight: normal;
|
|
letter-spacing: 0.03em;
|
|
color: #ffffff;
|
|
background: none;
|
|
}
|
|
.title_left {
|
|
display: flex;
|
|
align-items: center;
|
|
.sign {
|
|
font-size: 26px;
|
|
font-weight: 900;
|
|
letter-spacing: 0.04em;
|
|
margin-right: 22px;
|
|
color: #ffffff;
|
|
}
|
|
.tag_wrap {
|
|
display: flex;
|
|
flex-direction: column;
|
|
align-items: center;
|
|
font-size: 20px;
|
|
font-weight: 500;
|
|
line-height: 19px;
|
|
letter-spacing: 0.03em;
|
|
color: #ffffff;
|
|
}
|
|
}
|
|
}
|
|
.identify_info {
|
|
position: absolute;
|
|
right: 28px;
|
|
bottom: 22px;
|
|
border-radius: 6px;
|
|
background: #fe0a0a;
|
|
font-size: 26px;
|
|
font-weight: 900;
|
|
letter-spacing: 0.04em;
|
|
color: #ffffff;
|
|
padding: 13px 20px;
|
|
box-sizing: border-box;
|
|
display: flex;
|
|
align-items: center;
|
|
.left_wrap {
|
|
display: flex;
|
|
flex-direction: column;
|
|
align-items: center;
|
|
font-size: 26px;
|
|
font-weight: 900;
|
|
letter-spacing: 0.04em;
|
|
color: #ffffff;
|
|
}
|
|
.tag_wrap {
|
|
display: flex;
|
|
flex-direction: column;
|
|
align-items: center;
|
|
font-size: 26px;
|
|
font-weight: 900;
|
|
letter-spacing: 0.04em;
|
|
color: #ffffff;
|
|
margin-left: 25px;
|
|
justify-content: space-between;
|
|
}
|
|
}
|
|
.success {
|
|
background: #01ff82;
|
|
}
|
|
.img {
|
|
object-fit: cover;
|
|
width: 100%;
|
|
height: 100%;
|
|
}
|
|
}
|
|
</style>
|