气球表白网页

转载:https://blog.csdn.net/weixin_41110459/article/details/80556720

html:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<title>告白气球</title>
		<style type="text/css">
			body,html{
				width: 100%;
				height: 100%;
				background: black;
			}
			div{
				position: absolute;
				border-radius: 50%;
			}
			#txt{
				position: relative;
				font-family: 楷体;
				font-size: 50px;
				width: 400px;
				height: 100px;
				margin: 260px 520px;
				z-index: 1000;
			}
		</style>
	</head>
	<body>
		<!--
        	作者:offline
        	时间:2018-07-06
        	描述:div></div>
        -->
        <div id="txt"><p>老婆,我爱你!</p></div>
        <embed src="music/周笔畅-最美的期待.mp3" autoplay="autoplay"></embed>
		<script type="text/javascript" src="js/Balloon.js"></script>
		<script type="text/javascript">
			var n=0;
		//创建一个对象
			var t=setInterval(function(){
				var b = new Balloon("url(img/"+n+".png)");
				b.drawBalloon(document.body);
				b.run();
				n++;
				if(n>8){
					clearInterval(t);
				}
			},3000);
			
		for(var i=0;i<30;i++){
			//创建一个对象
			var b = new Balloon();
			b.drawBalloon(document.body);
			b.run();
		}
			
		</script>
	</body>
</html>	<head>
		<meta charset="utf-8" />
		<title>告白气球</title>
		<style type="text/css">
			body,html{
				width: 100%;
				height: 100%;
				background: black;
			}
			div{
				position: absolute;
				border-radius: 50%;
			}
			#txt{
				position: relative;
				font-family: 楷体;
				font-size: 50px;
				width: 400px;
				height: 100px;
				margin: 260px 520px;
				z-index: 1000;
			}
		</style>
	</head>
	<body>
		<!--
        	作者:offline
        	时间:2018-07-06
        	描述:div></div>
        -->
        <div id="txt"><p>老婆,我爱你!</p></div>
        <embed src="music/周笔畅-最美的期待.mp3" autoplay="autoplay"></embed>
		<script type="text/javascript" src="js/Balloon.js"></script>
		<script type="text/javascript">
			var n=0;
		//创建一个对象
			var t=setInterval(function(){
				var b = new Balloon("url(img/"+n+".png)");
				b.drawBalloon(document.body);
				b.run();
				n++;
				if(n>8){
					clearInterval(t);
				}
			},3000);
			
		for(var i=0;i<30;i++){
			//创建一个对象
			var b = new Balloon();
			b.drawBalloon(document.body);
			b.run();
		}
			
		</script>
	</body>
</html>

js:

Balloon.js

//要使用面向对象的思维来开发
//定义一个气球对象
/*
 * 分析属性方法
 * 半径  r
 * 位置  left top 
 * 盒子  div
 * 背景  bg
 * 速度  speedX speedY
 */


//把气球画出来
//drawBalloon()

//让气球动起来
//run()
			
function Balloon(pic) {
	//盒子
	this.div = document.createElement("div");
	
	//位置
	this.left = randomRange(0,1000);
	this.top = randomRange(0,600);
	//速度
	this.speedX = randomRange(-3,3);
	this.speedY = randomRange(-3,3);
	//背景
	if(pic == null){
		this.bg = randomColor();
		this.r = randomRange(20,80);
	}else{
		this.bg = pic;
		this.r = 100;
	}
}


//画气球 原型
Balloon.prototype.drawBalloon = function(parent) {
	this.parent = parent;
	var style = this.div.style;
	style.width = this.r * 2 +"px";
	style.height = this.r * 2 +"px";
	style.left = this.left + "px";
	style.top = this.top + "px";
	style.background = this.bg;
	parent.appendChild(this.div);
}

