Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
S
SuperMan
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
1
Issues
1
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
罗超
SuperMan
Commits
f198d7ea
Commit
f198d7ea
authored
Aug 31, 2023
by
沈良进
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
页面修改
parent
3666a475
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
162 additions
and
139 deletions
+162
-139
travelDays.vue
src/components/LeaveGroupDownload/travelDays.vue
+162
-139
No files found.
src/components/LeaveGroupDownload/travelDays.vue
View file @
f198d7ea
...
...
@@ -9,116 +9,135 @@
</div>
</div>
</div>
-->
<div
class=
"UpgradedVersion-box UpgradedVersion-homebj relative"
v-for=
"(item,index) in tripList"
>
<div
class=
"absolute z-index1 column"
style=
"left: 0;right: 0; top: 0;bottom: 0;"
>
<Header
:TripColor=
"dataAll.tripColor"
:orderMsg=
"orderMsg"
></Header>
<div
class=
"travelDaysTitlle row-aic"
>
<div
class=
"travelDaysTitlle-left"
>
<div
class=
"travelDaysTitlle-left-text column-ajc"
>
<div
class=
"travelDaysTitlle-left-textOne"
>
<span>
{{
item
.
dayNum
>
9
?
item
.
dayNum
:
'0'
+
item
.
dayNum
}}
</span>
</div>
<div
class=
"travelDaysTitlle-left-textTwo"
>
<span>
{{
day
}}
</span>
<div
class=
"UpgradedVersion-box UpgradedVersion-homebj relative"
v-for=
"(item,index) in tripList"
>
<div
class=
"absolute z-index1 column"
style=
"left: 0;right: 0; top: 0;bottom: 0;"
>
<Header
:TripColor=
"dataAll.tripColor"
:orderMsg=
"orderMsg"
></Header>
<div
class=
"travelDaysTitlle row-aic"
>
<div
class=
"travelDaysTitlle-left"
>
<div
class=
"travelDaysTitlle-left-text column-ajc"
>
<div
class=
"travelDaysTitlle-left-textOne"
>
<span>
{{
item
.
dayNum
>
9
?
item
.
dayNum
:
'0'
+
item
.
dayNum
}}
</span>
</div>
<div
class=
"travelDaysTitlle-left-textTwo"
>
<span>
{{
day
}}
</span>
</div>
</div>
</div>
</div
>
<div
class=
"travelDaysTitlle-right"
>
<div
class=
"travelDaysTitlle-right-text row-aic"
:style=
"
{'background': dataAll.tripColor,'font-size': getFontSize(item.title),'color':textColor}">
{{
item
.
title
}}
<div
class=
"travelDaysTitlle-right"
>
<div
class=
"travelDaysTitlle-right-text row-aic"
:style=
"
{'background': dataAll.tripColor,'font-size': getFontSize(item.title),'color':textColor}">
{{
item
.
title
}}
</div>
</div>
</div>
</div>
<div
:id=
"'travelDaysMasterMap_'+index"
class=
"travelDaysMasterMap relative"
>
<div
:id=
"'travelDaysMasterMap_'+index"
class=
"travelDaysMasterMap relative"
>
<div
class=
"travelDaysMasterMap-one"
:style=
"
{'color':'#fff'}">
<div
class=
"travelDaysMasterMap-oneImg relative bjF6"
:id=
"'travelDaysImg_one'+index"
>
<img
class=
"absolute"
:src=
"item.details[0].img?item.details[0].img:'https://imgfile.oytour.com/Static/NewTripFeature/acquiesce.jpg'"
>
<img
class=
"absolute"
:src=
"item.details[0].img?item.details[0].img:'https://imgfile.oytour.com/Upload/DefalutImage/DMC/defaultairline.png'"
>
</div>
<div
class=
"travelDaysMasterMap-text absolute z-index2"
>
{{
item
.
details
[
0
].
title
}}
</div>
</div>
<div
class=
"travelDaysMasterMap-two absolute z-index2"
>
<template
v-if=
"item.imgMapId=='travelDaysMasterMap_'+index&&item.showImgOne"
>
<div
class=
"travelDaysMasterMap-twoImg relative bjF6"
:style=
"
{'color':'#fff'}"
:id="'travelDaysImg_two'+index"
v-if="(item.details
&&
item.details.length>1
&&
item.details[1].img)||(item.jiu2
&&
item.jiu2.length>0
&&
item.jiu2[0].url)">
<template
v-if=
"item.details.length>1&&item.details[1].img"
>
<img
class=
""
:src=
"item.details[1].img?item.details[1].img:'https://imgfile.oytour.com/Static/NewTripFeature/acquiesce.jpg'"
>
<div
class=
"travelDaysMasterMap-text textTwo absolute z-index2"
>
【
{{
item
.
details
[
1
].
title
}}
】
</div>
</
template
>
<
template
v-else
>
<template
v-for=
"(jiudian,j) in item.jiu2"
>
<template
v-if=
"jiudian.url&&j==0"
>
<img
class=
""
v-if=
"jiudian.url"
:src=
"jiudian.url?jiudian.url:'https://imgfile.oytour.com/Static/NewTripFeature/acquiesce.jpg'"
>
<div
class=
"travelDaysMasterMap-text textTwo absolute z-index2"
>
【
{{
jiudian
.
newTitle
}}
】
</div>
<div
class=
"travelDaysMasterMap-twoImg relative bjF6"
:style=
"
{'color':'#fff'}"
:id="'travelDaysImg_two'+index"
v-if="(item.details
&&
item.details.length>1
&&
item.details[1].img)||(item.jiu2
&&
item.jiu2.length>0
&&
item.jiu2[0].url)">
<template
v-if=
"item.details.length>1&&item.details[1].img"
>
<img
class=
""
:src=
"item.details[1].img?item.details[1].img:'https://imgfile.oytour.com/Static/NewTripFeature/acquiesce.jpg'"
>
<div
class=
"travelDaysMasterMap-text textTwo absolute z-index2"
>
【
{{
item
.
details
[
1
].
title
}}
】
</div>
</
template
>
<
template
v-else
>
<template
v-for=
"(jiudian,j) in item.jiu2"
>
<template
v-if=
"jiudian.url&&j==0"
>
<img
class=
""
v-if=
"jiudian.url"
:src=
"jiudian.url?jiudian.url:'https://imgfile.oytour.com/Static/NewTripFeature/acquiesce.jpg'"
>
<div
class=
"travelDaysMasterMap-text textTwo absolute z-index2"
>
【
{{
jiudian
.
newTitle
}}
】
</div>
</
template
>
</template>
</template>
</template>
</div>
</div>
</template>
<
template
v-if=
"item.imgMapId=='travelDaysMasterMap_'+index&&item.showImgTwo"
>
<div
class=
"travelDaysMasterMap-twoImg relative bjF6"
style=
"margin-top: 47px;"
:style=
"
{'color':'#fff'}"
:id="'travelDaysImg_three'+index"
v-if="(item.details
&&
item.details.length>2
&&
item.details[2].img)||(item.jiu2
&&
item.jiu2.length>1
&&
item.jiu2[0].url)">
<template
v-if=
"item.details.length>2&&item.details[2].img"
>
<img
class=
""
:src=
"item.details[2].img?item.details[2].img:'https://imgfile.oytour.com/Static/NewTripFeature/acquiesce.jpg'"
>
<div
class=
"travelDaysMasterMap-text textTwo absolute z-index2"
>
【
{{
item
.
details
[
2
].
title
}}
】
</div>
</
template
>
<
template
v-else
>
<template
v-for=
"(jiudian,j) in item.jiu2"
>
<template
v-if=
"jiudian.url&&j==1"
>
<img
class=
""
v-if=
"jiudian.url"
:src=
"jiudian.url?item.details[2].img:'https://imgfile.oytour.com/Static/NewTripFeature/acquiesce.jpg'"
>
<div
class=
"travelDaysMasterMap-twoImg relative bjF6"
style=
"margin-top: 47px;"
:style=
"
{'color':'#fff'}"
:id="'travelDaysImg_three'+index"
v-if="(item.details
&&
item.details.length>2
&&
item.details[2].img)||(item.jiu2
&&
item.jiu2.length>1
&&
item.jiu2[0].url)">
<template
v-if=
"item.details.length>2&&item.details[2].img"
>
<img
class=
""
:src=
"item.details[2].img?item.details[2].img:'https://imgfile.oytour.com/Static/NewTripFeature/acquiesce.jpg'"
>
<div
class=
"travelDaysMasterMap-text textTwo absolute z-index2"
>
【
{{
jiudian
.
nam
e
}}
】
</div>
【
{{
item
.
details
[
2
].
titl
e
}}
】
</div>
</
template
>
</template>
</template>
</div>
<
template
v-else
>
<template
v-for=
"(jiudian,j) in item.jiu2"
>
<template
v-if=
"jiudian.url&&j==1"
>
<img
class=
""
v-if=
"jiudian.url"
:src=
"jiudian.url?item.details[2].img:'https://imgfile.oytour.com/Static/NewTripFeature/acquiesce.jpg'"
>
<div
class=
"travelDaysMasterMap-text textTwo absolute z-index2"
>
【
{{
jiudian
.
name
}}
】
</div>
</
template
>
</template>
</template>
</div>
</template>
</div>
</div>
<div
class=
"travelDaysContent column"
>
<div
class=
"travelDaysContent-text"
v-for=
"(jindian,j) in item.details"
>
<span>
【{{jindian.title}}】
</span>
{{jindian.content}}
</div>
</div>
<div
class=
"travelDaysdetails absolute"
>
<div
class=
"travelDaysdetailsBJ row"
:style=
"{'background':backgroundColor}"
>
<div
class=
"travelDaysdetails-text row"
>
<span>
早餐:
</span>
<div><p>
{{item.can.breakfirst}}
</p></div>
</div>
<div
class=
"travelDaysdetails-text row"
>
<span>
午餐:
</span>
<div><p>
{{item.can.lanuch}}
</p></div>
<
template
v-if=
"item.details&&item.details.length>0"
>
<div
class=
"travelDaysContent column"
>
<div
class=
"travelDaysContent-text"
v-for=
"(jindian,j) in item.details"
>
<span>
【
{{
jindian
.
title
}}
】
</span>
{{
jindian
.
content
}}
</div>
</div>
<div
class=
"travelDaysdetails-text row"
>
<span>
晚餐:
</span>
<div><p>
{{item.can.dinner}}
</p></div>
</
template
>
<
template
v-else
>
<div
class=
"travelDaysContent column"
>
<div
class=
"travelDaysContent-text"
>
<span>
【
{{
jindian
.
title
}}
】
</span>
{{
jindian
.
content
}}
</div>
</div>
<div
class=
"travelDaysdetails-text row"
>
<span>
住宿:
</span>
<div>
<p
v-for=
"(j,i) in item.jiu2"
>
{{j.name}}
</p>
</
template
>
<div
class=
"travelDaysdetails absolute"
>
<div
class=
"travelDaysdetailsBJ row"
:style=
"{'background':backgroundColor}"
>
<div
class=
"travelDaysdetails-text row"
>
<span>
早餐:
</span>
<div>
<p>
{{item.can.breakfirst}}
</p>
</div>
</div>
<div
class=
"travelDaysdetails-text row"
>
<span>
午餐:
</span>
<div>
<p>
{{item.can.lanuch}}
</p>
</div>
</div>
<div
class=
"travelDaysdetails-text row"
>
<span>
晚餐:
</span>
<div>
<p>
{{item.can.dinner}}
</p>
</div>
</div>
<div
class=
"travelDaysdetails-text row"
>
<span>
住宿:
</span>
<div>
<p
v-for=
"(j,i) in item.jiu2"
>
{{j.name}}
</p>
</div>
</div>
</div>
</div>
</div>
<!-- otherJourney-footer -->
<div>
<div
class=
"otherJourney-introduceFooter absolute z-index1 row-aic"
:style=
"{'background':''}"
>
<!-- otherJourney-footer -->
<div>
<div
class=
"otherJourney-introduceFooter absolute z-index1 row-aic"
:style=
"{'background':''}"
>
<div
class=
"introduceFooterBJ introduceFooterOne"
:style=
"{'background':dataAll.tripColor}"
>
</div>
<div
class=
"introduceFooterBJ introduceFootertTwo"
:style=
"{'background':dataAll.tripColor}"
>
</div>
<div
class=
"introduceFooter-text row-aic"
>
...
...
@@ -127,9 +146,9 @@
</div>
<div
class=
"introduceFooterBJ introduceFootertThree"
:style=
"{'background':dataAll.tripColor}"
>
</div>
<div
class=
"introduceFooterBJ introduceFootertFour"
:style=
"{'background':dataAll.tripColor}"
>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
...
...
@@ -142,7 +161,7 @@
components
:
{
Header
},
props
:
[
'dataAll'
,
'tripList'
,
'orderMsg'
,
'orderTripdiff'
,
'vshowD'
,
'vshowK'
],
props
:
[
'dataAll'
,
'tripList'
,
'orderMsg'
,
'orderTripdiff'
,
'vshowD'
,
'vshowK'
],
data
()
{
return
{
title
:
'北京-马德里-塞戈维亚-萨拉曼卡-贝尼多姆/小镇-瓦伦西亚-巴塞罗那(约 253km,约 3h)北京-马德里-塞戈维亚-萨拉曼卡-贝尼多姆/小镇-瓦伦西亚-巴塞罗那(约 253km,约 3h)'
,
...
...
@@ -154,39 +173,39 @@
},
methods
:
{
getShow
(
Id
,
HeightNum
,
item
)
{
getShow
(
Id
,
HeightNum
,
item
)
{
item
.
imgMapId
=
Id
if
(
HeightNum
>=
243
)
{
if
(
HeightNum
>=
243
)
{
item
.
showImgOne
=
true
}
else
{
}
else
{
item
.
showImgOne
=
false
}
if
(
HeightNum
>=
478
)
{
if
(
HeightNum
>=
478
)
{
item
.
showImgTwo
=
true
}
else
{
}
else
{
item
.
showImgTwo
=
false
}
this
.
$forceUpdate
()
},
getHeigthNum
(
Id
,
item
)
{
getHeigthNum
(
Id
,
item
)
{
let
that
=
this
setTimeout
(()
=>
{
setTimeout
(()
=>
{
var
Height
=
document
.
getElementById
(
Id
);
if
(
Height
)
{
if
(
Height
)
{
let
HeightNum
=
Height
.
offsetHeight
that
.
getShow
(
Id
,
HeightNum
,
item
)
that
.
getShow
(
Id
,
HeightNum
,
item
)
}
},
300
)
},
300
)
},
getFontSize
(
title
){
if
(
title
.
length
>
60
)
{
return
929
/
60
+
'px'
}
else
{
getFontSize
(
title
)
{
if
(
title
.
length
>
60
)
{
return
929
/
60
+
'px'
}
else
{
return
'30px'
}
},
getImgColor
(
img
,
id
)
{
getImgColor
(
img
,
id
)
{
return
"#fff"
return
// this.canvasImgColor(img,id, (callback) => {
...
...
@@ -202,14 +221,14 @@
// })
},
// 获取图片颜色
canvasImgColor
(
imgs
,
ids
,
callback
)
{
var
imgSrc
=
imgs
var
upload
=
document
.
getElementById
(
ids
)
const
imgEle
=
document
.
createElement
(
'img'
)
const
canvas
=
document
.
createElement
(
'canvas'
)
imgEle
.
src
=
imgSrc
imgEle
.
crossOrigin
=
''
;
imgEle
.
onload
=
()
=>
{
canvasImgColor
(
imgs
,
ids
,
callback
)
{
var
imgSrc
=
imgs
var
upload
=
document
.
getElementById
(
ids
)
const
imgEle
=
document
.
createElement
(
'img'
)
const
canvas
=
document
.
createElement
(
'canvas'
)
imgEle
.
src
=
imgSrc
imgEle
.
crossOrigin
=
''
;
imgEle
.
onload
=
()
=>
{
var
ctx
=
canvas
.
getContext
(
"2d"
);
var
naturalImgSize
=
[
imgEle
.
naturalWidth
,
imgEle
.
naturalHeight
];
canvas
.
width
=
naturalImgSize
[
0
];
...
...
@@ -224,58 +243,62 @@
const
oneLineImgDataLen
=
canvas
.
width
*
4
;
imgData
.
data
.
forEach
((
colorVal
,
i
)
=>
{
if
(
i
%
oneLineImgDataLen
<=
0.5
*
oneLineImgDataLen
||
i
%
oneLineImgDataLen
>=
0.6
*
oneLineImgDataLen
)
{
const
inLeft
=
i
%
oneLineImgDataLen
<=
0.5
*
oneLineImgDataLen
if
(
i
%
4
===
0
)
{
// 获取rgb均值
const
curAverageRGB
=
(
imgData
.
data
[
i
]
+
imgData
.
data
[
i
+
1
]
+
imgData
.
data
[
i
+
2
])
/
3
;
let
leftOrRightRef
=
inLeft
?
leftSectionData
:
rightSectionData
;
//每个数组里存四个值:本颜色值中的r、g、b的均值,以及r、g、b三个值。
//均值一方面用于累加计算本区域的整体均值,然后再跟每个均值对比拿到与整体均值最接近的项的索引,再取该数组里的后三个值:rgb,对应着颜色
leftOrRightRef
[
leftOrRightRef
.
length
]
=
[
curAverageRGB
,
imgData
.
data
[
i
],
imgData
.
data
[
i
+
1
],
imgData
.
data
[
i
+
2
]]
}
if
(
i
%
oneLineImgDataLen
<=
0.5
*
oneLineImgDataLen
||
i
%
oneLineImgDataLen
>=
0.6
*
oneLineImgDataLen
)
{
const
inLeft
=
i
%
oneLineImgDataLen
<=
0.5
*
oneLineImgDataLen
if
(
i
%
4
===
0
)
{
// 获取rgb均值
const
curAverageRGB
=
(
imgData
.
data
[
i
]
+
imgData
.
data
[
i
+
1
]
+
imgData
.
data
[
i
+
2
])
/
3
;
let
leftOrRightRef
=
inLeft
?
leftSectionData
:
rightSectionData
;
//每个数组里存四个值:本颜色值中的r、g、b的均值,以及r、g、b三个值。
//均值一方面用于累加计算本区域的整体均值,然后再跟每个均值对比拿到与整体均值最接近的项的索引,再取该数组里的后三个值:rgb,对应着颜色
leftOrRightRef
[
leftOrRightRef
.
length
]
=
[
curAverageRGB
,
imgData
.
data
[
i
],
imgData
.
data
[
i
+
1
],
imgData
.
data
[
i
+
2
]
]
}
}
})
//generate average rgb
const
averageOfLeft
=
Math
.
round
(
leftSectionData
.
reduce
((
_cur
,
item
)
=>
{
return
_cur
+
item
[
0
]
return
_cur
+
item
[
0
]
},
0
)
/
leftSectionData
.
length
)
const
averageOfRight
=
Math
.
round
(
rightSectionData
.
reduce
((
_cur
,
item
)
=>
{
return
_cur
+
item
[
0
]
return
_cur
+
item
[
0
]
},
0
)
/
rightSectionData
.
length
)
//find the most near color
const
findNearestIndex
=
(
averageVal
,
arrBox
)
=>
{
let
_gapValue
=
Math
.
abs
(
averageVal
-
arrBox
[
0
])
let
_nearColorIndex
=
0
arrBox
.
forEach
((
item
,
index
)
=>
{
const
curGapValue
=
Math
.
abs
(
item
-
averageVal
)
if
(
curGapValue
<
_gapValue
)
{
_gapValue
=
curGapValue
_nearColorIndex
=
index
}
})
return
_nearColorIndex
let
_gapValue
=
Math
.
abs
(
averageVal
-
arrBox
[
0
])
let
_nearColorIndex
=
0
arrBox
.
forEach
((
item
,
index
)
=>
{
const
curGapValue
=
Math
.
abs
(
item
-
averageVal
)
if
(
curGapValue
<
_gapValue
)
{
_gapValue
=
curGapValue
_nearColorIndex
=
index
}
})
return
_nearColorIndex
}
const
leftNearestColor
=
leftSectionData
[
findNearestIndex
(
averageOfLeft
,
leftSectionData
)]
const
rightNearestColor
=
rightSectionData
[
findNearestIndex
(
averageOfRight
,
rightSectionData
)]
upload
.
style
.
backgroundColor
=
`rgba(
${
leftNearestColor
[
1
]}
,
${
leftNearestColor
[
2
]}
,
${
leftNearestColor
[
3
]}
,1) 0%,rgba(
${
rightNearestColor
[
1
]}
,
${
rightNearestColor
[
2
]}
,
${
rightNearestColor
[
3
]}
,1)`
upload
.
style
.
backgroundColor
=
`rgba(
${
leftNearestColor
[
1
]}
,
${
leftNearestColor
[
2
]}
,
${
leftNearestColor
[
3
]}
,1) 0%,rgba(
${
rightNearestColor
[
1
]}
,
${
rightNearestColor
[
2
]}
,
${
rightNearestColor
[
3
]}
,1)`
callback
(
upload
.
style
.
backgroundColor
)
}
}
}
},
computed
:
{},
watch
:
{
dataAll
:
{
handler
(
val
,
oldVal
)
{
if
(
val
&&
val
.
tripColor
)
{
if
(
val
&&
val
.
tripColor
)
{
this
.
backgroundColor
=
this
.
hexToRgb
(
val
.
tripColor
,
0.2
)
let
rgba
=
this
.
hexToRgb
(
val
.
tripColor
,
1
)
rgba
=
rgba
.
split
(
','
)
let
rgba0
=
rgba
[
0
].
split
(
'('
)
let
arr
=
[
rgba0
[
1
],
rgba
[
1
],
rgba
[
2
]]
if
(
this
.
getRgbLevel
(
arr
)
>
50
)
{
let
arr
=
[
rgba0
[
1
],
rgba
[
1
],
rgba
[
2
]]
if
(
this
.
getRgbLevel
(
arr
)
>
50
)
{
this
.
textColor
=
"#fff"
}
else
{
}
else
{
this
.
textColor
=
"#333"
}
}
...
...
@@ -285,8 +308,8 @@
},
tripList
:
{
handler
(
val
,
oldVal
)
{
this
.
tripList
.
forEach
((
x
,
index
)
=>
{
this
.
getHeigthNum
(
'travelDaysMasterMap_'
+
index
,
x
)
this
.
tripList
.
forEach
((
x
,
index
)
=>
{
this
.
getHeigthNum
(
'travelDaysMasterMap_'
+
index
,
x
)
})
},
deep
:
true
,
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment