|
@@ -338,6 +338,7 @@
|
|
</defs>
|
|
</defs>
|
|
<!-- 背景图片 -->
|
|
<!-- 背景图片 -->
|
|
<image
|
|
<image
|
|
|
|
+ :style="`transform: translate(${getTransformPositionX()}px, 0)`"
|
|
x="0"
|
|
x="0"
|
|
y="90"
|
|
y="90"
|
|
height="787"
|
|
height="787"
|
|
@@ -346,6 +347,7 @@
|
|
href="./standAloneImg-green.png"
|
|
href="./standAloneImg-green.png"
|
|
/>
|
|
/>
|
|
<image
|
|
<image
|
|
|
|
+ :style="`transform: translate(${getTransformPositionX()}px, 0)`"
|
|
x="0"
|
|
x="0"
|
|
y="90"
|
|
y="90"
|
|
height="787"
|
|
height="787"
|
|
@@ -362,37 +364,37 @@
|
|
@click="click(3)"
|
|
@click="click(3)"
|
|
>
|
|
>
|
|
<use
|
|
<use
|
|
|
|
+ :transform="`translate(${getTransformPositionX(100)}, 190) scale(0.7)`"
|
|
class="stand-alone-img-item"
|
|
class="stand-alone-img-item"
|
|
xlink:href="#pitch"
|
|
xlink:href="#pitch"
|
|
x="214"
|
|
x="214"
|
|
y="110"
|
|
y="110"
|
|
- transform="translate(110, 190) scale(0.7)"
|
|
|
|
/>
|
|
/>
|
|
<use
|
|
<use
|
|
class="stand-alone-img-item-circle"
|
|
class="stand-alone-img-item-circle"
|
|
xlink:href="#stand-alone-circle-bj"
|
|
xlink:href="#stand-alone-circle-bj"
|
|
- x="320"
|
|
|
|
|
|
+ :x="getTransformPositionX(320)"
|
|
y="330"
|
|
y="330"
|
|
/>
|
|
/>
|
|
<line
|
|
<line
|
|
:class="{ 'stand-alone-line': line && hover == 3 }"
|
|
:class="{ 'stand-alone-line': line && hover == 3 }"
|
|
- x1="320"
|
|
|
|
|
|
+ :x1="getTransformPositionX(320)"
|
|
y1="330"
|
|
y1="330"
|
|
- x2="620"
|
|
|
|
|
|
+ :x2="getTransformPositionX(620)"
|
|
y2="50"
|
|
y2="50"
|
|
stroke="#edbf03"
|
|
stroke="#edbf03"
|
|
stroke-width="2"
|
|
stroke-width="2"
|
|
/>
|
|
/>
|
|
<circle
|
|
<circle
|
|
:class="{ 'stand-alone-circle': circle && hover == 3 }"
|
|
:class="{ 'stand-alone-circle': circle && hover == 3 }"
|
|
- cx="620"
|
|
|
|
|
|
+ :cx="getTransformPositionX(620)"
|
|
cy="50"
|
|
cy="50"
|
|
r="5"
|
|
r="5"
|
|
fill="#edbf03"
|
|
fill="#edbf03"
|
|
/>
|
|
/>
|
|
<text
|
|
<text
|
|
:class="{ 'stand-alone-text': text && hover == 3 }"
|
|
:class="{ 'stand-alone-text': text && hover == 3 }"
|
|
- x="630"
|
|
|
|
|
|
+ :x="getTransformPositionX(630)"
|
|
y="60"
|
|
y="60"
|
|
fill="#fcaf17"
|
|
fill="#fcaf17"
|
|
font-size="50"
|
|
font-size="50"
|
|
@@ -409,6 +411,7 @@
|
|
@click="click(6)"
|
|
@click="click(6)"
|
|
>
|
|
>
|
|
<use
|
|
<use
|
|
|
|
+ :style="`transform: translate(${getTransformPositionX()}px, 0)`"
|
|
class="stand-alone-img-item"
|
|
class="stand-alone-img-item"
|
|
xlink:href="#engine-room"
|
|
xlink:href="#engine-room"
|
|
x="1270"
|
|
x="1270"
|
|
@@ -417,28 +420,28 @@
|
|
<use
|
|
<use
|
|
class="stand-alone-img-item-circle"
|
|
class="stand-alone-img-item-circle"
|
|
xlink:href="#stand-alone-circle-jc"
|
|
xlink:href="#stand-alone-circle-jc"
|
|
- x="750"
|
|
|
|
|
|
+ :x="getTransformPositionX(750)"
|
|
y="380"
|
|
y="380"
|
|
/>
|
|
/>
|
|
<line
|
|
<line
|
|
:class="{ 'stand-alone-line': line && hover == 6 }"
|
|
:class="{ 'stand-alone-line': line && hover == 6 }"
|
|
- x1="750"
|
|
|
|
|
|
+ :x1="getTransformPositionX(750)"
|
|
y1="380"
|
|
y1="380"
|
|
- x2="1050"
|
|
|
|
|
|
+ :x2="getTransformPositionX(1050)"
|
|
y2="90"
|
|
y2="90"
|
|
stroke="#edbf03"
|
|
stroke="#edbf03"
|
|
stroke-width="2"
|
|
stroke-width="2"
|
|
/>
|
|
/>
|
|
<circle
|
|
<circle
|
|
:class="{ 'stand-alone-circle': circle && hover == 6 }"
|
|
:class="{ 'stand-alone-circle': circle && hover == 6 }"
|
|
- cx="1050"
|
|
|
|
|
|
+ :cx="getTransformPositionX(1050)"
|
|
cy="90"
|
|
cy="90"
|
|
r="5"
|
|
r="5"
|
|
fill="#edbf03"
|
|
fill="#edbf03"
|
|
/>
|
|
/>
|
|
<text
|
|
<text
|
|
:class="{ 'stand-alone-text': text && hover == 6 }"
|
|
:class="{ 'stand-alone-text': text && hover == 6 }"
|
|
- x="1060"
|
|
|
|
|
|
+ :x="getTransformPositionX(1060)"
|
|
y="100"
|
|
y="100"
|
|
fill="#fcaf17"
|
|
fill="#fcaf17"
|
|
font-size="50"
|
|
font-size="50"
|
|
@@ -459,33 +462,33 @@
|
|
xlink:href="#gear-box"
|
|
xlink:href="#gear-box"
|
|
x="730"
|
|
x="730"
|
|
y="335"
|
|
y="335"
|
|
- transform="translate(220, 280) scale(0.7)"
|
|
|
|
|
|
+ :transform="`translate(${getTransformPositionX(220)}, 280) scale(0.7)`"
|
|
/>
|
|
/>
|
|
<use
|
|
<use
|
|
class="stand-alone-img-item-circle"
|
|
class="stand-alone-img-item-circle"
|
|
xlink:href="#stand-alone-circle-clx"
|
|
xlink:href="#stand-alone-circle-clx"
|
|
- x="800"
|
|
|
|
|
|
+ :x="getTransformPositionX(800)"
|
|
y="550"
|
|
y="550"
|
|
/>
|
|
/>
|
|
<line
|
|
<line
|
|
:class="{ 'stand-alone-line': line && hover == 2 }"
|
|
:class="{ 'stand-alone-line': line && hover == 2 }"
|
|
- x1="800"
|
|
|
|
|
|
+ :x1="getTransformPositionX(800)"
|
|
y1="550"
|
|
y1="550"
|
|
- x2="1100"
|
|
|
|
|
|
+ :x2="getTransformPositionX(1100)"
|
|
y2="250"
|
|
y2="250"
|
|
stroke="#edbf03"
|
|
stroke="#edbf03"
|
|
stroke-width="2"
|
|
stroke-width="2"
|
|
/>
|
|
/>
|
|
<circle
|
|
<circle
|
|
:class="{ 'stand-alone-circle': circle && hover == 2 }"
|
|
:class="{ 'stand-alone-circle': circle && hover == 2 }"
|
|
- cx="1100"
|
|
|
|
|
|
+ :cx="getTransformPositionX(1100)"
|
|
cy="250"
|
|
cy="250"
|
|
r="5"
|
|
r="5"
|
|
fill="#edbf03"
|
|
fill="#edbf03"
|
|
/>
|
|
/>
|
|
<text
|
|
<text
|
|
:class="{ 'stand-alone-text': text && hover == 2 }"
|
|
:class="{ 'stand-alone-text': text && hover == 2 }"
|
|
- x="1110"
|
|
|
|
|
|
+ :x="getTransformPositionX(1110)"
|
|
y="250"
|
|
y="250"
|
|
fill="#fcaf17"
|
|
fill="#fcaf17"
|
|
font-size="50"
|
|
font-size="50"
|
|
@@ -506,33 +509,33 @@
|
|
xlink:href="#alternator"
|
|
xlink:href="#alternator"
|
|
x="900"
|
|
x="900"
|
|
y="385"
|
|
y="385"
|
|
- transform="translate(300, 260) scale(0.7)"
|
|
|
|
|
|
+ :transform="`translate(${getTransformPositionX(300)}, 260) scale(0.7)`"
|
|
/>
|
|
/>
|
|
<use
|
|
<use
|
|
class="stand-alone-img-item-circle"
|
|
class="stand-alone-img-item-circle"
|
|
xlink:href="#stand-alone-circle-fdj"
|
|
xlink:href="#stand-alone-circle-fdj"
|
|
- x="990"
|
|
|
|
|
|
+ :x="getTransformPositionX(990)"
|
|
y="580"
|
|
y="580"
|
|
/>
|
|
/>
|
|
<line
|
|
<line
|
|
:class="{ 'stand-alone-line': line && hover == 1 }"
|
|
:class="{ 'stand-alone-line': line && hover == 1 }"
|
|
- x1="990"
|
|
|
|
|
|
+ :x1="getTransformPositionX(990)"
|
|
y1="580"
|
|
y1="580"
|
|
- x2="1290"
|
|
|
|
|
|
+ :x2="getTransformPositionX(1290)"
|
|
y2="880"
|
|
y2="880"
|
|
stroke="#edbf03"
|
|
stroke="#edbf03"
|
|
stroke-width="2"
|
|
stroke-width="2"
|
|
/>
|
|
/>
|
|
<circle
|
|
<circle
|
|
:class="{ 'stand-alone-circle': circle && hover == 1 }"
|
|
:class="{ 'stand-alone-circle': circle && hover == 1 }"
|
|
- cx="1290"
|
|
|
|
|
|
+ :cx="getTransformPositionX(1290)"
|
|
cy="880"
|
|
cy="880"
|
|
r="5"
|
|
r="5"
|
|
fill="#edbf03"
|
|
fill="#edbf03"
|
|
/>
|
|
/>
|
|
<text
|
|
<text
|
|
:class="{ 'stand-alone-text': text && hover == 1 }"
|
|
:class="{ 'stand-alone-text': text && hover == 1 }"
|
|
- x="1300"
|
|
|
|
|
|
+ :x="getTransformPositionX(1300)"
|
|
y="920"
|
|
y="920"
|
|
fill="#fcaf17"
|
|
fill="#fcaf17"
|
|
font-size="50"
|
|
font-size="50"
|
|
@@ -548,32 +551,37 @@
|
|
@mouseout="mouseout"
|
|
@mouseout="mouseout"
|
|
@click="click(4)"
|
|
@click="click(4)"
|
|
>
|
|
>
|
|
- <use class="stand-alone-img-item" xlink:href="#yaw" x="675" y="645" />
|
|
|
|
|
|
+ <use
|
|
|
|
+ class="stand-alone-img-item"
|
|
|
|
+ xlink:href="#yaw"
|
|
|
|
+ :x="getTransformPositionX(675)"
|
|
|
|
+ y="645"
|
|
|
|
+ />
|
|
<use
|
|
<use
|
|
class="stand-alone-img-item-circle"
|
|
class="stand-alone-img-item-circle"
|
|
xlink:href="#stand-alone-circle-ph"
|
|
xlink:href="#stand-alone-circle-ph"
|
|
- x="650"
|
|
|
|
|
|
+ :x="getTransformPositionX(650)"
|
|
y="750"
|
|
y="750"
|
|
/>
|
|
/>
|
|
<line
|
|
<line
|
|
:class="{ 'stand-alone-line': line && hover == 4 }"
|
|
:class="{ 'stand-alone-line': line && hover == 4 }"
|
|
- x1="650"
|
|
|
|
|
|
+ :x1="getTransformPositionX(650)"
|
|
y1="750"
|
|
y1="750"
|
|
- x2="950"
|
|
|
|
|
|
+ :x2="getTransformPositionX(950)"
|
|
y2="1050"
|
|
y2="1050"
|
|
stroke="#edbf03"
|
|
stroke="#edbf03"
|
|
stroke-width="2"
|
|
stroke-width="2"
|
|
/>
|
|
/>
|
|
<circle
|
|
<circle
|
|
:class="{ 'stand-alone-circle': circle && hover == 4 }"
|
|
:class="{ 'stand-alone-circle': circle && hover == 4 }"
|
|
- cx="950"
|
|
|
|
|
|
+ :cx="getTransformPositionX(950)"
|
|
cy="1050"
|
|
cy="1050"
|
|
r="5"
|
|
r="5"
|
|
fill="#edbf03"
|
|
fill="#edbf03"
|
|
/>
|
|
/>
|
|
<text
|
|
<text
|
|
:class="{ 'stand-alone-text': text && hover == 4 }"
|
|
:class="{ 'stand-alone-text': text && hover == 4 }"
|
|
- x="960"
|
|
|
|
|
|
+ :x="getTransformPositionX(960)"
|
|
y="1050"
|
|
y="1050"
|
|
fill="#fcaf17"
|
|
fill="#fcaf17"
|
|
font-size="50"
|
|
font-size="50"
|
|
@@ -594,33 +602,33 @@
|
|
xlink:href="#hydraulic-pressure"
|
|
xlink:href="#hydraulic-pressure"
|
|
x="775"
|
|
x="775"
|
|
y="455"
|
|
y="455"
|
|
- transform="translate(260, 310) scale(0.7)"
|
|
|
|
|
|
+ :transform="`translate(${getTransformPositionX(260)}, 310) scale(0.7)`"
|
|
/>
|
|
/>
|
|
<use
|
|
<use
|
|
class="stand-alone-img-item-circle"
|
|
class="stand-alone-img-item-circle"
|
|
xlink:href="#stand-alone-circle-yy"
|
|
xlink:href="#stand-alone-circle-yy"
|
|
- x="850"
|
|
|
|
|
|
+ :x="getTransformPositionX(850)"
|
|
y="730"
|
|
y="730"
|
|
/>
|
|
/>
|
|
<line
|
|
<line
|
|
:class="{ 'stand-alone-line': line && hover == 5 }"
|
|
:class="{ 'stand-alone-line': line && hover == 5 }"
|
|
- x1="850"
|
|
|
|
|
|
+ :x1="getTransformPositionX(850)"
|
|
y1="730"
|
|
y1="730"
|
|
- x2="1150"
|
|
|
|
|
|
+ :x2="getTransformPositionX(1150)"
|
|
y2="1030"
|
|
y2="1030"
|
|
stroke="#edbf03"
|
|
stroke="#edbf03"
|
|
stroke-width="2"
|
|
stroke-width="2"
|
|
/>
|
|
/>
|
|
<circle
|
|
<circle
|
|
:class="{ 'stand-alone-circle': circle && hover == 5 }"
|
|
:class="{ 'stand-alone-circle': circle && hover == 5 }"
|
|
- cx="1150"
|
|
|
|
|
|
+ :cx="getTransformPositionX(1150)"
|
|
cy="1030"
|
|
cy="1030"
|
|
r="5"
|
|
r="5"
|
|
fill="#edbf03"
|
|
fill="#edbf03"
|
|
/>
|
|
/>
|
|
<text
|
|
<text
|
|
:class="{ 'stand-alone-text': text && hover == 5 }"
|
|
:class="{ 'stand-alone-text': text && hover == 5 }"
|
|
- x="1160"
|
|
|
|
|
|
+ :x="getTransformPositionX(1160)"
|
|
y="1030"
|
|
y="1030"
|
|
fill="#fcaf17"
|
|
fill="#fcaf17"
|
|
font-size="50"
|
|
font-size="50"
|
|
@@ -650,6 +658,8 @@ export default {
|
|
hover: 0,
|
|
hover: 0,
|
|
svgWidth: 0,
|
|
svgWidth: 0,
|
|
svgHeight: 400,
|
|
svgHeight: 400,
|
|
|
|
+ // SVG 整体横向位移值,正数向左位移,负数向右位移,连同内部高亮区域与其他元素会一并位移
|
|
|
|
+ transformPositionX: 480,
|
|
};
|
|
};
|
|
},
|
|
},
|
|
props: {
|
|
props: {
|
|
@@ -695,6 +705,10 @@ export default {
|
|
click: function (index) {
|
|
click: function (index) {
|
|
this.$emit("selectSvg", index);
|
|
this.$emit("selectSvg", index);
|
|
},
|
|
},
|
|
|
|
+
|
|
|
|
+ getTransformPositionX(posValue = 0) {
|
|
|
|
+ return posValue - this.transformPositionX;
|
|
|
|
+ },
|
|
},
|
|
},
|
|
// 生命周期钩子
|
|
// 生命周期钩子
|
|
beforeCreate() {
|
|
beforeCreate() {
|