国庆节烟花效果代码

代码语言:html

所属分类:粒子

代码描述:国庆节烟花效果代码,用五彩斑斓的烟花来祝福伟大的祖国繁荣昌盛。

代码标签: 国庆节 烟花

下面为部分代码预览,完整代码请点击下载或在bfwstudio webide中打开

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">

    <meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=no">
    <style>
        * {
        	position:relative;
        	box-sizing:border-box
        }
        html,body {
        	height:100%
        }
        html {
        	background-color:#000
        }
        body {
        	overflow:hidden;
        	color:rgba(255,255,255,0.5);
        	font-family:"Russo One",arial,sans-serif;
        	line-height:1.25;
        	letter-spacing:.06em
        }
        .hide {
        	opacity:0;
        	visibility:hidden
        }
        .remove {
        	display:none!important
        }
        .blur {
        	filter:blur(12px)
        }
        .container {
        	height:100%;
        	display:flex;
        	justify-content:center;
        	align-items:center
        }
        .loading-init {
        	width:100%;
        	align-self:center;
        	text-align:center;
        	text-transform:uppercase
        }
        .loading-init__header {
        	font-size:2.2em
        }
        .loading-init__status {
        	margin-top:1em;
        	font-size:.8em;
        	opacity:.75
        }
        .stage-container {
        	overflow:hidden;
        	box-sizing:initial;
        	border:1px solid #222;
        	margin:-1px
        }
        @media(max-width:840px) {
        	.stage-container {
        	border:0;
        	margin:0
        }
        }.canvas-container {
        	width:100%;
        	height:100%;
        	            background-image:url("//repo.bfw.wiki/bfwrepo/image/6335428c7ee12.png");
        	            background-repeat: no-repeat;
        	            background-size: cover;
        	transition:filter .3s
        }
        .canvas-container canvas {
        	position:absolute;
        	mix-blend-mode:lighten;
        	transform:translateZ(0)
        }
        .controls {
        	position:absolute;
        	top:0;
        	width:100%;
        	padding-bottom:50px;
        	display:flex;
        	justify-content:space-between;
        	transition:opacity .3s,visibility .3s
        }
        @media(min-width:840px) {
        	.controls {
        	visibility:visible
        }
        .controls.hide:hover {
        	opacity:1
        }
        }.menu {
        	position:absolute;
        	top:0;
        	bottom:0;
        	left:0;
        	right:0;
        	background-color:rgba(0,0,0,0.42);
        	transition:opacity .3s,visibility .3s
        }
        .menu__inner-wrap {
        	display:flex;
        	flex-direction:column;
        	justify-content:center;
        	align-items:center;
        	position:absolute;
        	top:0;
        	bottom:0;
        	left:0;
        	right:0;
        	transition:opacity .3s
        }
        .menu__header {
        	margin-top:auto;
        	margin-bottom:8px;
        	padding-top:16px;
        	font-size:2em;
        	text-transform:uppercase
        }
        .menu__subheader {
        	margin-bottom:auto;
        	padding-bottom:12px;
        	font-size:.86em;
        	opacity:.8
        }
        .menu form {
        	width:100%;
        	max-width:400px;
        	padding:0 10px;
        	overflow:auto;
        	-webkit-overflow-scrolling:touch
        }
        .menu .form-option {
        	display:flex;
        	align-items:center;
        	margin:16px 0;
        	transition:opacity .3s
        }
        .menu .form-option label {
        	display:block;
        	width:50%;
        	padding-right:12px;
        	text-align:right;
        	text-transform:uppercase;
        	-webkit-user-select:none;
        	-moz-user-select:none;
        	-ms-user-select:none;
        	user-select:none
        }
        .menu .form-option--select select {
        	display:block;
        	width:50%;
        	height:30px;
        	font-size:1rem;
        	font-family:"Russo One",arial,sans-serif;
        	color:rgba(255,255,255,0.5);
        	letter-spacing:.06em;
        	background-color:transparent;
        	border:1px solid rgba(255,255,255,0.5)
        }
        .menu .form-option--select select option {
        	background-color:black
        }
        .menu .form-option--checkbox input {
        	display:block;
        	width:26px;
        	height:26px;
        	margin:0;
        	opacity:.5
        }
        @media(max-width:840px) {
        	.menu .form-option select,.menu .form-option input {
        	outline:0
        }
        }.close-menu-btn {
        	position:absolute;
        	top:0;
        	right:0
        }
        .btn {
        	opacity:.16;
        	width:50px;
        	height:50px;
        	display:flex;
        	-webkit-user-select:none;
        	-moz-user-select:none;
        	-ms-user-select:none;
        	user-select:none;
        	cursor:default;
        	transition:opacity .3s
        }
        .btn--bright {
        	opacity:.5
        }
        @media(min-width:840px) {
        	.btn:hover {
        	opacity:.32
        }
        .btn--bright:hover {
        	opacity:.75
        }
        }.btn svg {
        	display:block;
        	margin:auto
        }
        .credits {
        	margin-top:auto;
        	margin-bottom:10px;
        	padding-top:6px;
        	font-size:.8em;
        	opacity:.75
        }
        .credits a {
        	color:rgba(255,255,255,0.5);
        	text-decoration:none
        }
        .credits a:hover,.credits a:active {
        	color:rgba(255,255,255,0.75);
        	text-decoration:underline
        }
        .help-modal {
        	display:flex;
        	justify-content:center;
        	align-items:center;
        	position:fixed;
        	top:0;
        	bottom:0;
        	left:0;
        	right:0;
        	visibility:hidden;
        	transition-property:visibility;
        	transition-duration:.25s
        }
        .help-modal__overlay {
        	position:absolute;
        	top:0;
        	bottom:0;
        	left:0;
        	right:0;
        	opacity:0;
        	transition-property:opacity;
        	transition-timing-function:ease-in;
        	transition-duration:.25s
        }
        .help-modal__dialog {
        	display:flex;
        	flex-direction:column;
        	align-items:center;
        	max-width:400px;
        	max-height:calc(100vh - 100px);
        	margin:10px;
        	padding:20px;
        	border-radius:.3em;
        	background-color:rgba(0,0,0,0.4);
        	opacity:0;
        	transform:scale(0.9,0.9);
        	transition-property:opacity,transform;
        	transition-timing-function:ease-in;
        	transition-duration:.25s
        }
        @media(min-width:840px) {
        	.help-modal__dialog {
        	font-size:1.25rem;
        	max-width:500px
        }
        }.help-modal__header {
        	font-size:1.75em;
        	text-transform:uppercase;
        	text-align:center
        }
        .help-modal__body {
        	overflow-y:auto;
        	-webkit-overflow-scrolling:touch;
        	margin:1em 0;
        	padding:1em 0;
        	border-top:1px solid rgba(255,255,255,0.25);
        	border-bottom:1px solid rgba(255,255,255,0.25);
        	line-height:1.5;
        	color:rgba(255,255,255,0.75)
        }
        .help-modal__close-btn {
        	flex-shrink:0;
        	outline:0;
        	border:0;
        	border-radius:2px;
        	padding:.25em .75em;
        	margin-top:.36em;
        	font-family:"Russo One",arial,sans-serif;
        	font-size:1em;
        	color:rgba(255,255,255,0.5);
        	text-transform:uppercase;
        	letter-spacing:.06em;
        	background-color:rgba(255,255,255,0.25);
        	transition:color .3s,background-color .3s
        }
        .help-modal__close-btn:hover,.help-modal__close-btn:active,.help-modal__close-btn:focus {
        	color:#FFF;
        	background-color:#09F
        }
        .help-modal.active {
        	visibility:visible;
        	transition-duration:.4s
        }
        .help-modal.active .help-modal__overlay {
        	opacity:1;
        	transition-timing-function:ease-out;
        	transition-duration:.4s
        }
        .help-modal.active .help-modal__dialog {
        	opacity:1;
        	transform:scale(1,1);
        	transition-timing-function:ease-out;
        	transition-duration:.4s
        }
    </style>
