HumanBreak/src/components/enemyOne.vue

236 lines
6.6 KiB
Vue
Raw Normal View History

2022-11-16 23:01:23 +08:00
<template>
2022-11-19 18:15:42 +08:00
<div
class="enemy-container"
@click="select"
2023-04-22 10:10:54 +08:00
@mousemove="enter"
2022-11-19 18:15:42 +08:00
:selected="selected"
2023-12-01 21:44:37 +08:00
:style="style"
2022-11-19 18:15:42 +08:00
>
2022-11-16 23:01:23 +08:00
<div class="info">
<div class="leftbar">
2023-07-31 16:49:04 +08:00
<span class="name">{{ enemy.enemy.enemy.name }}</span>
2022-11-16 23:01:23 +08:00
<BoxAnimate
2023-07-31 16:49:04 +08:00
:id="enemy.enemy.id"
2022-12-29 19:57:31 +08:00
:width="isMobile ? 32 : w"
:height="isMobile ? 32 : w"
2022-11-16 23:01:23 +08:00
style="margin: 5%"
></BoxAnimate>
<div
class="special-text"
v-if="has(enemy.special) && enemy.special.length > 0"
>
<span
2023-07-31 16:49:04 +08:00
v-for="(text, i) in enemy.showSpecial"
:style="{ color: text[2] }"
>&nbsp;{{ text[0] }}&nbsp;</span
2022-11-16 23:01:23 +08:00
>
</div>
<div class="special-text" v-else>无属性</div>
</div>
<a-divider
type="vertical"
dashed
2022-11-19 11:30:14 +08:00
style="height: 100%; margin: 0 3% 0 1%; border-color: #ddd4"
2022-11-16 23:01:23 +08:00
></a-divider>
<div class="rightbar">
<div class="detail">
<div class="detail-info">
<span style="color: lightgreen"
>生命&nbsp;&nbsp;&nbsp;&nbsp;{{
2023-07-31 16:49:04 +08:00
core.formatBigNumber(enemy.enemy.info.hp)
2022-11-16 23:01:23 +08:00
}}</span
>
</div>
<div class="detail-info">
<span style="color: lightcoral"
>攻击&nbsp;&nbsp;&nbsp;&nbsp;{{
2023-07-31 16:49:04 +08:00
core.formatBigNumber(enemy.enemy.info.atk)
2022-11-16 23:01:23 +08:00
}}</span
>
</div>
<div class="detail-info">
<span style="color: lightblue"
>防御&nbsp;&nbsp;&nbsp;&nbsp;{{
2023-07-31 16:49:04 +08:00
core.formatBigNumber(enemy.enemy.info.def)
2022-11-16 23:01:23 +08:00
}}</span
>
</div>
<div class="detail-info">
<span style="color: lightyellow"
>金币&nbsp;&nbsp;&nbsp;&nbsp;{{
2023-07-31 16:49:04 +08:00
core.formatBigNumber(enemy.enemy.enemy.money)
2022-11-16 23:01:23 +08:00
}}</span
>
</div>
<div class="detail-info">
<span style="color: lawngreen"
>经验&nbsp;&nbsp;&nbsp;&nbsp;{{
2023-07-31 16:49:04 +08:00
core.formatBigNumber(enemy.enemy.enemy.exp)
2022-11-16 23:01:23 +08:00
}}</span
>
</div>
<div class="detail-info">
2023-07-31 16:49:04 +08:00
<span :style="{ color: enemy.damageColor }"
2022-12-30 14:14:28 +08:00
>伤害&nbsp;&nbsp;&nbsp;&nbsp;{{
2023-07-31 16:49:04 +08:00
enemy.damage
2022-11-16 23:01:23 +08:00
}}</span
>
</div>
2022-12-30 14:14:28 +08:00
2022-11-16 23:01:23 +08:00
<div class="detail-info">
<span style="color: lightsalmon"
>临界&nbsp;&nbsp;&nbsp;&nbsp;{{
2023-07-31 16:49:04 +08:00
enemy.critical
2022-11-16 23:01:23 +08:00
}}</span
>
</div>
<div class="detail-info">
<span style="color: lightpink"
>减伤&nbsp;&nbsp;&nbsp;&nbsp;<span
:style="{
2023-07-31 16:49:04 +08:00
color: 'lightpink'
2022-11-16 23:01:23 +08:00
}"
2023-07-31 16:49:04 +08:00
>{{ enemy.criticalDam }}</span
2022-11-16 23:01:23 +08:00
></span
>
</div>
<div class="detail-info">
2022-12-30 14:14:28 +08:00
<span style="color: cyan"
>{{
core.formatBigNumber(core.status.thisMap.ratio)
}}&nbsp;&nbsp;&nbsp;&nbsp;{{
2023-07-31 16:49:04 +08:00
core.formatBigNumber(enemy.defDam)
2022-11-16 23:01:23 +08:00
}}</span
>
</div>
</div>
</div>
</div>
</div>
</template>
<script lang="ts" setup>
import { has } from '../plugin/utils';
import BoxAnimate from '../components/boxAnimate.vue';
import { isMobile } from '../plugin/use';
2023-07-31 16:49:04 +08:00
import { ToShowEnemy } from '../plugin/ui/book';
2023-12-01 21:44:37 +08:00
import border from '@/data/enemyBorder.json';
2022-11-16 23:01:23 +08:00
const props = defineProps<{
2023-07-31 16:49:04 +08:00
enemy: ToShowEnemy;
2022-11-19 18:15:42 +08:00
selected?: boolean;
2022-11-16 23:01:23 +08:00
}>();
2022-11-19 11:30:14 +08:00
const emits = defineEmits<{
(e: 'select'): void;
2022-11-19 18:15:42 +08:00
(e: 'hover'): void;
2022-11-19 11:30:14 +08:00
}>();
2022-11-16 23:01:23 +08:00
const core = window.core;
2022-11-19 11:30:14 +08:00
2022-12-29 19:57:31 +08:00
const w = window.innerWidth * 0.032;
2023-12-01 21:44:37 +08:00
const style = border[props.enemy.enemy.enemy.id as keyof typeof border] ?? {};
2022-11-19 11:30:14 +08:00
/**
* 选择这个怪物时
*/
function select(e: MouseEvent) {
emits('select');
}
2022-11-19 18:15:42 +08:00
function enter() {
emits('hover');
}
2022-11-16 23:01:23 +08:00
</script>
<style lang="less" scoped>
.enemy-container {
border: 1.5px solid transparent;
2023-08-06 17:46:29 +08:00
border-radius: 15px;
2022-11-16 23:01:23 +08:00
transition: all 0.2s linear;
height: 100%;
.info {
flex-basis: 100%;
display: flex;
flex-direction: row;
align-items: center;
justify-content: stretch;
height: 100%;
}
}
2022-11-19 18:15:42 +08:00
.enemy-container[selected='true'] {
2022-11-16 23:01:23 +08:00
border: 1.5px solid gold;
}
.leftbar {
2022-11-19 11:30:14 +08:00
width: 15%;
2022-11-16 23:01:23 +08:00
height: 100%;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
2023-08-06 17:46:29 +08:00
font-size: 120%;
2022-11-19 11:30:14 +08:00
padding-left: 1%;
2022-11-16 23:01:23 +08:00
}
.name {
text-align: center;
max-width: 100%;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
display: block;
}
.special-text {
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
2022-11-19 11:30:14 +08:00
display: flex;
flex-direction: row;
align-items: center;
justify-items: space-between;
2022-11-16 23:01:23 +08:00
}
.rightbar {
2023-08-06 17:46:29 +08:00
font-size: 140%;
width: 85%;
2022-11-16 23:01:23 +08:00
height: 100%;
padding: 1.5vh 0 1.5vh 0;
.detail {
display: flex;
2022-12-30 14:14:28 +08:00
flex-direction: row;
2022-11-16 23:01:23 +08:00
flex-wrap: wrap;
height: 100%;
.detail-info {
2022-11-19 11:30:14 +08:00
flex-basis: 33.3%;
2022-11-16 23:01:23 +08:00
line-height: 0;
display: flex;
flex-direction: column;
justify-content: center;
}
}
}
2022-11-19 11:30:14 +08:00
@media screen and (max-width: 600px) {
.rightbar {
2023-08-06 17:46:29 +08:00
width: 80%;
font-size: 85%;
2022-11-19 11:30:14 +08:00
}
.leftbar {
2023-08-06 17:46:29 +08:00
width: 20%;
font-size: 80%;
2022-11-19 11:30:14 +08:00
}
2022-12-31 19:49:43 +08:00
.enemy-container {
2023-08-06 17:46:29 +08:00
border-radius: 20px;
2022-12-31 19:49:43 +08:00
}
2022-11-19 11:30:14 +08:00
}
2022-11-16 23:01:23 +08:00
</style>