首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

基于arduino的光控窗帘_光控窗帘

为了方便居民在白天把窗帘及时拉开,晚上把窗帘及时拉上,我们设计了光控窗帘。本设计硬件主要是光敏传感器,电机以及单片机;软件主要采用C语言进行编程。...对光的感应我们采用光敏传感器模块,驱动部分我们采用了步进电机,避免了一般电机要用额外电源带动的麻烦,同时为了方便用户,我们还加了两个led指示灯,电机转动拉开窗帘一个指示灯亮,当电机反向转动另一个灯亮。...设备通过光敏传感器的感知,对外界环境光线信号输入到单片机,通过单片机的控制,实现电机的自动开合。...软件设计 在软件设计上有三点,第一是单片机在感到光线变强时驱动电机正转或光线变暗时是驱动电机反转,第二是在驱动一段时间以后必须停下驱动来达到省电以及省设备的目的,第三就是合理控制电机转动时间来达到窗帘的合理拉合...//则电机为状态1 else motivate=0; //否则电机为状态0 } 应用 在实际应用中,应该根据窗帘的长度来调节电机每次驱动所转的转数来调节窗帘是否拉到底或开到底

80610
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    JS动画效果

    JavaScript 动画框架 框架封装 ---- 相信大家在很多门户网站上都可以看到动画的交互效果,通过这些动画生动地体现了我们在网页上的交互效果,现在我们就来学习一下这些动画效果的分解动作吧。...作为学习了网页设计初步的一个进阶选修课。 动画的实现思路都是通过连续改变物体的属性值来实现效果的。一般来说都是改变一个物体的left,right,width,height,opacity....,放进一个人通用的JS文件里movement.js: function getStyle(obj,attr) { if(obj.currentStyle){ return obj.currentStyle...JSON的格式: {键:值,键:值} 完善后的运动框架js:movement.js function getStyle(obj,attr) { if(obj.currentStyle){...startMove(li,{'width':400,'height':200,'opacity':100}); 效果果然是可以同时运动的。

    20.8K81

    Js 实现 marquee 效果

    使用RequestAnimationFrame,核心部分就是利用transformX实现位移 Js 逻辑写的比较挫,还要想想怎么改进,或者有更好的思路。...marquee的要求是两段文字的间隔能人为的控制,所以用了两个重复的p标签。...利用倍数来计算, 实际文字的宽度 / 可视区域的宽度得到3、3.5、4之类的一个倍数,用这个倍数和 目前正在变化时拿到的translateX的值 / 可视区域的宽度 假设是3倍,那么第二步计算出的值如果正好是...3,说明文字的末尾已经出现在‘可视区域’,此时➕一个系数x,就可以实现两段文字的间隔(x按照实际想要的间隔自行设置)。...第二段文字的起始位置就是‘可视区域’的宽度。 然后判断文字全部移出‘可视区域’判断 第二步骤的 倍数 - 第一步的倍数 的误差值即可。

    8.1K20

    圆盘时钟效果 原生JS

    圆盘时钟 旋转时钟 数字时钟 写在前面 仿荣耀手机时钟,设计的同款时钟效果 实现效果 ?...背景采用的是一个炫彩流光的效果,利用了CSS3新增的动画效果 这部分的炫彩流光效果在之前的博客中有详细讲到 炫彩流光效果 指针时钟 通过定位将三根针重叠在一起,下端对齐都摆在原点,通过transfrom-origin...')' 就像这样把分针旋转了多少反馈给时针,60分钟一个小时,所以是除以60 旋转时钟 这里采用的是clip-path属性采取另一半的圆,圆环的效果采用的是大小圆的思路,用小圆盖在大半圆的上方 圆环的旋转和指针的旋转异曲同工...226,20,233),rgb(41, 41, 41)); clip-path: inset( 0 50% 0 0 ); transform-origin: center center; } JS...,圆环的实现,也只是通过了简单的裁剪,想不到实现圆弧的效果 代码有点长,如需完整代码,可以留言或私信

    11.7K20

    实现一个简单的JS效果

    JS中的问题 开发工具与关键技术:javascript 作者:盘洪源 撰写时间:2019年1月27日星期六 如何实现导航中的三角符号的方向和颜色的变换。如下图 一开始 ?...,一开始我以为只是用一个i标签创建出一个三角符号出来后,然后通过JS来把它的颜色和方向换过,但后来发现并不是这样。...直接在原来的i标签的地方在创建多一个i标签创建出一个新的三角符号,然后它的颜色和方向就是你后面需要变化的那些。 ?...在i标签上面必须加入style=”display:”,哪个是要后面通过鼠标移入事件就先填none先隐藏起来,然后后面再通过JS来实现后面的效果。...首先一开始就是原来的三角符号呈现出来,然后通过鼠标移入事件将原来的隐藏掉,将后面的i表签呈现出来 ?

    1.7K31
    领券