設定時間後に自動的に停止するタイマー機能を持ったプログラムをつくりたいのですが、現時点の知識ではsleepでしか知りません。
py
def loop(): GPIO.output(17, GPIO.HIGH) sleep(10) GPIO.output(17, GPIO.LOW) sleep(0)
10秒後に停止処理を行いたく、sleep(0)と書きましたが停止せず、(0)を(1)にすると、当然ながら停止時間が1秒立つとまた10秒間処理を開始してしまい、ひたすら繰り返します。
一度だけ処理を行う記述をお教えいただけないでしょうか。
よろしくお願いいたします。
コード全体を表示します。行っていることは、ラズパイでLチカです。
LED点灯後指定した時間で消灯させたいです。
py
import webiopi import RPi.GPIO as GPIO from time import sleep GPIO = webiopi.GPIO LIGHT = 17 # GPIO pin using BCM numbering # setup function is automatically called at WebIOPi startup def setup(): # set the GPIO used by the light to output GPIO.setFunction(LIGHT, GPIO.OUT) # loop function is repeatedly called by WebIOPi def loop(): # gives CPU some time before looping again GPIO.output(17, GPIO.HIGH) sleep(10) GPIO.output(17, GPIO.LOW) sleep(0) # destroy function is called at WebIOPi shutdown def destroy(): GPIO.digitalWrite(LIGHT, GPIO.LOW)
HTML
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>WebIOPi | Light Control</title> <script type="text/javascript" src="/webiopi.js"></script> <script type="text/javascript"> webiopi().ready(function() { // Create a "Light" labeled button for GPIO 17 var button = webiopi().createGPIOButton(17, "Light"); var button_2 = webiopi().createGPIOButton(4, "Light"); // Append button to HTML element with ID="controls" using jQuery $("#controls").append(button); $("#controls_2").append(button_2); // Refresh GPIO buttons // pass true to refresh repeatedly of false to refresh once webiopi().refreshGPIO(true); }); </script> <style type="text/css"> button { display: block; margin: 5px 5px 5px 5px; width: 160px; height: 45px; font-size: 24pt; font-weight: bold; color: white; } button_2 { display: block; margin: 5px 5px 5px 5px; width: 160px; height: 45px; font-size: 24pt; font-weight: bold; color: white; } #gpio17.LOW { background-color: Black; } #gpio17.HIGH { background-color: Blue; } #gpio4.LOW { background-color: Black; } #gpio4.HIGH { background-color: Blue; } </style> </head> <body> <div id="controls" align="center"></div> <div id="controls_2" align="center"></div> </body> </html>
よろしくお願いいたします。
この関数はどうやって使われているか分からないので、ソースコード全体を載せてください
ありがとうございます。コード全体を載せます
[[Q&A] ラズパイを用いてLED点灯をタイマーセッティングを行い自動消灯させたい - Qiita]( https://qiita.com/morita05041984/questions/eb2b2a89b442a3d94478 )
まだ回答がついていません
会員登録して回答してみよう