<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
	<id>http://wikihandbk.com/ruwiki/index.php?action=history&amp;feed=atom&amp;title=Arduino%3A%D0%9F%D1%80%D0%B8%D0%BC%D0%B5%D1%80%D1%8B%2FTimeRTCLog</id>
	<title>Arduino:Примеры/TimeRTCLog - История изменений</title>
	<link rel="self" type="application/atom+xml" href="http://wikihandbk.com/ruwiki/index.php?action=history&amp;feed=atom&amp;title=Arduino%3A%D0%9F%D1%80%D0%B8%D0%BC%D0%B5%D1%80%D1%8B%2FTimeRTCLog"/>
	<link rel="alternate" type="text/html" href="http://wikihandbk.com/ruwiki/index.php?title=Arduino:%D0%9F%D1%80%D0%B8%D0%BC%D0%B5%D1%80%D1%8B/TimeRTCLog&amp;action=history"/>
	<updated>2026-04-07T21:18:54Z</updated>
	<subtitle>История изменений этой страницы в вики</subtitle>
	<generator>MediaWiki 1.40.0</generator>
	<entry>
		<id>http://wikihandbk.com/ruwiki/index.php?title=Arduino:%D0%9F%D1%80%D0%B8%D0%BC%D0%B5%D1%80%D1%8B/TimeRTCLog&amp;diff=8496032&amp;oldid=prev</id>
		<title>EducationBot в 08:38, 8 июля 2023</title>
		<link rel="alternate" type="text/html" href="http://wikihandbk.com/ruwiki/index.php?title=Arduino:%D0%9F%D1%80%D0%B8%D0%BC%D0%B5%D1%80%D1%8B/TimeRTCLog&amp;diff=8496032&amp;oldid=prev"/>
		<updated>2023-07-08T08:38:42Z</updated>

		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;table style=&quot;background-color: #fff; color: #202122;&quot; data-mw=&quot;interface&quot;&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;ru&quot;&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;← Предыдущая версия&lt;/td&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;Версия от 12:38, 8 июля 2023&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot; id=&quot;mw-diff-left-l130&quot;&gt;Строка 130:&lt;/td&gt;