</head>

<body>


    <div style="height: 0; width: 0; position: absolute; visibility: hidden;"><svg xmlns="http://www.w3.org/2000/svg"><symbol id="icon-play" viewBox="0 0 24 24"><path d="M8 5v14l11-7z" /></symbol><symbol id="icon-pause" viewBox="0 0 24 24"><path d="M6 19h4V5H6v14zm8-14v14h4V5h-4z" /></symbol><symbol id="icon-close" viewBox="0 0 24 24"><path d="M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z" /></symbol><symbol id="icon-settings" viewBox="0 0 24 24"><path d="M19.43 12.98c.04-.32.07-.64.07-.98s-.03-.66-.07-.98l2.11-1.65c.19-.15.24-.42.12-.64l-2-3.46c-.12-.22-.39-.3-.61-.22l-2.49 1c-.52-.4-1.08-.73-1.69-.98l-.38-2.65C14.46 2.18 14.25 2 14 2h-4c-.25 0-.46.18-.49.42l-.38 2.65c-.61.25-1.17.59-1.69.98l-2.49-1c-.23-.09-.49 0-.61.22l-2 3.46c-.13.22-.07.49.12.64l2.11 1.65c-.04.32-.07.65-.07.98s.03.66.07.98l-2.11 1.65c-.19.15-.24.42-.12.64l2 3.46c.12.22.39.3.61.22l2.49-1c.52.4 1.08.73 1.69.98l.38 2.65c.03.24.24.42.49.42h4c.25 0 .46-.18.49-.42l.38-2.65c.61-.25 1.17-.59 1.69-.98l2.49 1c.23.09.49 0 .61-.22l2-3.46c.12-.22.07-.49-.12-.64l-2.11-1.65zM12 15.5c-1.93 0-3.5-1.57-3.5-3.5s1.57-3.5 3.5-3.5 3.5 1.57 3.5 3.5-1.57 3.5-3.5 3.5z" /></symbol><symbol id="icon-sound-on" viewBox="0 0 24 24"><path d="M3 9v6h4l5 5V4L7 9H3zm13.5 3c0-1.77-1.02-3.29-2.5-4.03v8.05c1.48-.73 2.5-2.25 2.5-4.02zM14 3.23v2.06c2.89.86 5 3.54 5 6.71s-2.11 5.85-5 6.71v2.06c4.01-.91 7-4.49 7-8.77s-2.99-7.86-7-8.77z" /></symbol><symbol id="icon-sound-off" viewBox="0 0 24 24"><path d="M16.5 12c0-1.77-1.02-3.29-2.5-4.03v2.21l2.45 2.45c.03-.2.05-.41.05-.63zm2.5 0c0 .94-.2 1.82-.54 2.64l1.51 1.51C20.63 14.91 21 13.5 21 12c0-4.28-2.99-7.86-7-8.77v2.06c2.89.86 5 3.54 5 6.71zM4.27 3L3 4.27 7.73 9H3v6h4l5 5v-6.73l4.25 4.25c-.67.52-1.42.93-2.25 1.18v2.06c1.38-.31 2.63-.95 3.69-1.81L19.73 21 21 19.73l-9-9L4.27 3zM12 4L9.91 6.09 12 8.18V4z" /></symbol></svg></div>
    <!-- App -->
    <div class="container">
        <div class="loading-init">
            <div class="loading-init__header">Loading</div>
            <div class="loading-init__status">Assembling Shells</div>
        </div>
        <div class="stage-container remove">
            <div class="canvas-container"><canvas id="trails-canvas"></canvas><canvas id="main-canvas"></canvas></div>
            <div class="controls">
                <div class="btn pause-btn"><svg fill="white" width="24" height="24"><use href="#icon-pause" xlink:href="#icon-pause"></use></svg></div>
                <div class="btn sound-btn"><svg fill="white" width="24" height="24"><use href="#icon-sound-off" xlink:href="#icon-sound-off"></use></svg></div>
                <div class="btn settings-btn"><svg fill="white" width="24" height="24"><use href="#icon-settings" xlink:href="#icon-settings"></use></svg></div>
            </div>
            <div class="menu hide">
                <div class="menu__inner-wrap">
                    <div class="btn btn--bright close-menu-btn"><svg fill="white" width="24" height="24"><use href="#icon-close" xlink:href="#icon-close"></use></svg></div>
                    <div class="menu__header">Settings</div>
                    <div class="menu__subheader">For more info,click any label.</div>
                    <form>
                        <div class="form-option form-option--select"><label class="shell-type-label">Shell Type</label><select class="shell-type"></select></div>
                        <div class="form-option form-option--select"><label class="shell-size-label">Shell Size</label><select class="shell-size"></select></div>
                        <div class="form-option form-option--select"><label class="quality-ui-label">Quality</label><select class="quality-ui"></select></div>
                        <div class="form-option form-option--select"><label class="sky-lighting-label">Sky Lighting</label><select class="sky-lighting"></select></div>
                        <div class="form-option form-option--select"><label class="scaleFactor-label">Scale</label><select class="scaleFactor"></select></div>
                        <div class="form-option form-option--checkbox"><label class="auto-launch-label">Auto Fire</label><input class="auto-launch" type="checkbox" /></div>
                        <div class="form-option form-option--checkbox form-option--finale-mode"><label class="finale-mode-label">Finale Mode</label><input class="finale-mode" type="checkbox" /></div>
                        <div class="form-option form-option--checkbox"><label class="hide-controls-label">Hide Controls</label><input class="hide-controls" type="checkbox" /></div>
                        <div class="form-option form-option--checkbox form-option--fullscreen"><label class="fullscreen-label">Fullscreen</label><input class="fullscreen" type="checkbox" /></div>
                        <div class="form-option form-option--checkbox"><label class="long-exposure-label">Open Shutter</label><input class="long-exposure" type="checkbox" /></div>
                    </form>
                    <div class="credits">Passionately built by <a href="http://www.bootstrap.com" target="_blank">Caleb Miller</a>. </div>
                </div>
            </div>
        </div>
        <div class="help-modal">
            <div class="help-modal__overlay"></div>
            <div class="help-modal__dialog">
                <div class="help-modal__header"></div>
                <div class="help-modal__body"></div><button type="button" class="help-modal__close-btn">Close</button></div>
        </div>
    </div>
    <!-- partial -->
    <script type="text/javascript" src="//repo.bfw.wiki/bfwrepo/js/fscreen.1.0.1.js"></script>
    <script type="text/javascript" src="//repo.bfw.wiki/bfwrepo/js/Stage.0.1.4.js"></script>
    <script type="text/javascript" src="//repo.bfw.wiki/bfwrepo/js/MyMath.js"></script>
    <script>
        // This is a prime example of what starts out as a simple project
        // and snowballs way beyond its intended size. It's a little clunky
        // reading/working on this single file, but here it is anyways :)
        
        const IS_MOBILE = window.innerWidth <= 640;
        const IS_DESKTOP = window.innerWidth > 800;
        const IS_HEADER = IS_DESKTOP && window.innerHeight < 300;
        // Detect high end devices. This will be a moving target.
        const IS_HIGH_END_DEVICE = (() => {
        	const hwConcurrency = navigator.hardwareConcurrency;
        	if (!hwConcurrency) {
        		return false;
        	}
        	// Large screens indicate a full size computer, which often have hyper threading these days.
        	// So a quad core desktop machine has 8 cores. We'll place a higher min threshold there.
        	const minCount = window.innerWidth <= 1024 ? 4 : 8;
        	return hwConcurrency >= minCount;
        })();
        // Prevent canvases from getting too large on ridiculous screen sizes.
        // 8K - can restrict this if needed
        const MAX_WIDTH = 7680;
        const MAX_HEIGHT = 4320;
        const GRAVITY = 0.9; // Acceleration in px/s
        let simSpeed = 1;
        
        function getDefaultScaleFactor() {
        	if (IS_MOBILE) return 0.9;
        	if (IS_HEADER) return 0.75;
        	return 1;
        }
        
        // Width/height values that.........完整代码请登录后点击上方下载按钮下载查看

网友评论0