﻿<?xml version="1.0" encoding="UTF-8"?><rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>Tag Volet - Constellation</title>
	<atom:link href="https://developer.myconstellation.io/tag/volet/feed/" rel="self" type="application/rss+xml" />
	<link>https://developer.myconstellation.io/tag/volet/</link>
	<description>Votre plateforme d&#039;interconnexion</description>
	<lastBuildDate>Thu, 19 Apr 2018 05:05:48 +0000</lastBuildDate>
	<language>fr-FR</language>
	<sy:updatePeriod>
	hourly	</sy:updatePeriod>
	<sy:updateFrequency>
	1	</sy:updateFrequency>
	<generator>https://wordpress.org/?v=6.0.11</generator>

<image>
	<url>https://developer.myconstellation.io/wp-content/uploads/2016/02/256x256-e1457476015859.png</url>
	<title>Tag Volet - Constellation</title>
	<link>https://developer.myconstellation.io/tag/volet/</link>
	<width>32</width>
	<height>32</height>
</image> 
	<item>
		<title>Connecter un vidéo projecteur standard à Constellation et synchroniser les volets</title>
		<link>https://developer.myconstellation.io/tutorials/connecter-un-video-projecteur-dans-constellation/</link>
					<comments>https://developer.myconstellation.io/tutorials/connecter-un-video-projecteur-dans-constellation/#respond</comments>
		
		<dc:creator><![CDATA[Lucas]]></dc:creator>
		<pubDate>Tue, 16 May 2017 10:23:36 +0000</pubDate>
				<category><![CDATA[Tutoriels]]></category>
		<category><![CDATA[IoT]]></category>
		<category><![CDATA[Arduino]]></category>
		<category><![CDATA[ESP8266]]></category>
		<category><![CDATA[Domotique]]></category>
		<category><![CDATA[Volet]]></category>
		<category><![CDATA[.NET]]></category>
		<category><![CDATA[Projecteur]]></category>
		<guid isPermaLink="false">https://developer.myconstellation.io/?p=4888</guid>

					<description><![CDATA[<p>Par Lucas Dupuis Ayant fait récemment l&#8217;acquisition d&#8217;un vidéo-projecteur pour mes soirées films, je me suis vite rendu compte qu&#8217;avec les jours qui rallongent, j&#8217;ai besoin de fermer les volets de mon salon afin de rester dans une certaine pénombre.</p>
<p>The post <a rel="nofollow" href="https://developer.myconstellation.io/tutorials/connecter-un-video-projecteur-dans-constellation/">Connecter un vidéo projecteur standard à Constellation et synchroniser les volets</a> appeared first on <a rel="nofollow" href="https://developer.myconstellation.io">Constellation</a>.</p>
]]></description>
										<content:encoded><![CDATA[<p><em>Par Lucas Dupuis</em></p>
<p>Ayant fait récemment l&rsquo;acquisition d&rsquo;un vidéo-projecteur pour mes soirées films, je me suis vite rendu compte qu&rsquo;avec les jours qui rallongent, j&rsquo;ai besoin de fermer les volets de mon salon afin de rester dans une certaine pénombre.</p>
<p>La présentation de mon système de pilotage de volets n&rsquo;est plus à faire, <a href="/showcases/connecter-volets-constellation-arduino-raspberry/">vous la retrouverez ici</a>. Vous pouvez aussi utiliser des modules Z-Wave comme le FGR-211 qu&rsquo;on connectera à Constellation via le package <a href="/package-library/vera/">Vera</a> ou <a href="/package-library/jeedom/">Jeedom</a>. Dans tous les cas, nous disposons un <a href="/concepts/messaging-message-scope-messagecallback-saga/">MessageCallback </a>pour ouvrir ou fermer nos volets !</p>
<p>La problématique qui se pose est la suivante : comment savoir que le projecteur est allumé et que je m&rsquo;apprête à regarder un film ?</p>
<p>J&rsquo;ai réfléchi à plusieurs solutions :</p>
<ul>
<li>Monitorer la consommation de la prise électrique afin de déduire que le projecteur est allumé
<ul>
<li>Avantages :
<ul>
<li>Permet d&rsquo;exposer un booléen indiquant que le projecteur est allumé et d&rsquo;ouvrir/fermer les volets en conséquence</li>
<li>Permet de monitorer la consommation en temps réel</li>
<li>Permet de monitorer la durée d&rsquo;utilisation de la lampe du vidéo-projecteur</li>
</ul>
</li>
<li>Inconvénients :
<ul>
<li>Nécessite une prise connectée avec conso-mètre (à fabriquer ou à acheter)</li>
<li>C&rsquo;est potentiellement complexe et coûteux</li>
</ul>
</li>
</ul>
</li>
<li>Surveiller le StateObject de mon médiacenter Kodi (exposé par le package <a href="/package-library/xbmc/">xbmc</a>)
<ul>
<li>Avantages :
<ul>
<li>J&rsquo;ai déjà une routine surveillant le stateobject pour allumer et éteindre le système de son lorsqu&rsquo;un média est joué</li>
<li>Il n&rsquo;y a que du code à mettre en place dans le package « cerveau » de la maison</li>
</ul>
</li>
<li>Inconvénients :
<ul>
<li>Il n&rsquo;y a pas de lien direct entre l&rsquo;allumage du projecteur et une action sur les volets</li>
<li>La sélection du film ou du média sur l&rsquo;écran se fait volets ouverts, et donc c&rsquo;est potentiellement gênant en cas de luminosité importante</li>
<li>Cela ne tient pas compte des autres sources branchées sur le projecteur (TV, console, &#8230;)</li>
</ul>
</li>
</ul>
</li>
<li>Utiliser un déclencheur sur le projecteur
<ul>
<li>Avantages :
<ul>
<li>Montage simple</li>
<li>Peu d&rsquo;investissement</li>
<li>Système embarqué trivial</li>
</ul>
</li>
<li>Inconvénients :
<ul>
<li>Pas de monitoring de consommation</li>
</ul>
</li>
</ul>
</li>
</ul>
<p>J&rsquo;ai retenu la seconde et la troisième option : la seconde option, consistant à surveiller le stateobject de <a href="/package-library/xbmc/">kodi</a> permet l&rsquo;allumage du système de son lorsqu&rsquo;un média est lu, que ce soit un film ou un morceau de musique et la troisième option pour déclencher la fermeture des volets à l&rsquo;allumage du vidéo projecteur.</p>
<h3>Prerequis</h3>
<ul>
<li>Un serveur Constellation</li>
<li>Un vidéo-projecteur avec une sortie 12V</li>
<li>Un ESP8266 (ou Arduino connecté) avec un régulateur de tension</li>
<li>Le SDK Visual Studio</li>
</ul>
<h3>Etape 1 : connecter le vidéo projecteur dans Constellation</h3>
<p>En regardant les caractéristiques de mon projecteur, je me suis rendu compte qu&rsquo;il existait une sortie 12V permettant de déclencher un moteur pour une toile de projection.</p>
<p align="center"><a href="https://developer.myconstellation.io/wp-content/uploads/2017/05/2017-05-03-21.19.35.jpg"><img class="colorbox-4888"  loading="lazy" style="background-image: none; padding-top: 0px; padding-left: 0px; display: inline; padding-right: 0px; border: 0px;" title="Le projecteur vidéo" src="https://developer.myconstellation.io/wp-content/uploads/2017/05/2017-05-03-21.19.35_thumb.jpg" alt="Le projecteur vidéo" width="454" height="342" border="0" /></a></p>
<p>À la maison je projette sur un mur blanc, je n&rsquo;ai donc pas besoin de cette sortie. Il s&rsquo;agit d&rsquo;un connecteur jack mono que vous trouverez rapidement chez vous dans votre boite de récup&rsquo; ou bien directement sur le net pour quelques centimes.</p>
<p>Il suffit donc d&rsquo;un ESP8266 (par exemple un ESP-01, très petit et peu cher) et d&rsquo;un régulateur de tension 3.3v (ex. LD1117v33) acceptant en entrée une tension entre 5 et 15V et le tour est joué !</p>
<p>En effet, le projecteur envoie du 12v sur la sortie dès qu&rsquo;il est sous tension et du 0v lorsqu&rsquo;il est éteint. Ainsi notre ESP-01 sera alimenté par cette sortie. Lorsqu&rsquo;on allume le vidéo-projecteur, l&rsquo;ESP-01 sera démarré et lorsqu&rsquo;on éteint le vidéo projecteur, il sera éteint car plus d&rsquo;alimentation !</p>
<p>Aussi simple que cela !</p>
<p align="center"><a href="https://developer.myconstellation.io/wp-content/uploads/2017/05/2017-05-16-10.27.17.jpg"><img class="colorbox-4888"  loading="lazy" style="background-image: none; padding-top: 0px; padding-left: 0px; display: inline; padding-right: 0px; border: 0px;" title="Schéma du montage avec l'ESP8266" src="https://developer.myconstellation.io/wp-content/uploads/2017/05/2017-05-16-10.27.17_thumb.jpg" alt="Schéma du montage avec l'ESP8266" width="454" height="193" border="0" /></a></p>
<p align="center"><a href="https://developer.myconstellation.io/wp-content/uploads/2017/05/2017-05-06-15.37.28.jpg"><img class="colorbox-4888"  loading="lazy" style="background-image: none; padding-top: 0px; padding-left: 0px; display: inline; padding-right: 0px; border: 0px;" title="Le vidéo projecteur avec l'ESP8266" src="https://developer.myconstellation.io/wp-content/uploads/2017/05/2017-05-06-15.37.28_thumb.jpg" alt="Le vidéo projecteur avec l'ESP8266" width="454" height="342" border="0" /></a></p>
<p>L&rsquo;ESP, de son côté, publie simplement toutes les secondes un StateObject ayant une durée de vie de 5 secondes pour indiquer que le projecteur est allumé.</p>
<p>Pour connecter un ESP8266 (ou un Arduino) <a href="/getting-started/connecter-un-arduino-ou-un-esp8266-constellation/">suivez ce guide</a> ! Une fois connecté dans ma Constellation, je <a href="/client-api/arduino-esp-api/produire-des-stateobjects-depuis-arduino-esp/">publie le StateObject</a> dans la boucle principale <em>loop()</em></p>
<p></p><pre class="crayon-plain-tag">void loop() {
  constellation.loop();
 
  if(((millis() - lastTime) &gt; 1000) 
    || (millis() &lt; lastTime))
  {
    constellation.pushStateObject("Uptime",  millis(), 5);
    lastTime = millis();
  } 
}</pre><p></p>
<p>On a donc dans les StateObjects de notre Constellation, un StateObject « Uptime » publié dans mon cas par le package (virtuel)  « ESP01_Projector » qui contient l&rsquo;uptime de mon projecteur :</p>
<p align="center"><a href="https://developer.myconstellation.io/wp-content/uploads/2017/05/Screenshot-SO.png"><img class="colorbox-4888"  loading="lazy" style="background-image: none; padding-top: 0px; padding-left: 0px; display: inline; padding-right: 0px; border: 0px;" title="Le StateObject de l'uptime du projecteur" src="https://developer.myconstellation.io/wp-content/uploads/2017/05/Screenshot-SO_thumb.png" alt="Le StateObject de l'uptime du projecteur" width="457" height="332" border="0" /></a></p>
<p style="text-align: left;" align="center">Ce StateObject est mis à jour par l&rsquo;ESP toutes les secondes avec une durée de vie de 5 secondes ! Ainsi je n&rsquo;ai pas besoin de connaitre la valeur du StateObject, il me suffit juste de vérifier que le StateObject est « Valide » et non « Expiré » !</p>
<p style="text-align: left;" align="center">Si il est valide c&rsquo;est que dans les 5 dernières secondes il y a bien publié son Uptime, donc l&rsquo; ESP est démarré ce qui implique que mon vidéo projecteur est bien démarré (pour alimenter l&rsquo;ESP) !</p>
<p style="text-align: left;" align="center">En revanche si ce StateObject est expiré, c&rsquo;est à dire que le StateObject n&rsquo;a pas été mis à jour durant les 5 dernières secondes or l&rsquo;ESP est censé le faire à chaque seconde ! L&rsquo;ESP-01 est donc déconnecté ce qui impliquerai que le vidéo projecteur est arrêté !</p>
<h3 style="text-align: left;" align="center">Etape 2 : synchroniser le vidéo projecteur avec mes volets</h3>
<p style="text-align: left;" align="center">Maintenant, dans mon package « cerveau » de Constellation, il suffit de surveiller ce StateObject et son état expiré ou non pour savoir quelle commande envoyer aux volets.</p>
<p style="text-align: left;" align="center">J&rsquo;ai donc créé un package « cerveau » en C#.</p>
<p style="text-align: left;" align="center">Dans ma classe, je crée un <a href="/client-api/net-package-api/consommer-des-stateobjects/">StateObjectLink </a>pour lier le StateObject de l&rsquo;ESP dans une propriété .NET de mon code :</p>
<p></p><pre class="crayon-plain-tag">/// &lt;summary&gt;
/// StateObject du projecteur. Permet de connaitre l'uptime du projecteur.
/// &lt;/summary&gt;
[StateObjectLink("ESP01_Projector", "Uptime")]
public StateObjectNotifier ProjectorUptime { get; set; }</pre><p></p>
<p>Maintenant au démarrage de mon package, j&rsquo;attache un « handler » sur l&rsquo;événement « <em>ValueChanged</em> » permettant d&rsquo;ajouter du code en cas de mise à jour du StateObject.</p>
<p>Ici je vérifie que mon StateObjectLink est bien lié au StateObject (<em>HasValue</em>) et que ce StateObject n&rsquo;est pas expiré (<em>IsExpired</em>).</p>
<p>Si la condition est vrai, c&rsquo;est que mon projecteur est allumé, alors je peux fermer mes volets autrement je restaure les volets dans leurs positions précédentes.</p>
<p></p><pre class="crayon-plain-tag">this.ProjectorUptime.ValueChanged += (s, e) =&gt;
{
    // Projecteur allumé ?
    if (this.ProjectorUptime.HasValue == true &amp;&amp; this.ProjectorUptime.Value.IsExpired == false)
    {
        // Si projecteur est allumé, on ferme les volets.
        foreach (var volet in this.voletConfig)
        {
            if (this.ShowDebug)
            {
                PackageHost.WriteWarn($"Fermeture du volet {volet.Name} à 100%.");
            }
            
            // On enregistre au passage la position de départ pour la restaurer à la fin.
            volet.PreviousPosition = volet.CurrentPosition; 
            
            // Ordre de fermeture (100%).
            PackageHost.CreateMessageScope("ESP_Shutters").ChangePercent(volet.Name, 100);
        }
    }
    else
    {
        // Si projecteur est éteint, on rouvre les volets.
        foreach (var volet in this.voletConfig)
        {
            if (this.ShowDebug)
            {
                PackageHost.WriteWarn($"Ouverture du volet {volet.Name} à l'ancienne position, {Convert.ToInt32(volet.Percent * 100.0)}-&gt;{volet.PreviousPosition}% après {this.tempoReouvertureVolets} secs d'inactivité.");
            }

            // Pour chaque volet, on revient à la position initiale
            PackageHost.CreateMessageScope("ESP_Shutters").ChangePercent(volet.Name, volet.PreviousPosition);
        }
    }
};</pre><p></p>
<h3>Conclusion</h3>
<p>Une demi-heure de prototypage et de soudure, un petit quart d&rsquo;heure de développement, et le challenge est relevé !</p>
<p>L&rsquo;allumage du projecteur ferme les volets de mon salon selon une consigne, il déclenche également un scénario prédéfini pour les lampes Hue et active la prise du système de son. Le clic sur le bouton de la télécommande rend l&rsquo;expérience du film beaucoup plus profitable avec Constellation !</p>
<p>The post <a rel="nofollow" href="https://developer.myconstellation.io/tutorials/connecter-un-video-projecteur-dans-constellation/">Connecter un vidéo projecteur standard à Constellation et synchroniser les volets</a> appeared first on <a rel="nofollow" href="https://developer.myconstellation.io">Constellation</a>.</p>
]]></content:encoded>
					
					<wfw:commentRss>https://developer.myconstellation.io/tutorials/connecter-un-video-projecteur-dans-constellation/feed/</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
			</item>
		<item>
		<title>Connecter ses volets dans la Constellation avec des Arduino et un Raspberry</title>
		<link>https://developer.myconstellation.io/showcases/connecter-volets-constellation-arduino-raspberry/</link>
					<comments>https://developer.myconstellation.io/showcases/connecter-volets-constellation-arduino-raspberry/#respond</comments>
		
		<dc:creator><![CDATA[Lucas]]></dc:creator>
		<pubDate>Mon, 08 Jun 2015 09:21:39 +0000</pubDate>
				<category><![CDATA[Showcases]]></category>
		<category><![CDATA[Volet]]></category>
		<category><![CDATA[Python]]></category>
		<category><![CDATA[Javascript]]></category>
		<category><![CDATA[Arduino]]></category>
		<category><![CDATA[Domotique]]></category>
		<category><![CDATA[Raspberry]]></category>
		<guid isPermaLink="false">https://developer.myconstellation.io/?p=4680</guid>

					<description><![CDATA[<p>Ecrit par Lucas Dupuis en Juin 2015. Lorsque nous avons acheté notre maison, nous avons entamé de lourds travaux de rénovation ce qui m’a permis de passer du câble multifonction blindé à chaque point de contrôle (interrupteurs) dans l’optique de</p>
<p>The post <a rel="nofollow" href="https://developer.myconstellation.io/showcases/connecter-volets-constellation-arduino-raspberry/">Connecter ses volets dans la Constellation avec des Arduino et un Raspberry</a> appeared first on <a rel="nofollow" href="https://developer.myconstellation.io">Constellation</a>.</p>
]]></description>
										<content:encoded><![CDATA[<p><em>Ecrit par Lucas Dupuis en Juin 2015.</em></p>
<p>Lorsque nous avons acheté notre maison, nous avons entamé de lourds travaux de rénovation ce qui m’a permis de passer du câble multifonction blindé à chaque point de contrôle (interrupteurs) dans l’optique de pouvoir facilement ajouter des fonctionnalités domotique sans avoir recours à des solutions sans fil comme le Z-Wave assez coûteux.</p>
<p>Après l’installation de pas moins d’une dizaine volets électrique dans la maison, il me fallait une solution de pilotage à la fois simple, fiable et surtout économique. De plus cette solution devra être ouverte me permettant de concevoir ma propre interface de contrôle sur tout type de support et de pouvoir facilement ajouter de l’intelligence.</p>
<p>Grace à la plateforme Constellation, un Raspberry Pi et quelques Arduinos, j’ai pu concevoir mon propre système de gestion des volets.</p>
<h3>La conception</h3>
<p>Concrètement chaque volet dispose de deux phases : une pour la montée et une autre pour la descente.</p>
<p>L’idée est donc de piloter ces deux phases avec des relais. Pour garder le contrôle manuel des volets (c’est-à-dire à partir des interrupteurs encastrés dans le mur), j’ai connecté chaque interrupteur bistable au système pour déclencher les volets (obligatoire pour une certification WAF J).</p>
<p>Pour cela derrière chaque interrupteur des volets, j’ai placé une carte de contrôle avec deux relais 220V et deux entrées. Chaque carte de contrôle est connectée sur un câble multifonction qui arrive à chaque volet. On utilise donc 6 fils : deux pour les entrées des interrupteurs (montée et descente), deux pour la commande des deux relais (montée et descente) et deux pour l’alimentation (5V ou 12V en fonction de vos relais).</p>
<p>Côté budget, comptez moins de 3€ par volet.</p>
<p align="center"><a href="https://developer.myconstellation.io/wp-content/uploads/2017/05/image-68.png"><img class="colorbox-4680"  loading="lazy" style="background-image: none; padding-top: 0px; padding-left: 0px; display: inline; padding-right: 0px; border: 0px;" title="Carte de relais par volet" src="https://developer.myconstellation.io/wp-content/uploads/2017/05/image_thumb-68.png" alt="Carte de relais par volet" width="304" height="404" border="0" /></a></p>
<p>L’ensemble des câbles se rejoignent tous jusque dans ma baie réseau au RDC. Chaque volet a donc besoin de deux sorties pour les relais et deux entrées pour l’interrupteur bistable. Avec 10 volets, ça nous donne donc 20 sorties et 20 entrées, beaucoup trop pour un Raspberry !</p>
<p>Toujours dans l’optique de baisser les coûts, j’utilise un réseau d’Arduino Mini Pro acheté moins de 2€ pièce.</p>
<p>Chaque Arduino peut gérer jusqu’à 3 volets. Ils sont tous installés sur une carte et connectés en série sur un bus I2C sur lequel est également connecté un Raspberry qui sera le cerveau des volets, lui-même connecté dans la Constellation.</p>
<p align="center"><a href="https://developer.myconstellation.io/wp-content/uploads/2017/05/image-69.png"><img class="colorbox-4680"  loading="lazy" style="background-image: none; padding-top: 0px; padding-left: 0px; display: inline; padding-right: 0px; border: 0px;" title="Centrale Arduino et Raspberry" src="https://developer.myconstellation.io/wp-content/uploads/2017/05/image_thumb-69.png" alt="Centrale Arduino et Raspberry" width="454" height="342" border="0" /></a></p>
<p>N’importe quel objet, page Web ou programme connecté dans la Constellation pourra envoyer un ordre à chaque volet. Chaque ordre sera traité par le package Constellation qui tourne sur le Raspberry qui, commandera l’Arduino associé via le bus I2C qui lui-même activera le relais correspondant à l’ordre de montée ou descente du volet cible !</p>
<h3>Conception logicielle</h3>
<p>Une fois nos volets connectés sur les cartes relais reliés aux Arduinos, il suffit d’activer les sorties pour basculer l’état des relais et donc piloter la montée ou la descente de chacun de nos volets.</p>
<p>Par exemple pour une montée :</p>
<p></p><pre class="crayon-plain-tag">digitalWrite(volets[i].relaisMontee, HIGH);
digitalWrite(volets[i].relaisDescente, LOW);</pre><p></p>
<p>Pour capter un changement d’état sur les interrupteurs bistables, il suffit de lire l’entrée correspondante configurée en pull-up. Si l’entrée change d’état à l’état LOW c’est qu’on vient d’appuyer sur le bouton de montée :</p>
<p></p><pre class="crayon-plain-tag">if (digitalRead(volets[i].buttonMontee) == LOW &amp;&amp; volets[i].previousSens != 1)
{
  // Demande de montée
}</pre><p></p>
<p>Pour la communication des Arduino avec la base Raspberry, j’utilise le protocole I2C. Chaque Arduino à son adresse 0x11 pour le 1<sup>er</sup>, 0x12 pour le 2<sup>ème</sup>, etc.. en esclave sur le bus. Le Raspberry est maître.</p>
<p>Lors du setup, j’attribue l’adresse de mon Arduino et configure des callbacks pour la réception et l’émission :</p>
<p></p><pre class="crayon-plain-tag">Wire.begin(SLAVE_ADDRESS);
Wire.onReceive(receiveData);
Wire.onRequest(sendData);</pre><p></p>
<p>Pour la lecture, dès qu’il y a quelque chose sur le bus, je récupère un Int dont les deux 1<sup>ers</sup> bits m’indiquent le n° du volet, suivi d’un bit pour savoir si je dois allumer ou eteindre le volet. En cas d’allumage, le dernier bit permet de connaitre le sens (montée ou descente) :</p>
<p></p><pre class="crayon-plain-tag">while(Wire.available()) 
{
    int dataReceived = 0;
    dataReceived = Wire.read();
    rawVal += dataReceived;
}
int rawInt = rawVal.toInt();
int numVolet = bitRead(rawInt,2) &amp; bitRead(rawInt,3)*2;
int allumageVolet = bitRead(rawInt,1);
int sensVolet = bitRead(rawInt,0);
// Envoyer l'ordre sur les sorties du volet correspondant</pre><p></p>
<p>Pour connaitre l’état des interrupteurs depuis le Raspberry, chaque Arduino écrit sur le bus un Int avec le même format pour indiquer pour chaque volet son état :</p>
<p></p><pre class="crayon-plain-tag">Wire.write(/* int représentant l’état du volet */);</pre><p></p>
<p>Maintenant que je peux piloter l’ensemble de mes volets depuis mon Raspberry, j’utilise la plateforme Constellation pour tout connecter facilement.</p>
<p>Grace au SDK Constellation dans Visual Studio et aux Python Tools for Visual Studio, j’ai créé un package Constellation en Python.</p>
<p>Le package expose des méthodes dans la Constellation pour le contrôle et publie des « StateObjects » sur l’état de chaque volet.</p>
<p></p><pre class="crayon-plain-tag">def ActionVoletMessageCallback(data):
    # Action à envoyer à un volet.
    try:
        volet = GetShutter(data["shutterName"].lower())
        actionStr = data["actionShutter"].lower()
     if actionStr == "montee":
            volet.Open()
        elif actionStr == "descente":
            volet.Close()
        else:
            volet.Stop()
    Constellation.WriteInfo("ActionVolet: %s =&gt; %s ", (volet.nom, actionStr))</pre><p></p>
<p>Les methodes Open/Close/Stop écrivent sur le bus I2C avec la commande I2CSet à destination de l’adresse de l’arduino cible, l’entier représentant l’ordre à exécuter :</p>
<p></p><pre class="crayon-plain-tag">commande = 'i2cset -y 1 %s 0x%x' % (self.adresse, i)
os.system(commande)</pre><p></p>
<p>Pour la lecture sur le bus, j’utilise la commande « i2cget ».</p>
<p></p><pre class="crayon-plain-tag">f = os.popen('i2cget -y 1 %s' % self.adresse, 'r')
retour = f.read()</pre><p></p>
<p>Une fois l’entier représentant l’état de chaque volet décrypté, je publie dans la Constellation un StateObject avec toutes les infos :</p>
<p></p><pre class="crayon-plain-tag"># Changement, on met à jour le stateobject
 Constellation.PushStateObject(volet.nom, volet.etat, "Shutter",
   {
       "Adresse": volet.adresse,
       "Numero": volet.numero,
       "Statut inversé" : volet.inverseStatut,
       "Commande inversée" : volet.inverseCommande
   })</pre><p></p>
<p>Une fois mon package développé, je peux directement depuis Visual Studio le publier sur mon serveur et le déployer sur une sentinelle de ma Constellation.</p>
<p>Au préalable j’ai installé une Sentinelle Constellation sur mon Raspberry. Il me suffit ensuite de lancer mon package depuis l’interface Web de contrôle de ma Constellation.</p>
<p>Cette interface me permet également de suivre en temps réel les logs de mes packages :</p>
<p align="center"><a href="https://developer.myconstellation.io/wp-content/uploads/2017/05/image-70.png"><img class="colorbox-4680"  loading="lazy" style="background-image: none; padding-top: 0px; padding-left: 0px; display: inline; padding-right: 0px; border: 0px;" title="Console Constellation 1.7" src="https://developer.myconstellation.io/wp-content/uploads/2017/05/image_thumb-70.png" alt="Console Constellation 1.7" width="354" height="100" border="0" /></a></p>
<h3>Aller plus loin avec Constellation</h3>
<p>A ce stade l’état de chaque volet de ma maison est publié dans la Constellation et je suis capable de piloter chacun d’entre eux en envoyer un message dans la Constellation à destination de mon package Python.</p>
<p>La suite logique est de créer une interface de pilotage. Pour cela je vais utiliser l’API Constellation pour AngularJS me permettant de créer une application HTML/JS connectée dans la Constellation avec le framework Angular de Google.</p>
<p>Grace à la Constellation, le code Javascript se résume à cela :</p>
<p></p><pre class="crayon-plain-tag">app.controller('ShutterAngularController', ['$scope', 'constellation', function ($scope, constellation) {

    constellation.intializeClient("http://constellation.myhome.lan:8088/", "MonAcessKey", "HomeControl");

    var MesVolets = {};
    constellation.onUpdateStateObject(function (message) {
        $scope.$apply(function () {
            $scope.MesVolets[message.Name] = message;
        });
    });

    constellation.onConnectionStateChanged(function (change) {
        if (change.newState === $.signalR.connectionState.connected) {
            constellation.requestSubscribeStateObjects("*", "ShutterController", "*", "*");
        }
    });

    $scope.actionShutter = function (shutter, action) {
        constellation.sendMessage({ Scope: 'Package', Args: ['ShutterController'] }, 'ActionVoletMessageCallback', { 'shutterName': shutter.Name, 'actionShutter': action });
    };

    constellation.connect();
}]);</pre><p></p>
<p>Dans mon contrôleur, je me connecte à ma Constellation et je m’abonne au StateObject du package « ShutterController ». A chaque réception d’un state object, je l’ajoute dans mon scope Angular. De plus j’ai ajouté une méthode pour envoyer un message de contrôle à mon package Python.</p>
<p>Il ne reste plus qu’à faire une vue HTML en faisant une boucle sur notre variable de scope « MesVolets » :</p>
<p></p><pre class="crayon-plain-tag">&lt;div class="list-group-item" ng-repeat="shutter in ShutterController"&gt;
    &lt;h3&gt;                        
        {{shutter.Name}}
        &lt;em class="pull-right btn-group" role="group" aria-label="..."&gt;
            &lt;button type="button" 
                class="btn btn-default glyphicon glyphicon-chevron-up" 
                ng-class="{ active: shutter.Value==='Montee' }" 
                ng-click='actionShutter(shutter, "montee")'&gt;
                &lt;/button&gt;
            &lt;button type="button" 
                class="btn btn-default glyphicon glyphicon-stop" 
                ng-class="{ active: shutter.Value==='Arret' }" 
                ng-click='actionShutter(shutter, "stop")'&gt;
                &lt;/button&gt;
            &lt;button type="button" 
                class="btn btn-default glyphicon glyphicon-chevron-down" 
                ng-class="{ active: shutter.Value==='Descente' }" 
                ng-click='actionShutter(shutter, "descente")'&gt;
                &lt;/button&gt;
        &lt;/em&gt;
    &lt;/h3&gt;
&lt;/div&gt;</pre><p></p>
<p>Et voilà comment créer une première interface Web de supervision et de contrôle de l’ensemble des volets à la maison.</p>
<p align="center"><a href="https://developer.myconstellation.io/wp-content/uploads/2017/05/image-71.png"><img class="colorbox-4680"  loading="lazy" style="background-image: none; padding-top: 0px; padding-left: 0px; display: inline; padding-right: 0px; border: 0px;" title="Interface de contrôle des volets" src="https://developer.myconstellation.io/wp-content/uploads/2017/05/image_thumb-71.png" alt="Interface de contrôle des volets" width="404" height="387" border="0" /></a></p>
<p>Les propriétés des volets étant exposées dans la Constellation, il devient facile d’ajouter de l’intelligence dans la maison. Par exemple, j’ai également un autre Raspberry avec un capteur de luminosité TSL2561 dans ma Constellation ce qui me permet d’ouvrir et fermer les volets en fonction du seuil de luminosité ou encore de fermer automatiquement les volets lorsque je lance un film sur mon XBMC (XBMC/Kodi étant lui-même connecté dans ma Constellation).</p>
<p>Grace à la plateforme Constellation, l’interconnexion des objets devient un jeu d’enfant comme l’orchestration et le déploiement de mes programmes à travers les différents devices de la maison.</p>
<p>Ainsi, moyennant un budget inférieur à 100€, j’ai pu connecter et rendre intelligents mes dix volets.</p>
<p><b><i>Lucas Dupuis</i></b></p>
<p>The post <a rel="nofollow" href="https://developer.myconstellation.io/showcases/connecter-volets-constellation-arduino-raspberry/">Connecter ses volets dans la Constellation avec des Arduino et un Raspberry</a> appeared first on <a rel="nofollow" href="https://developer.myconstellation.io">Constellation</a>.</p>
]]></content:encoded>
					
					<wfw:commentRss>https://developer.myconstellation.io/showcases/connecter-volets-constellation-arduino-raspberry/feed/</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
			</item>
	</channel>
</rss>

<!--
Performance optimized by W3 Total Cache. Learn more: https://www.boldgrid.com/w3-total-cache/?utm_source=w3tc&utm_medium=footer_comment&utm_campaign=free_plugin

Mise en cache de page à l’aide de Disk: Enhanced 

Served from: developer.myconstellation.io @ 2026-01-22 04:34:24 by W3 Total Cache
-->