实验安装

main
Ly 2 weeks ago
parent 639a56f393
commit 4d9d68d8ac
  1. 15
      src/api/index.ts
  2. BIN
      src/assets/images/bg13.png
  3. BIN
      src/assets/images/bg14.png
  4. 418
      src/views/largeDataScreen/home.vue
  5. 136
      src/views/subjectTest/index.vue

@ -12,3 +12,18 @@ export const getCode = (time: any) => {
url: '/sys/randomImage/' + time,
})
}
//试题表
export const subTestapi = () => {
return request({
url: '/questions/xnQuestions/api/list',
method: 'get',
})
}
//试题回答检查
export const checkapi = (params:any)=> {
return request({
url: '/questionrecords/xnQuestionRecords/check',
method: 'get',
params
})
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.4 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.0 KiB

@ -131,6 +131,71 @@
</div>
</div>
</el-popover>
<el-popover
placement="right"
:width="260"
trigger="contextmenu"
v-if="product"
ref="popover2"
>
<template #reference>
<div class="item">
<div class="icon">
<img
style="width: 100%"
src="@/assets/images/bg14.png"
alt=""
srcset=""
/>
</div>
<div class="file-name">LabVIEW2014</div>
</div>
</template>
<div class="setting-list">
<div class="item" @click="openSrttingDialog">
<div class="icon">
<!-- <img src="@/assets/images/home.png" alt="" /> -->
</div>
<div class="name" style="font-weight: 700">打开</div>
</div>
<div class="item">
<div class="icon">
<img src="@/assets/images/home.png" alt="" />
</div>
<div class="name">管理员身份运行</div>
</div>
<div class="item">
<div class="icon">
<img src="@/assets/images/home.png" alt="" />
</div>
<div class="name">解压到当前文件夹</div>
</div>
<div class="item">
<div class="icon">
<img src="@/assets/images/home.png" alt="" />
</div>
<div class="name">解压到...</div>
</div>
<div class="item">
<div class="icon">
<img src="@/assets/images/home.png" alt="" />
</div>
<div class="name">解压到"LabVIEW2024 (64位)\"</div>
</div>
<div class="item">
<div class="icon">
<img src="@/assets/images/home.png" alt="" />
</div>
<div class="name">其他压缩命令</div>
</div>
<div class="item">
<div class="icon">
<img src="@/assets/images/home.png" alt="" />
</div>
<div class="name">Edit width Notepad++</div>
</div>
</div>
</el-popover>
</div>
<div class="openFilesGroupDialg">
<div class="step1" v-show="step === 1">
@ -248,19 +313,115 @@
<div class="title">用户信息</div>
<div class="tip">请输入以下信息</div>
<div class="name">
<span>全名</span><el-input style="width: 280px;margin-left: 30px;"></el-input>
<span>全名</span><el-input style="width: 280px;margin-left: 30px;"placeholder="软件安全管家"></el-input>
</div>
<div class="unit">
<span>单位</span><el-input style="width: 280px;margin-left: 30px;"></el-input>
<span>单位</span><el-input style="width: 280px;margin-left: 30px;"placeholder="中国大陆"></el-input>
</div>
</div>
<div class="step3" v-show="installationStep === 3">
<div class="title">序列号</div>
<div class="tip">请输入以下产品序列号</div>
<div class="serial">
<div class="name" >序列号</div>
<el-form label-width="400px" style="max-width: 720" >
<el-form-item label="LabVIEW 2014(基本版 / 完整版 / 专业版):"label-width="307px">
<el-input style="width: 300px;margin-left: 95px;" />
</el-form-item>
<el-form-item label="应用程序生成器 - 用于 LabVIEW 2014,如激活 LabVIEW 专业版则保留空白:">
<el-input style="width: 300px"/>
</el-form-item>
<el-form-item label="Report Generation 工具包 - 用于 LabVIEW 2014,如激活 LabVIEW 专业版则保留空白:">
<el-input style="width: 300px"/>
</el-form-item>
<el-form-item label="atabase 工具包 - 用于 LabVIEW 2014,如激活 LabVIEW 专业版则保留空白):">
<el-input style="width: 300px"/>
</el-form-item>
</el-form>
</div>
</div>
<div class="step4" v-show="installationStep === 4">
<div class="title">目标目录</div>
<div class="tip">选择主安装目录</div>
<div class="item">选择 NI 软件的安装文件夹</div>
<el-select disabled placeholder="C:\Users\LabVIEW Chinese\2014" style="width: 300px;margin-top: 10px;"/>
<el-button disabled style="margin-left: 5px;margin-top: 10px;">浏览</el-button>
<div class="item">选择NI LabVIEW 2014的安装文件夹</div>
<el-select disabled placeholder="C:\Users\LabVIEW Chinese\2014" style="width: 300px;margin-top: 10px;"/>
<el-button disabled style="margin-left: 5px;margin-top: 10px;">浏览</el-button>
</div>
<div class="step5" v-show="installationStep === 5">
<div class="title">组件</div>
<div class="tip">选择需要安装的组件</div>
<div class="headers">
<div class="header">
<div class="item">NI LabVIEW 2014</div>
<div class="item">Database Connectivity工具包</div>
<div class="item">Report Generation工具包</div>
<div class="item">V Package Manager 2014</div>
<div class="item">附加组件</div>
<div class="item">HI Measurement & Automation Explorer</div>
<div class="item">设备驱动程序</div>
</div>
<div class="image-container">
<p style="margin-bottom: 20px;">测量和仪器的图形化编程</p>
<img src="@/assets/images/bg13.png" alt="">
<p style="margin-top: 20px;">该组件将安装至本地硬盘</p>
</div>
</div>
<div class="name">选择NI LabVIEW 2014的安装文件夹</div>
<el-select disabled placeholder="C:\Users\LabVIEW Chinese\2014" style="width: 300px;margin-top: 10px;"/>
<el-button disabled style="margin-left: 5px;margin-top: 10px;">浏览</el-button>
</div>
<div class="step6" v-show="installationStep === 6">
<div class="title">产品通知</div>
<div class="tip">请查看所选配置的相关信息</div>
<div class="item">
警告可能已启用Windows防火墙默认状态下Windows操作系统启用防火墙首次打开LabVIEW时可能会弹出一个对话框要求您选择是否从网络接收信息建议选择解除阻止以使用LabVIEW的所有网络功能详细信息请访问ni.com/info并输入信息代码expm69查询
<br>产品注意事项
<br>安装该产品之前必须安装Microsoft Office XP或更高版本Report Generation工具包-用于Microsoft Office提供的一组VI可用于创建和编辑Microsoft Word和Microsoft Excel格式的报表通过报表生成工具用户可使用WordExcel或自定义模板创建风格一致的专业报表减少报表显示打印或保存前编程的工作量还可以在*.rd文档和Excel工作表中执行Visual Basic宏实现自定义的功能更多关于Report Generation工具包的信息请访问ni.com/info并输入信息代码report
<br>正在安装自等社过猪保要票影的前我地,是器得品和更新如执行搜索则gational Instruments将在遵循保密协议的前提下使用您的搜索查询来改进搜索结果和相关性
</div>
</div>
<div class="step7" v-show="installationStep === 7">
<p class="name">总进度</p>
<el-progress :text-inside="true" :stroke-width="20" :percentage="80" style="margin-bottom: 25px"/>
<p class="name">复制新文件</p>
<el-progress :percentage="100" status="success" :stroke-width="20" />
</div>
<div class="step7" v-show="installationStep === 8">
<p class="name">总进度</p>
<el-progress :text-inside="true" :stroke-width="20" :percentage="80" style="margin-bottom: 25px"/>
<p class="name">复制新文件</p>
<el-progress :percentage="100" status="success" :stroke-width="20" />
</div>
</div>
<template #footer>
<div class="dialog-footer">
<el-button
v-show="installationStep === 5"
@click="Installation = false"
style="background-color: #f3f3f3; color: #000000; border-color: #ccc"
>恢复默认设置</el-button
>
<el-button
v-show="installationStep === 5"
@click="Installation = false"
style="background-color: #f3f3f3; color: #fff; border-color: #ccc"
style="background-color: #f3f3f3; color: #000000; border-color: #ccc"
>磁盘占用</el-button
>
<el-button
v-show="installationStep === 6"
@click="Installation = false"
style="background-color: #f3f3f3; color: #000000; border-color: #ccc"
>保存文件</el-button
>
<el-button
@click="Installation = false"
style="background-color: #f3f3f3; color: #000000; border-color: #ccc"
>上一步</el-button
>
<el-button
@ -273,13 +434,80 @@
<el-button
type="primary"
@click="Installation = false"
style="background-color: #f3f3f3; color: #fff; border-color: #ccc"
style="background-color: #f3f3f3; color: #000000; border-color: #ccc"
>
取消
</el-button>
</div>
</template>
</el-dialog>
<el-dialog
v-model="Popup"
width="650px"
height="500px"
top="10%"
style="left: 5%;padding: 0;"
>
<template #header>
<div class="dialog-header" >安装LabVIEW硬件支持</div>
</template>
<div class="installation-box">
<div v-show="installationStep === 8">
<div style="margin-top: 8px; margin-bottom: 80px;font-size: 16px;line-height: 1.6;letter-spacing: 0.5px;font-weight: bold">如需使LabVIEW支持硬件设备必须安装相应的设备驱动程序即便以前版本的LabVIEW已经安装相应设备驱动程序仍需需为当前版本的LabVIEW重新安装</div>
<div class="item">如所需文件处于其他位置请在下面输入相应路径</div>
<el-select disabled placeholder="C:\Users\LabVIEW Chinese\2014" style="width: 300px;margin-top: 10px;margin-left: 15px;"/>
<el-button disabled style="margin-left: 5px;margin-top: 10px;">浏览</el-button>
</div>
<div class="step9" v-show="installationStep === 9"style="height: 250px;font-weight: bold;font-size: 16px;">
安装完成!
</div>
</div>
<template #footer>
<div class="dialog-footer">
<el-button
v-show="installationStep === 8"
size="large"
@click="Installation = false"
style="background-color: #f3f3f3; color: #000000; border-color: #ccc"
>安装支持</el-button
>
<el-button
v-show="installationStep === 8"
type="primary"
size="large"
@click="setInstallationStep"
style="background-color: #0052d9; color: #fff; border: 0"
>
不需要支持
</el-button>
<el-button
v-show="installationStep === 9"
size="large"
@click="Installation = false"
style="background-color: #f3f3f3; color: #000000; border-color: #ccc"
>上一步</el-button
>
<el-button
v-show="installationStep === 9"
type="primary"
size="large"
@click="Installation = false"
style="background-color: #f3f3f3; color: #000000; border-color: #ccc"
>
下一步
</el-button>
<el-button
v-show="installationStep === 9"
size="large"
@click="Completed"
style="background-color: #0052d9; color: #fff; border: 0"
>完成</el-button
>
</div>
</template>
</el-dialog>
</template>
<script setup lang="ts">
@ -287,11 +515,13 @@ import { ref } from "vue";
type Falg = boolean;
type Step = number;
const falg = ref<Falg>(false);
const product = ref<Falg>(false);
const step = ref<Step>(0);
const popover1 = ref<any>(null);
const popover2 = ref<any>(null);
const dialogVisible = ref<Falg>(false);
const Installation = ref<Falg>(false);
const Popup = ref<Falg>(false);
const installationStep = ref<Step>(1);
const checkList = ref<Step[]>([1, 2]);
const unpack = (): void => {
@ -316,7 +546,18 @@ const openSrttingDialog = (): void => {
};
const setInstallationStep = (): void => {
installationStep.value++;
if(installationStep.value == 8){
Popup.value = true
}
if(installationStep.value == 9){
Installation.value = false
Popup.value = true
}
};
const Completed = ():void => {
Popup.value = false
product.value = true;
}
</script>
<style scoped lang="scss">
@ -332,8 +573,8 @@ const setInstallationStep = (): void => {
height: 753px;
// background-color: pink;
.app-list {
width: 100%;
height: 100%;
width: 500px;
height: 500px;
display: flex;
flex-direction: column;
flex-wrap: wrap;
@ -345,7 +586,7 @@ const setInstallationStep = (): void => {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
// justify-content: center;
cursor: pointer;
&:hover {
border: 1px solid #41d3ff;
@ -537,28 +778,155 @@ const setInstallationStep = (): void => {
}
}
.step2 {
min-height: 230px;
.title {
font-size: 24px;
color: #585858;
font-weight: 700;
margin-top: 10px;
}
.tip {
font-size: 16px;
line-height: 30px;
color: #585858;
min-height: 230px;
.title {
font-size: 24px;
color: #585858;
font-weight: 700;
margin-top: 10px;
}
.tip {
font-size: 16px;
line-height: 30px;
color: #585858;
margin-top: 10px;
}
.name,
.unit {
padding-left: 37px;
margin-top: 25px;
margin-top: 10px;
}
.name,
.unit {
padding-left: 37px;
margin-top: 25px;
}
}
.step3{
// width: 540px;
// height: 500px;
// border-radius: 5px;
// background-color: #fff;
.title {
font-size: 25px;
font-weight: bold; /* 设置文字加粗 */
}
.tip{
margin-top: 20px;
font-size: 15px;
font-weight: bold; /* 设置文字加粗 */
}
.serial{
margin-top: 40px;
.name{
font-size: 15px;
font-weight: bold; /* 设置文字加粗 */
margin-left: 400px;
margin-bottom: 15px;
}
:deep(.el-form-item__label ){
text-align: left; /* 设置label左对齐 */
line-height: 20px;
}
}
}
.step4{
.title {
font-size: 25px;
font-weight: bold; /* 设置文字加粗 */
}
.tip {
margin-top: 20px;
font-size: 15px;
font-weight: bold; /* 设置文字加粗 */
}
.item{
margin-top: 50px;
}
.item:before {
content: "• "; /* 在内容前添加一个小点和空格 */
color: rgb(0, 0, 0); /* 设置小点的颜色 */
font-size: 15px; /* 设置小点的大小 */
margin-right: 5px; /* 设置小点和文本之间的间距 */
}
}
.step5{
.title {
font-size: 25px;
font-weight: bold; /* 设置文字加粗 */
}
.tip {
margin-top: 20px;
font-size: 15px;
font-weight: bold; /* 设置文字加粗 */
}
.headers{
display: flex; /* 使用Flexbox布局 */
justify-content: space-between; /* 让子元素在容器中左右对齐 */
}
.header{
display: flex; /* 使用Flexbox布局 */
flex-direction: column; /* 设置子元素竖向排列 */
align-items: flex-start; /* 对齐方式,让子元素的起始位置对齐 */
width: auto;
}
.item{
margin-top: 20px;
margin-left: 30px;
font-size: 13px;
}
}
.item:before {
content: '▸ '; /* 在内容前添加一个小点和空格 */
color: rgb(0, 0, 0); /* 设置小点的颜色 */
font-size: 13px; /* 设置小点的大小 */
margin-right: 5px; /* 设置小点和文本之间的间距 */
}
.image-container {
background-color: #ebebeb;
width: 300px; /* 或者根据需要调整宽度 */
margin-left: auto; /* 推动到右侧 */
padding: 10px;
display: flex; /* 启用Flexbox布局 */
flex-direction: column; /* 设置子元素竖向排列 */
justify-content: center; /* 垂直居中 */
align-items: center; /* 水平居中 */
}
.name{
margin-top: 40px;
}
.name:before {
content: "• "; /* 在内容前添加一个小点和空格 */
color: rgb(0, 0, 0); /* 设置小点的颜色 */
font-size: 15px; /* 设置小点的大小 */
margin-right: 5px; /* 设置小点和文本之间的间距 */
}
}
.step6{
.title {
font-size: 15px;
font-weight: bold; /* 设置文字加粗 */
color: #f2994a;
margin-bottom: 10px;
}
.item{
margin-top: 40px;
line-height: 1.6; /* 设置行高 */
letter-spacing: 0.5px; /* 设置字母间距 */
}
}
.step7{
padding: 50px;
// width: 600px;
.name{
margin-bottom: 8px;
font-size: 15px;
font-weight: bold; /* 设置文字加粗 */
}
.item:before {
content: "• "; /* 在内容前添加一个小点和空格 */
color: rgb(0, 0, 0); /* 设置小点的颜色 */
font-size: 15px; /* 设置小点的大小 */
margin-right: 5px; /* 设置小点和文本之间的间距 */
}
}
}
.dialog-header {
padding: 20px;

@ -15,19 +15,19 @@
<p class="questions"><span class="questions-count">10</span></p>
<!-- 遍历题目 -->
<div v-if="currentQuestionIndex < questions.length" class="txt">
<span>{{ currentQuestion.question }}</span>
<span>{{ currentQuestion }}</span>
</div>
<!-- 遍历选项 -->
<div class="options">
<button
v-for="option in currentQuestion.options"
:key="option.option"
:class="{ option: true, selected: selectedOption[currentQuestionIndex] === option.option }"
@click="selectOption(option.option)"
v-for="option in xnOptionsList"
:key="option.id"
:class="['option', { 'selected': selectedOption[currentQuestionIndex] && selectedOption[currentQuestionIndex].oid == option.id }]"
@click="selectOption(option.id)"
class="option"
>
<span class="option-letter">{{ option.option }}</span>
{{ option.content }}
<span class="option-letter">{{ option.optionName }}</span>
{{ option.optionText }}
</button>
</div>
@ -46,6 +46,7 @@
<script lang="ts" setup>
import resultsAnnounced from '@/views/resultsAnnounced/index.vue'
import settingStore from "@/store/modules/setting";
import {subTestapi,checkapi} from '@/api/index.ts'
import { ref,computed,onMounted, onUnmounted} from "vue"
import { ElMessage } from 'element-plus'
const setting = settingStore();
@ -59,13 +60,15 @@ import { ElMessage } from 'element-plus'
}
}
//
const SubRight =()=>{
const SubRight = async()=>{
const res:any = await checkapi(selectedOption.value[currentQuestionIndex.value]);
// answer.value = res.result;
console.log(selectedOption.value);
console.log(res,'res')
//
if (selectedOption.value[currentQuestionIndex.value] === currentQuestion.value.correctAnswer) {
if(currentSum.value < questions.length){
setTimeout(() => {
currentQuestionIndex.value++; //
}, 200); // 0.2
if (res.result == "success") {
if(currentSum.value < questions.value.length){
currentQuestionIndex.value++; //
}
else{
ElMessage.success('答题已完成,请提交')
@ -79,82 +82,79 @@ import { ElMessage } from 'element-plus'
}
}
}
const questions = [
{
//
question: "根据基尔霍夫电压定律(KVL),下列说法正确的是:",
//
options: [
{ option: "A", content: "在任一瞬时,沿任一闭合回路各段电压的代数和为零。" },
{ option: "B", content: "在任一瞬时,沿任一闭合回路各段电压的代数和不为零。" },
{ option: "C", content: "在任一瞬时,沿任一闭合回路各段电压的代数和为正。" },
{ option: "D", content: "在任一瞬时,沿任一闭合回路各段电压的代数和为负。" }
],
correctAnswer: "A" //
},
{
question: "根据欧姆定律,下列说法正确的是:",
options: [
{ option: "A", content: "电流与电压成反比,与电阻成正比。" },
{ option: "B", content: "电流与电压成正比,与电阻成反比。" },
{ option: "C", content: "电流与电压和电阻无关。" },
{ option: "D", content: "电流与电压成正比,与电阻成正比。" }
],
correctAnswer: "B" //
},
{
question: "在电路分析中,欧姆定律是一个基本而重要的原理,它描述了电流、电压和电阻之间的关系。根据欧姆定律,通过导体的电流与导体两端的电压成正比,与导体的电阻成反比。请根据这一定律,选择下列哪个选项最准确地描述了这一关系?此外,考虑到实际应用中,导体的电阻可能会受到温度、材料和几何尺寸等因素的影响,这些因素如何改变电流与电压和电阻之间的关系?",
options: [
{ option: "A", content: "电流与电压成正比,与电阻成正比。" },
{ option: "B", content: "电流与电压成正比,与电阻成反比。" },
{ option: "C", content: "电流与电压成反比,与电阻无关。" },
{ option: "D", content: "电流与电压和电阻均无关,仅受外部磁场影响。" }
],
correctAnswer: "C" //
}
];
const questions = ref<any[]>([]);
const currentList = async ()=>{
const res:any = await subTestapi();
questions.value = res.result
console.log(res.result)
// console.log(questions.value[0].xnOptionsList[0].id)
// console.log(questions.value,'questions1.value')
}
//
const currentQuestionIndex = ref(0);
//1
const currentSum = computed(() => currentQuestionIndex.value + 1);
//
const currentQuestion = computed(() => questions[currentQuestionIndex.value]);
const currentQuestion = computed(() => {
// questions.value
if (questions.value.length > 0) {
return questions.value[currentQuestionIndex.value].questionText;
}
return '';
});
const xnOptionsList =computed(() =>{
if (questions.value.length > 0) {
return questions.value[currentQuestionIndex.value].xnOptionsList
}
console.log(selectedOption.value)
return [];
})
//
const selectedOption = ref<string[]>(Array(questions.length).fill(null)); // null
// questions.value null
const selectedOption = ref<{ oid: any; qid: string }[]>(Array(questions.value.length).fill(null));
//
const selectOption = (option: string) => {
selectedOption.value[currentQuestionIndex.value] = option; //
console.log(selectedOption.value);
};
const selectOption = (option:any) => {
if (questions.value.length > 0) {
const currentQuestion = questions.value[currentQuestionIndex.value];
selectedOption.value[currentQuestionIndex.value]= {
oid: option,
qid: currentQuestion.id
};
console.log(selectedOption.value[currentQuestionIndex.value].oid,option);
}
}
const score = ref(0); // 0
const isVisible = ref (false) //
//
const submitAnswers = () => {
const submitAnswers = async() => {
console.log(selectedOption.value[currentQuestionIndex.value])
//
if(selectedOption.value[questions.length - 1] == null){
if(selectedOption.value[questions.value.length - 1] == null){
ElMessage.warning('请先完成答题')
}else{
if (selectedOption.value[currentQuestionIndex.value] !== currentQuestion.value.correctAnswer){
const res:any = await checkapi(selectedOption.value[currentQuestionIndex.value]);
if (res.result !== "success"){
ElMessage.error('回答错误')
}else{
stopTimer(); //
score.value = 0; //
score.value = 100; //
isVisible.value = true;
for (let i = 0; i < questions.length; i++) {
// 10
if (selectedOption.value[i] === questions[i].correctAnswer) {
score.value += 10;
}
}
// for (let i = 0; i < questions.value.length; i++) {
// // 10
// if (res.result == "success") {
// // score.value += 10;
// score.value == 100
// }
// }
}
}
};
// 退
const resetAnswers = () => {
isVisible.value = false;
};
//
const timer = ref<number | null>(null); // setInterval
@ -182,7 +182,7 @@ import { ElMessage } from 'element-plus'
}
};
//
onMounted(() => {startTimer();});
onMounted(() => {startTimer();currentList();});
//
onUnmounted(() => {stopTimer();});
@ -191,7 +191,7 @@ import { ElMessage } from 'element-plus'
const handleRecreate = () => {
console.log(timer.value,"子组件触发了重做事件");
isVisible.value = false; //
selectedOption.value = Array(questions.length).fill(null); //
selectedOption.value = Array(questions.value.length).fill(null); //
currentQuestionIndex.value = 0; //
stopTimer()//
elapsedTime.value = 0
@ -277,8 +277,8 @@ import { ElMessage } from 'element-plus'
letter-spacing: 3px; /* 字符间距 */
text-align: right;
position: absolute; /* 使用绝对定位 */
top: 24.5%; /* 距离顶部 50% */
left: 71%; /* 距离左侧 50% */
top: 24.5%; /* 距离顶部 */
left: 71.4%; /* 距离左侧 */
}
.questions{
font-size: 23px; /* 字体大小 */

Loading…
Cancel
Save