feat: 启动页面支持视频背景

This commit is contained in:
小莫唐尼 2024-07-10 11:20:25 +08:00
parent 0e342d5fa3
commit ad6719e201

View File

@ -1,443 +1,478 @@
<template> <template>
<view class="app-page bg-gradient-blue-lighten-b" :style="pageStyle"> <view class="app-page bg-gradient-blue-lighten-b" :style="pageStyle">
<view class="tn-satr"> <view v-if="!calcUseVideoBackground" class="tn-satr">
<view class="sky"></view> <view class="sky"></view>
<view class="stars"> <view class="stars">
<view class="falling-stars"> <view class="falling-stars">
<view class="star-fall"></view> <view class="star-fall"></view>
<view class="star-fall"></view> <view class="star-fall"></view>
<view class="star-fall"></view> <view class="star-fall"></view>
<view class="star-fall"></view> <view class="star-fall"></view>
</view> </view>
<view class="small-stars"> <view class="small-stars">
<view class="star"></view> <view class="star"></view>
<view class="star"></view> <view class="star"></view>
<view class="star"></view> <view class="star"></view>
<view class="star"></view> <view class="star"></view>
<view class="star"></view> <view class="star"></view>
<view class="star"></view> <view class="star"></view>
<view class="star"></view> <view class="star"></view>
<view class="star"></view> <view class="star"></view>
<view class="star"></view> <view class="star"></view>
<view class="star"></view> <view class="star"></view>
<view class="star"></view> <view class="star"></view>
<view class="star"></view> <view class="star"></view>
</view> </view>
<view class="medium-stars"> <view class="medium-stars">
<view class="star"></view> <view class="star"></view>
<view class="star"></view> <view class="star"></view>
<view class="star"></view> <view class="star"></view>
<view class="star"></view> <view class="star"></view>
<view class="star"></view> <view class="star"></view>
<view class="star"></view> <view class="star"></view>
<view class="star"></view> <view class="star"></view>
<view class="star"></view> <view class="star"></view>
<view class="star"></view> <view class="star"></view>
<view class="star"></view> <view class="star"></view>
<view class="star"></view> <view class="star"></view>
<view class="star"></view> <view class="star"></view>
</view> </view>
</view> </view>
</view> </view>
<view class="user-info__container flex flex-col flex-center"> <video v-else class="video-bg" :src="bg" :loop="true" :autoplay="true" :muted="true" :controls="false"
<image class="user-info__avatar" :src="$utils.checkImageUrl(startConfig.logo)" mode="aspectFill"></image> :show-fullscreen-btn="false" :show-play-btn="false" :show-center-play-btn="false" :show-loading="false"
<view class="user-info__nick-name"> {{ startConfig.title }} </view> :enable-progress-gesture="false" :show-progress="false"></video>
</view>
<view class="text-align-center text-white" style="padding: 60vh 0 0 0;"> <view v-if="startConfig.title || startConfig.logo" class="user-info__container flex flex-col flex-center">
<view class="" style="font-size: 44rpx;" v-if="startConfig.desc1">{{ startConfig.desc1 }}</view> <image v-if="startConfig.logo" class="user-info__avatar" :src="$utils.checkImageUrl(startConfig.logo)"
<view class="mt-30 text-size-m" v-if="startConfig.desc2">{{ startConfig.desc2 }}</view> mode="aspectFill"></image>
</view> <view v-if="startConfig.title " class="user-info__nick-name" :style="startConfig.titleStyle"> {{ startConfig.title }} </view>
</view>
<view class="" style="padding: 120rpx 200rpx;z-index: 999;position: relative;"> <cover-view class="btn-group">
<view class="start-btn" @click="fnStart()">{{ startConfig.btnText || '开始体验' }}</view> <view v-if="startConfig.desc1 || startConfig.desc2" class="text-align-center" :style="startConfig.descStyle" style="color:white;padding: 60vh 0 0 0;">
</view> <view class="" style="font-size: 44rpx;" v-if="startConfig.desc1">{{ startConfig.desc1 }}</view>
<view class="mt-30 text-size-m" v-if="startConfig.desc2">{{ startConfig.desc2 }}</view>
</view>
<!-- 波浪效果 --> <view class="" style="padding: 120rpx 200rpx;z-index: 999;position: relative;">
<wave></wave> <view class="start-btn" :class="[startConfig.btnClass]" @click="fnStart()"
</view> :style="startConfig.btnStyle">{{ startConfig.btnText || '开始体验' }}</view>
</view>
</cover-view>
<!-- 波浪效果 -->
<wave v-if="startConfig.useWave"></wave>
</view>
</template> </template>
<script> <script>
import wave from '@/components/wave/wave.vue'; import wave from '@/components/wave/wave.vue';
export default { export default {
components: { components: {
wave wave
}, },
computed: { data() {
startConfig() { return {
return this.$tm.vx.getters().getConfigs.appConfig.startConfig; bg: "https://thalo.925i.cn/upload/92739970-24856955-start.mp4"
}, }
pageStyle() { },
if (this.startConfig.bg) { computed: {
const _bg = this.$utils.checkIsUrl(this.startConfig.bg) ? `url(${this.$utils.checkImageUrl(this.startConfig.bg)})` : this startConfig() {
.startConfig.bg; return this.$tm.vx.getters().getConfigs.appConfig.startConfig;
return { },
background: _bg + '!important' calcUseVideoBackground() {
}; return this.startConfig.useVideoBackground;
} },
return {}; pageStyle() {
} if (this.calcUseVideoBackground) {
}, return {
methods: { background: '#ffffff'
fnStart() { }
uni.switchTab({ }
url: '/pages/tabbar/home/home', if (this.startConfig.bg) {
success: () => { const _bg = this.$utils.checkIsUrl(this.startConfig.bg) ?
uni.setStorageSync('APP_HAS_STARTED', true); `url(${this.$utils.checkImageUrl(this.startConfig.bg)})` : this
} .startConfig.bg;
}); return {
} background: _bg + '!important'
} };
}; }
return {};
}
},
methods: {
fnStart() {
uni.switchTab({
url: '/pages/tabbar/home/home',
success: () => {
uni.setStorageSync('APP_HAS_STARTED', true);
}
});
}
}
};
</script> </script>
<style lang="scss" scoped> <style lang="scss" scoped>
.app-page { .app-page {
width: 100vw; width: 100vw;
height: 100vh; height: 100vh;
} }
.start-btn { .start-btn {
box-sizing: border-box; box-sizing: border-box;
background-color: transparent; background-color: transparent;
padding: 16rpx 50rpx; padding: 16rpx 50rpx;
border-radius: 50rpx; border-radius: 50rpx;
border: 2rpx solid #ffffff; border: 2rpx solid #ffffff;
color: #ffffff; color: #ffffff;
text-align: center; text-align: center;
font-size: 28rpx; font-size: 28rpx;
} }
/* 用户信息 start */ .btn-group {
.user-info { position: fixed;
&__container { bottom: 50rpx;
position: absolute; left: 50%;
top: 25vh; transform: translateX(-50%);
left: 50%; z-index: 10;
-webkit-transform: translate(-50%, -50%); }
transform: translate(-50%, -50%);
}
&__avatar { .video-bg {
width: 200rpx; width: 100vw;
height: 200rpx; height: 100vh;
border: 8rpx solid rgba(255, 255, 255, 0.05); z-index: 0;
border-radius: 50%; }
overflow: hidden;
box-shadow: 0rpx 0rpx 80rpx 0rpx rgba(0, 0, 0, 0.15);
}
&__nick-name { /* 用户信息 start */
color: #ffffff; .user-info {
margin-top: 26rpx; &__container {
font-size: 36rpx; position: absolute;
font-weight: 600; top: 25vh;
text-align: center; left: 50%;
} -webkit-transform: translate(-50%, -50%);
} transform: translate(-50%, -50%);
}
/* 用户信息 end */ &__avatar {
width: 200rpx;
height: 200rpx;
border: 8rpx solid rgba(255, 255, 255, 0.05);
border-radius: 50%;
overflow: hidden;
box-shadow: 0rpx 0rpx 80rpx 0rpx rgba(0, 0, 0, 0.15);
}
/* 流星*/ &__nick-name {
.tn-satr { color: #ffffff;
position: fixed; margin-top: 26rpx;
width: 100%; font-size: 36rpx;
height: 600px; font-weight: 600;
overflow: hidden; text-align: center;
flex-shrink: 0; }
z-index: 998; }
}
.stars { /* 用户信息 end */
position: absolute;
z-index: 1;
width: 100%;
height: 400px;
}
.star { /* 流星*/
border-radius: 50%; .tn-satr {
background: #ffffff; position: fixed;
box-shadow: 0px 0px 6px 0px rgba(255, 255, 255, 0.8); width: 100%;
} height: 600px;
overflow: hidden;
flex-shrink: 0;
z-index: 998;
}
.small-stars .star { .stars {
position: absolute; position: absolute;
width: 3px; z-index: 1;
height: 3px; width: 100%;
} height: 400px;
}
.small-stars .star:nth-child(2n) { .star {
opacity: 0; border-radius: 50%;
-webkit-animation: star-blink 1.2s linear infinite alternate; background: #ffffff;
animation: star-blink 1.2s linear infinite alternate; box-shadow: 0px 0px 6px 0px rgba(255, 255, 255, 0.8);
} }
.small-stars .star:nth-child(1) { .small-stars .star {
left: 40px; position: absolute;
bottom: 50px; width: 3px;
} height: 3px;
}
.small-stars .star:nth-child(2) { .small-stars .star:nth-child(2n) {
left: 200px; opacity: 0;
bottom: 40px; -webkit-animation: star-blink 1.2s linear infinite alternate;
} animation: star-blink 1.2s linear infinite alternate;
}
.small-stars .star:nth-child(3) { .small-stars .star:nth-child(1) {
left: 60px; left: 40px;
bottom: 120px; bottom: 50px;
} }
.small-stars .star:nth-child(4) { .small-stars .star:nth-child(2) {
left: 140px; left: 200px;
bottom: 250px; bottom: 40px;
} }
.small-stars .star:nth-child(5) { .small-stars .star:nth-child(3) {
left: 400px; left: 60px;
bottom: 300px; bottom: 120px;
} }
.small-stars .star:nth-child(6) { .small-stars .star:nth-child(4) {
left: 170px; left: 140px;
bottom: 80px; bottom: 250px;
} }
.small-stars .star:nth-child(7) { .small-stars .star:nth-child(5) {
left: 200px; left: 400px;
bottom: 360px; bottom: 300px;
-webkit-animation-delay: 0.2s; }
animation-delay: 0.2s;
}
.small-stars .star:nth-child(8) { .small-stars .star:nth-child(6) {
left: 250px; left: 170px;
bottom: 320px; bottom: 80px;
} }
.small-stars .star:nth-child(9) { .small-stars .star:nth-child(7) {
left: 300px; left: 200px;
bottom: 340px; bottom: 360px;
} -webkit-animation-delay: 0.2s;
animation-delay: 0.2s;
}
.small-stars .star:nth-child(10) { .small-stars .star:nth-child(8) {
left: 130px; left: 250px;
bottom: 320px; bottom: 320px;
-webkit-animation-delay: 0.5s; }
animation-delay: 0.5s;
}
.small-stars .star:nth-child(11) { .small-stars .star:nth-child(9) {
left: 230px; left: 300px;
bottom: 330px; bottom: 340px;
-webkit-animation-delay: 7s; }
animation-delay: 7s;
}
.small-stars .star:nth-child(12) { .small-stars .star:nth-child(10) {
left: 300px; left: 130px;
bottom: 360px; bottom: 320px;
-webkit-animation-delay: 0.3s; -webkit-animation-delay: 0.5s;
animation-delay: 0.3s; animation-delay: 0.5s;
} }
@-webkit-keyframes star-blink { .small-stars .star:nth-child(11) {
50% { left: 230px;
width: 3px; bottom: 330px;
height: 3px; -webkit-animation-delay: 7s;
opacity: 1; animation-delay: 7s;
} }
}
@keyframes star-blink { .small-stars .star:nth-child(12) {
50% { left: 300px;
width: 3px; bottom: 360px;
height: 3px; -webkit-animation-delay: 0.3s;
opacity: 1; animation-delay: 0.3s;
} }
}
.medium-stars .star { @-webkit-keyframes star-blink {
position: absolute; 50% {
width: 3px; width: 3px;
height: 3px; height: 3px;
opacity: 0; opacity: 1;
-webkit-animation: star-blink 1.2s ease-in infinite alternate; }
animation: star-blink 1.2s ease-in infinite alternate; }
}
.medium-stars .star:nth-child(1) { @keyframes star-blink {
left: 300px; 50% {
bottom: 50px; width: 3px;
} height: 3px;
opacity: 1;
}
}
.medium-stars .star:nth-child(2) { .medium-stars .star {
left: 400px; position: absolute;
bottom: 40px; width: 3px;
-webkit-animation-delay: 0.4s; height: 3px;
animation-delay: 0.4s; opacity: 0;
} -webkit-animation: star-blink 1.2s ease-in infinite alternate;
animation: star-blink 1.2s ease-in infinite alternate;
}
.medium-stars .star:nth-child(3) { .medium-stars .star:nth-child(1) {
left: 330px; left: 300px;
bottom: 300px; bottom: 50px;
-webkit-animation-delay: 0.2s; }
animation-delay: 0.2s;
}
.medium-stars .star:nth-child(4) { .medium-stars .star:nth-child(2) {
left: 460px; left: 400px;
bottom: 300px; bottom: 40px;
-webkit-animation-delay: 0.9s; -webkit-animation-delay: 0.4s;
animation-delay: 0.9s; animation-delay: 0.4s;
} }
.medium-stars .star:nth-child(5) { .medium-stars .star:nth-child(3) {
left: 300px; left: 330px;
bottom: 150px; bottom: 300px;
-webkit-animation-delay: 1.2s; -webkit-animation-delay: 0.2s;
animation-delay: 1.2s; animation-delay: 0.2s;
} }
.medium-stars .star:nth-child(6) { .medium-stars .star:nth-child(4) {
left: 440px; left: 460px;
bottom: 120px; bottom: 300px;
-webkit-animation-delay: 1s; -webkit-animation-delay: 0.9s;
animation-delay: 1s; animation-delay: 0.9s;
} }
.medium-stars .star:nth-child(7) { .medium-stars .star:nth-child(5) {
left: 200px; left: 300px;
bottom: 140px; bottom: 150px;
-webkit-animation-delay: 0.8s; -webkit-animation-delay: 1.2s;
animation-delay: 0.8s; animation-delay: 1.2s;
} }
.medium-stars .star:nth-child(8) { .medium-stars .star:nth-child(6) {
left: 30px; left: 440px;
bottom: 480px; bottom: 120px;
-webkit-animation-delay: 0.3s; -webkit-animation-delay: 1s;
animation-delay: 0.3s; animation-delay: 1s;
} }
.medium-stars .star:nth-child(9) { .medium-stars .star:nth-child(7) {
left: 460px; left: 200px;
bottom: 400px; bottom: 140px;
-webkit-animation-delay: 1.2s; -webkit-animation-delay: 0.8s;
animation-delay: 1.2s; animation-delay: 0.8s;
} }
.medium-stars .star:nth-child(10) { .medium-stars .star:nth-child(8) {
left: 150px; left: 30px;
bottom: 10px; bottom: 480px;
-webkit-animation-delay: 1s; -webkit-animation-delay: 0.3s;
animation-delay: 1s; animation-delay: 0.3s;
} }
.medium-stars .star:nth-child(11) { .medium-stars .star:nth-child(9) {
left: 420px; left: 460px;
bottom: 450px; bottom: 400px;
-webkit-animation-delay: 1.2s; -webkit-animation-delay: 1.2s;
animation-delay: 1.2s; animation-delay: 1.2s;
} }
.medium-stars .star:nth-child(12) { .medium-stars .star:nth-child(10) {
left: 340px; left: 150px;
bottom: 180px; bottom: 10px;
-webkit-animation-delay: 1.1s; -webkit-animation-delay: 1s;
animation-delay: 1.1s; animation-delay: 1s;
} }
@keyframes star-blink { .medium-stars .star:nth-child(11) {
50% { left: 420px;
width: 4px; bottom: 450px;
height: 4px; -webkit-animation-delay: 1.2s;
opacity: 1; animation-delay: 1.2s;
} }
}
.star-fall { .medium-stars .star:nth-child(12) {
position: relative; left: 340px;
border-radius: 2px; bottom: 180px;
width: 80px; -webkit-animation-delay: 1.1s;
height: 2px; animation-delay: 1.1s;
overflow: hidden; }
-webkit-transform: rotate(-20deg);
transform: rotate(-20deg);
}
.star-fall:after { @keyframes star-blink {
content: ''; 50% {
position: absolute; width: 4px;
width: 50px; height: 4px;
height: 2px; opacity: 1;
background: -webkit-gradient(linear, right top, left top, from(rgba(0, 0, 0, 0)), to(rgba(255, 255, 255, 0.4))); }
background: linear-gradient(to left, rgba(0, 0, 0, 0) 0%, rgba(255, 255, 255, 0.4) 100%); }
left: 100%;
-webkit-animation: star-fall 3.6s linear infinite;
animation: star-fall 3.6s linear infinite;
}
.star-fall:nth-child(1) { .star-fall {
left: 80px; position: relative;
bottom: -100px; border-radius: 2px;
} width: 80px;
height: 2px;
overflow: hidden;
-webkit-transform: rotate(-20deg);
transform: rotate(-20deg);
}
.star-fall:nth-child(1):after { .star-fall:after {
-webkit-animation-delay: 2.4s; content: '';
animation-delay: 2.4s; position: absolute;
} width: 50px;
height: 2px;
background: -webkit-gradient(linear, right top, left top, from(rgba(0, 0, 0, 0)), to(rgba(255, 255, 255, 0.4)));
background: linear-gradient(to left, rgba(0, 0, 0, 0) 0%, rgba(255, 255, 255, 0.4) 100%);
left: 100%;
-webkit-animation: star-fall 3.6s linear infinite;
animation: star-fall 3.6s linear infinite;
}
.star-fall:nth-child(2) { .star-fall:nth-child(1) {
left: 200px; left: 80px;
bottom: -200px; bottom: -100px;
} }
.star-fall:nth-child(2):after { .star-fall:nth-child(1):after {
-webkit-animation-delay: 2s; -webkit-animation-delay: 2.4s;
animation-delay: 2s; animation-delay: 2.4s;
} }
.star-fall:nth-child(3) { .star-fall:nth-child(2) {
left: 430px; left: 200px;
bottom: -50px; bottom: -200px;
} }
.star-fall:nth-child(3):after { .star-fall:nth-child(2):after {
-webkit-animation-delay: 3.6s; -webkit-animation-delay: 2s;
animation-delay: 3.6s; animation-delay: 2s;
} }
.star-fall:nth-child(4) { .star-fall:nth-child(3) {
left: 400px; left: 430px;
bottom: 100px; bottom: -50px;
} }
.star-fall:nth-child(4):after { .star-fall:nth-child(3):after {
-webkit-animation-delay: 0.2s; -webkit-animation-delay: 3.6s;
animation-delay: 0.2s; animation-delay: 3.6s;
} }
@-webkit-keyframes star-fall { .star-fall:nth-child(4) {
20% { left: 400px;
left: -100%; bottom: 100px;
} }
100% { .star-fall:nth-child(4):after {
left: -100%; -webkit-animation-delay: 0.2s;
} animation-delay: 0.2s;
} }
@keyframes star-fall { @-webkit-keyframes star-fall {
20% { 20% {
left: -100%; left: -100%;
} }
100% { 100% {
left: -100%; left: -100%;
} }
} }
@keyframes star-fall {
20% {
left: -100%;
}
100% {
left: -100%;
}
}
</style> </style>