&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;Строка 130:&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br/&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br/&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&amp;lt;references /&amp;gt;&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&amp;lt;references /&amp;gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-side-deleted&quot;&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;{{Навигационная таблица/Портал/Arduino}}&lt;/ins&gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;[[Категория:Пример]]&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;[[Категория:Пример]]&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;[[Категория:Примеры]]&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;[[Категория:Примеры]]&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;[[Категория:Пример программирования Arduino]]&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;[[Категория:Пример программирования Arduino]]&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;[[Категория:Примеры программирования Arduino]]&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;[[Категория:Примеры программирования Arduino]]&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;/table&gt;</summary>
		<author><name>EducationBot</name></author>
	</entry>
	<entry>
		<id>http://wikihandbk.com/ruwiki/index.php?title=Arduino:%D0%9F%D1%80%D0%B8%D0%BC%D0%B5%D1%80%D1%8B/TimeRTCLog&amp;diff=16527&amp;oldid=prev</id>
		<title>Myagkij в 16:43, 19 октября 2016</title>
		<link rel="alternate" type="text/html" href="http://wikihandbk.com/ruwiki/index.php?title=Arduino:%D0%9F%D1%80%D0%B8%D0%BC%D0%B5%D1%80%D1%8B/TimeRTCLog&amp;diff=16527&amp;oldid=prev"/>
		<updated>2016-10-19T16:43:26Z</updated>

		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Новая страница&lt;/b&gt;&lt;/p&gt;&lt;div&gt;{{Arduino панель перехода}}&lt;br /&gt;
{{Перевод от Сubewriter}}&lt;br /&gt;
{{Myagkij-редактор}}&lt;br /&gt;
&lt;br /&gt;
=Учет изменений состояний на контактах с помощью RTC&amp;lt;ref&amp;gt;[https://github.com/PaulStoffregen/Time/blob/master/examples/TimeRTCLog/TimeRTCLog.ino github.com - TimeRTCLog.ino]&amp;lt;/ref&amp;gt;=&lt;br /&gt;
&lt;br /&gt;
Это скетч для [[Arduino:Библиотеки/Time|библиотеки Time]] и платы '''Arduino''', который демонстрирует, как использовать эту библиотеку, чтобы рассчитывать время, прошедшее с определенного события. В данном случае событиями выступают изменения состояний на шести цифровых контактах платы '''Arduino'''.&lt;br /&gt;
&lt;br /&gt;
== Код ==&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;c&amp;quot; line=&amp;quot;GESHI_NORMAL_LINE_NUMBERS|GESHI_FANCY_LINE_NUMBERS&amp;quot;&amp;gt;&lt;br /&gt;
/*&lt;br /&gt;
&lt;br /&gt;
Учет изменений состояний на контактах с помощью RTC&lt;br /&gt;
&lt;br /&gt;
Пример, демонстрирующий вычитание и прибавление времени.&lt;br /&gt;
&lt;br /&gt;
Этот скетч регистрирует изменения состояний на контактах. &lt;br /&gt;
Время события и время, прошедшее с последнего события,&lt;br /&gt;
рассчитываются и отправляются по последовательному порту.&lt;br /&gt;
&lt;br /&gt;
*/&lt;br /&gt;
&lt;br /&gt;
#include &amp;lt;TimeLib.h&amp;gt;&lt;br /&gt;
#include &amp;lt;Wire.h&amp;gt;&lt;br /&gt;
#include &amp;lt;DS1307RTC.h&amp;gt;  // базовая библиотека DS1307, возвращающая время в типе данных time_t&lt;br /&gt;
&lt;br /&gt;
const int nbrInputPins  = 6;             // количество цифровых контактов, за которыми будем наблюдать &lt;br /&gt;
const int inputPins[nbrInputPins] = {2,3,4,5,6,7};  // контакты, за которыми будем наблюдать&lt;br /&gt;
boolean state[nbrInputPins] ;            // состояние отслеживаемых контактов&lt;br /&gt;
time_t  prevEventTime[nbrInputPins] ;    // время, когда произошло предыдущее событие&lt;br /&gt;
&lt;br /&gt;
void setup()  {&lt;br /&gt;
  Serial.begin(9600);&lt;br /&gt;
  setSyncProvider(RTC.get);   // функция, синхронизирующая время с RTC &lt;br /&gt;
  for(int i=0; i &amp;lt; nbrInputPins; i++){&lt;br /&gt;
     pinMode( inputPins[i], INPUT);&lt;br /&gt;
     // если вам нужен подтягивающий резистор,&lt;br /&gt;
     // раскомментируйте две строчки ниже:&lt;br /&gt;
     // pinMode( inputPins[i], INPUT_PULLUP);&lt;br /&gt;
     // state[i] = HIGH;&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
void loop()&lt;br /&gt;
{&lt;br /&gt;
   for(int i=0; i &amp;lt; nbrInputPins; i++)&lt;br /&gt;
   {&lt;br /&gt;
     boolean val = digitalRead(inputPins[i]); &lt;br /&gt;
     if(val != state[i])&lt;br /&gt;
     {&lt;br /&gt;
        time_t duration = 0; // время, прошедшее с предыдущего события &lt;br /&gt;
        state[i] = val;&lt;br /&gt;
        time_t timeNow = now();&lt;br /&gt;
        if(prevEventTime[i] &amp;gt; 0)  &lt;br /&gt;
           // если это не первое изменение, рассчитываем время, &lt;br /&gt;
           // прошедшее с предыдущего изменения:&lt;br /&gt;
           duration = duration = timeNow - prevEventTime[i];         &lt;br /&gt;
        logEvent(inputPins[i], val, timeNow, duration );  // регистрируем событие&lt;br /&gt;
        prevEventTime[i] = timeNow;                       // сохраняем время этого события&lt;br /&gt;
     }&lt;br /&gt;
   }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
void logEvent( int pin, boolean state, time_t timeNow, time_t duration)&lt;br /&gt;
{&lt;br /&gt;
   Serial.print(&amp;quot;Pin &amp;quot;);  //  &amp;quot;Контакт &amp;quot; &lt;br /&gt;
   Serial.print(pin);&lt;br /&gt;
   if( state == HIGH)&lt;br /&gt;
      Serial.print(&amp;quot; went High at &amp;quot;);  //  &amp;quot; перешел в состояние HIGH в &amp;quot;&lt;br /&gt;
   else   &lt;br /&gt;
     Serial.print(&amp;quot; went  Low at &amp;quot;);  //  &amp;quot; перешел в состояние LOW в &amp;quot;&lt;br /&gt;
   showTime(timeNow); &lt;br /&gt;
   if(duration &amp;gt; 0){&lt;br /&gt;
     // показываем время только в том случае, если оно больше «0»: &lt;br /&gt;
     Serial.print(&amp;quot;, Duration was &amp;quot;);  //  &amp;quot;, Продолжительность была &amp;quot;&lt;br /&gt;
     showDuration(duration);&lt;br /&gt;
   }&lt;br /&gt;
   Serial.println();&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
void showTime(time_t t){&lt;br /&gt;
  // показываем заданное время: &lt;br /&gt;
  Serial.print(hour(t));&lt;br /&gt;
  printDigits(minute(t));&lt;br /&gt;
  printDigits(second(t));&lt;br /&gt;
  Serial.print(&amp;quot; &amp;quot;);&lt;br /&gt;
  Serial.print(day(t));&lt;br /&gt;
  Serial.print(&amp;quot; &amp;quot;);&lt;br /&gt;
  Serial.print(month(t));&lt;br /&gt;
  Serial.print(&amp;quot; &amp;quot;);&lt;br /&gt;
  Serial.print(year(t)); &lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
void printDigits(int digits){&lt;br /&gt;
  // вспомогательная функция для печати данных о времени &lt;br /&gt;
  // на монитор порта; добавляет в начале двоеточие и ноль:&lt;br /&gt;
  Serial.print(&amp;quot;:&amp;quot;);&lt;br /&gt;
  if(digits &amp;lt; 10)&lt;br /&gt;
    Serial.print('0');&lt;br /&gt;
  Serial.print(digits);&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
void showDuration(time_t duration){&lt;br /&gt;
// печатаем продолжительность в днях, минутах и секундах:&lt;br /&gt;
  if(duration &amp;gt;= SECS_PER_DAY){&lt;br /&gt;
     Serial.print(duration / SECS_PER_DAY);&lt;br /&gt;
     Serial.print(&amp;quot; day(s) &amp;quot;); &lt;br /&gt;
     duration = duration % SECS_PER_DAY;     &lt;br /&gt;
  }&lt;br /&gt;
  if(duration &amp;gt;= SECS_PER_HOUR){&lt;br /&gt;
     Serial.print(duration / SECS_PER_HOUR);&lt;br /&gt;
     Serial.print(&amp;quot; hour(s) &amp;quot;); &lt;br /&gt;
     duration = duration % SECS_PER_HOUR;     &lt;br /&gt;
  }&lt;br /&gt;
  if(duration &amp;gt;= SECS_PER_MIN){&lt;br /&gt;
     Serial.print(duration / SECS_PER_MIN);&lt;br /&gt;
     Serial.print(&amp;quot; minute(s) &amp;quot;); &lt;br /&gt;
     duration = duration % SECS_PER_MIN;     &lt;br /&gt;
  }&lt;br /&gt;
  Serial.print(duration);&lt;br /&gt;
  Serial.print(&amp;quot; second(s) &amp;quot;);   &lt;br /&gt;
}&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=См.также=&lt;br /&gt;
&lt;br /&gt;
=Внешние ссылки=&lt;br /&gt;
&lt;br /&gt;
&amp;lt;references /&amp;gt;&lt;br /&gt;
[[Категория:Пример]]&lt;br /&gt;
[[Категория:Примеры]]&lt;br /&gt;
[[Категория:Пример программирования Arduino]]&lt;br /&gt;
[[Категория:Примеры программирования Arduino]]&lt;/div&gt;</summary>
		<author><name>Myagkij</name></author>
	</entry>
</feed>