增加检查计轴可能有问题

This commit is contained in:
joylink_zhaoerwei 2023-12-05 17:33:54 +08:00
parent ec2830e9c2
commit 767ab87f25

View File

@ -5,16 +5,30 @@
</q-card-section> </q-card-section>
<q-form ref="myForm"> <q-form ref="myForm">
<selectConfig-utils ref="selectConfigUtils" :drawStore="drawStore" /> <selectConfig-utils ref="selectConfigUtils" :drawStore="drawStore" />
<div class="q-mt-md"> <div class="q-mt-md q-gutter-md">
<q-btn <q-btn label="确认修改" color="primary" @click="onSubmit" />
label="确认修改" <q-btn label="返回" color="red" @click="goBack" />
color="primary"
@click="onSubmit"
class="q-mr-md"
/>
<q-btn class="q-mr-md" label="返回" color="red" @click="goBack" />
<q-btn label="生成计轴" color="primary" @click="generateAxleCounting" /> <q-btn label="生成计轴" color="primary" @click="generateAxleCounting" />
</div> </div>
<div class="q-mt-md q-gutter-md">
<q-btn
label="检查计轴"
color="primary"
@click="showErrorAxleCounting"
/>
<q-btn
v-if="showCheck"
label="上一个"
color="primary"
@click="clickSelectCenter(-1)"
/>
<q-btn
v-if="showCheck"
label="下一个"
color="primary"
@click="clickSelectCenter(1)"
/>
</div>
</q-form> </q-form>
</q-card> </q-card>
</template> </template>
@ -32,6 +46,7 @@ import {
} from 'src/drawApp/commonApp'; } from 'src/drawApp/commonApp';
import SelectConfigUtils from 'src/components/common/SelectConfigUtils.vue'; import SelectConfigUtils from 'src/components/common/SelectConfigUtils.vue';
import { OneClickGenerate } from 'src/graphics/trainWindow/oneClickDrawAssistant'; import { OneClickGenerate } from 'src/graphics/trainWindow/oneClickDrawAssistant';
import { AxleCounting } from 'src/graphics/axleCounting/AxleCounting';
//使 //使
const filterSelect = (g: JlGraphic) => g instanceof Turnout; const filterSelect = (g: JlGraphic) => g instanceof Turnout;
@ -125,4 +140,49 @@ function generateAxleCounting() {
drawStore.oneClickType = 'AxleCounting'; drawStore.oneClickType = 'AxleCounting';
drawStore.getDrawApp().interactionPlugin(OneClickGenerate.Type).resume(); drawStore.getDrawApp().interactionPlugin(OneClickGenerate.Type).resume();
} }
const selectConfig = ref<
{
axleCountingId: string;
axleCountingCode: string;
}[]
>([]);
function showErrorAxleCounting() {
showCheck.value = true;
const axleCountings = drawStore
.getDrawApp()
.queryStore.queryByType<AxleCounting>(AxleCounting.Type);
const erroeAxleCountings = axleCountings
.filter(
(g) =>
g.datas.type ==
graphicData.AxleCounting.TypeDetectionPoint.AxleCounting &&
g.datas.axleCountingRef.length < 2
)
.sort((a, b) => a.position.x - b.position.x);
erroeAxleCountings.forEach((axleCounting) => {
selectConfig.value.push({
axleCountingId: axleCounting.id,
axleCountingCode: axleCounting.datas.code,
});
});
}
const currentIndex = ref(-1);
const showCheck = ref(false);
function clickSelectCenter(add: number) {
if (
currentIndex.value + add < 0 ||
currentIndex.value + add >= selectConfig.value.length
)
return;
currentIndex.value = currentIndex.value + add;
const target = drawStore
.getDrawApp()
.queryStore.queryById(
selectConfig.value[currentIndex.value].axleCountingId
);
drawStore.getDrawApp().makeGraphicCenterShow(target);
drawStore.getDrawApp().updateSelected(target);
}
</script> </script>