//开始移动
Balloon.prototype.run =function(){
	//获取父容器最大宽,高
	var maxLeft = this.parent.offsetWidth - this.r * 2; 
	var maxTop = this.parent.offsetHeight - this.r * 2;
	
	
	var ts = this;
	//设置定时器
	setInterval(function(){
		//左边移动距离
		var left = ts.div.offsetLeft + ts.speedX;
		//顶部移动的距离
		var top = ts.div.offsetTop + ts.speedY;
		
		//处理边界问题
		if(left<=0){
			left = 0;//这里一定要赋值,不然部分气球会贴边滚动,不反弹
			ts.speedX *=-1;
		}
		if(top<=0){
			top = 0;//这里一定要赋值,不然部分气球会贴边滚动,不反弹
			ts.speedY *=-1;
		}
		if(left>=maxLeft){
			left=maxLeft;
			ts.speedX *= -1;
		}
		if(top>=maxTop){
			top=maxTop;
			ts.speedY *= -1;
		}
		//开始移动
		ts.div.style.left = left + "px";
		ts.div.style.top = top + "px";
	},20);
}
//封装一个指定范围的随机函数
function randomRange(min , max ) {
	return Math.random()*(max - min)+min ;
}

//封装一个随机的颜色
function randomColor(){
	var r = randomRange(0,255);
	var g = randomRange(0,255);
	var b = randomRange(0,255);
	var a = randomRange(0,1);
	return "rgba("+r+","+g+","+b+","+a+")";
}

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Arduino蜂鸣器告白气球是一种浪漫且有趣的方式,它可以让人们通过电子科技来表达爱意。Arduino是一款开源的电子开发板,拥有丰富的功能和扩展性,可以与各种传感器、执行器等组合使用。蜂鸣器是Arduino的一个常用组件,可以通过控制它的频率和时长来发出不同的声音。 告白气球是一种特殊的气球,里面装有纸条或小卡片,可以用于表达心意。将Arduino蜂鸣器与告白气球结合使用,可以让告白更加有趣和特别。可以用Arduino来控制蜂鸣器,让它发出一段特别的音乐或声音,然后将蜂鸣器放置在告白气球内部。当对方打开气球时,蜂鸣器会发出音乐或声音,来给予回应和感谢。 这种方式有别于传统的告白方式,它不仅充满了科技感和创意,而且能够给予双方更多的回忆和纪念价值。Arduino蜂鸣器告白气球通过结合技术和情感的方式,打破了传统的告白方式,让人们感受到了一种全新的浪漫氛围。这种方式不仅适合年轻人,也适合那些喜欢创新和表达的人。 ### 回答2: Arduino蜂鸣器告白气球是一种很浪漫且有趣的DIY创意项目。该项目的目的是通过使用Arduino单片机和一个蜂鸣器来制作一个能够发出音乐和声音的气球,从而向心爱的人表白。 要完成这个项目,你需要准备一些材料和工具,如Arduino UNO板、蜂鸣器、面包板、面包板电线、9V电池和一个充气的气球。首先,你需要将面包板与Arduino板连接起来,然后将蜂鸣器固定在面包板上。 接下来,你需要将电线连接到面包板的适当管脚,并将气球充满空气。然后,你可以将整个电路连接到气球的顶部,以便让蜂鸣器发出声音。最后,你可以编写一个简单的Arduino程序来控制蜂鸣器发出喜欢的音乐和声音。 整个制作过程十分简单,不需要太多的电子专业知识。通过DIY制作这个项目,可以体现你对心爱的人的用心和真情,也可以给生活增添一些乐趣和趣味性。 ### 回答3: Arduino蜂鸣器告白气球是一种非常浪漫的方式,通过编程让蜂鸣器发出类似音乐的声音,从而达到向心爱的人表白的效果。通常情况下,这种告白方式需要准备一个气球和一块Arduino控制板,还需要预先编写好程序并将其上传到控制板中。当气球被填充满气体后,控制板就会启动蜂鸣器,发出一段旋律。在这个过程中,可以将自己的真心话写在气球上,并将其送给对方。这样不仅能够让告白更加具有仪式感,而且还能增添浪漫情调,让双方更加感性。当然,Arduino蜂鸣器告白气球并不是唯一的表白方式,合适的方式也应该因人而异。但无论如何,传达真心话和感受是永恒的主题,告白方式也应该充满自己的独特性和创意。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值