Projet avec produits arduino

Bonjour, j'ai envoyé plusieurs messages sur ce forum, j'ai créé plusieurs sujets et tout est mélangé en bout de ligne. Aussi, je trouve que ça n'avance pas aussi bien que certain autres membres. Je vais vous présenter mon projet comme il le faut et je crois que ça va être plus facile pour de l'aide et plus facile pour le monde qui vont me lire et suivre le projet.

Projet: Plateforme contrôlable
but : Contrôler à distance des appareils sur le réseau électrique domestique

Présentement avec de l'aide, j'ai été capable de créer un server qui actuellement a 3 boutons (on et off). Chaques boutons ont un gif animé qui sert de ''témoin d'activité''. Pour la suite, il faut que quand je clique sur un des boutons, une page s'ouvre dans une autre fenêtre et cette dite fenêtre sois un lien interne locale. (Dans mon cas, l'adresse d'une camera ip). Le problème est dans l'ouverture dans une nouvelle fenêtre et que le bouton en question ouvre et ferme la fenêtre. Ensuite une image devra être modifié à chaque fois que je tourne à on ou off chaques boutons. Un timer pour chaques boutons devra être programmé et pour finir, si possible, créer quelque chose qui pourrait servire de ''mémoriseur'' , c'est à dire un truc qui sera capable de mettre à on ou off une sortie selon une séquence préalablement définie.

Étape de création restante:

  • ouvrir dans une nouvelle page le lien activé par le bouton
  • codé l'image qui sera changé à chaques fois que j'actionne un bouton ou vis versa
  • codé un timer
  • codé un séquenceur

Merci tlm pour l'aide à venir et ceux qui mon aidé

Bonjour,

Je n'avais pas bien compris ton problème d'ouverture dans une nouvelle fenêtre… Essaie de regarder du côté des pop-up javascript

ex

window.open( page [,nom] [,options] )

Bonjour,

SI je comprends bien, vous souhaitez qu'ARDUINO soit le serveur web de l'application??? Est-bien exact???
Si c'est bien le cas, quelle en est la raison???
N'est-il pas plus 'simple' ou 'judicieux' de séparer le serveur web sur un vrai serveur hébergé ou local, fait pour ça et de mettre en place les communications entre le serveur web et l'ARDUINO... Pour finalement délester ARDUINO d'une tache pour lequel il n'est peut être pas le plus performant???

Je n'ai pas eu le temps d'aller très loin dans mes recherches, mais nous avions il y a quelques temps validé que ARDUINO pouvait communiquer de différentes façons avec un serveur web. J'avais personnellement retenu le protocole UDP, mais on pouvait aussi passer des variables par les URL etc...

Qu'en pensez-vous?

ojal:
Bonjour,

SI je comprends bien, vous souhaitez qu'ARDUINO soit le serveur web de l'application??? Est-bien exact???
Si c'est bien le cas, quelle en est la raison???
N'est-il pas plus 'simple' ou 'judicieux' de séparer le serveur web sur un vrai serveur hébergé ou local, fait pour ça et de mettre en place les communications entre le serveur web et l'ARDUINO... Pour finalement délester ARDUINO d'une tache pour lequel il n'est peut être pas le plus performant???

Je n'ai pas eu le temps d'aller très loin dans mes recherches, mais nous avions il y a quelques temps validé que ARDUINO pouvait communiquer de différentes façons avec un serveur web. J'avais personnellement retenu le protocole UDP, mais on pouvait aussi passer des variables par les URL etc...

Qu'en pensez-vous?

Bonjour, si je comprend bien, tu me dis que je pourrais heberger toute les informations sur un simple serveur web et que les cartes arduino servirait de communicateur entre ''le réseau et le serveur'' ? Comment faire pour déterminer chaques actions différentes entre plusieurs cartes installées? J'aimerais plus de détails , je suis un peu perdu.

Oliv4945:
Bonjour,

Je n'avais pas bien compris ton problème d'ouverture dans une nouvelle fenêtre… Essaie de regarder du côté des pop-up javascript

ex

window.open( page [,nom] [,options] )

Salut, en fait j'aimerais simplement ouvrir une page web dans une nouvelle fenêtre quand je clique sur un bouton. Je clique sur un bouton, la sortie s'actionne (ex : une led s'allume) et par le fait même une page web s'ouvre. Il n'est pas trop compliqué de faire ouvrir une page web mais, la faire ouvrire dans une nouvelle page c'est là le problème. J'essaye d'autres choses ce soir. Si tu as des idées fait moi signe!

Guillaume85:
Salut, en fait j’aimerais simplement ouvrir une page web dans une nouvelle fenêtre quand je clique sur un bouton. Je clique sur un bouton, la sortie s’actionne (ex : une led s’allume) et par le fait même une page web s’ouvre. Il n’est pas trop compliqué de faire ouvrir une page web mais, la faire ouvrire dans une nouvelle page c’est là le problème. J’essaye d’autres choses ce soir. Si tu as des idées fait moi signe!

Certains navigateurs peuvent bloqués l’ouverture de popup par défaut, je sais pas si ça peut venir de là dans tes différent test ?

Guillaume85:

Oliv4945:
Bonjour,

Je n'avais pas bien compris ton problème d'ouverture dans une nouvelle fenêtre… Essaie de regarder du côté des pop-up javascript

ex

window.open( page [,nom] [,options] )

Salut, en fait j'aimerais simplement ouvrir une page web dans une nouvelle fenêtre quand je clique sur un bouton. Je clique sur un bouton, la sortie s'actionne (ex : une led s'allume) et par le fait même une page web s'ouvre. Il n'est pas trop compliqué de faire ouvrir une page web mais, la faire ouvrire dans une nouvelle page c'est là le problème. J'essaye d'autres choses ce soir. Si tu as des idées fait moi signe!

Oui, récupère l'évènement du click via javascript, cf : http://www.commentcamarche.net/contents/javascript/jsevent.php3
Et après dans la fonction appelée utilise window.open( page [,nom] [,options] )

<A href=“URL” “onclickt=‘Action_Javascript_ou_Fonction();’”>Lien

pas trop sur de comprende , j’ai faite des recherche sur des site mais, les truc ne fonctionne pas. Ya un expert haha?

Guillaume85:
<A href=“URL” “onclickt=‘Action_Javascript_ou_Fonction();’”>Lien

Enlève le “t” à “onclick” !

Bonjour,
ci dessous un exemple.

<html>
	<head>
		<title>Tests</title>
	</head>
	<body>
		<script language="javascript">
			function ouverture() {
				// Toutes les actions associees
				// puis ouverture de fenetre
				window.open( 'http://www.arduino.cc' );
			}
		</script>
		<form><input type="button" value="Nouvelle page" onclick="ouverture()"></form>
	</body>
</head>

Lors de l’appui sur le bouton on appelle une fonction javascript, qui ouvre ta fenêtre.

Jean-François:

Guillaume85:
<A href=“URL” “onclickt=‘Action_Javascript_ou_Fonction();’”>Lien

Enlève le “t” à “onclick” !

honte, faute de frappe

j'ai encore rien compris, j'ai beau diviser le code ou le mettre en entier dans mon code et ça m'indique des erreures de compilations. 'ai une partie a mettre dans le void setup et dans le loop ? Ou je me trompe?

Ou encore, dédier une partie de la pageweb du server pour un lien vers le réseau. Par exemple dans mon application quand je vais cliquer sur le bouton mise en marche, un moteur va tourner et en même temps je veux visioner sur une caméra ip ce que le moteur exécute. Dédier une partie dans ma page, servirait uniquement à visionner ce que la caméra film. la page web en entier ferait l’affaire. Je ne sais pas si ça se fait ou encore si c’est plus facile, mais c’est proposé simplement.

Je continue d’esseyer avec l’autre code.

Autre sujet : est-ce normal que quand j’essais d’ajouter une nouvelle image dans ma page je upload sans prob sauf que la page ne s’ouvre pas. J’ai remonté le bufer j’usqu’à 1500 et j’ai testé l’image et ca fonctionne. Où est le prob ?

        plen=es.ES_fill_tcp_data_p(buf,0,PSTR("HTTP/1.0 200 OK\r\nContent-Type: text/html\r\n\r\n"));
    plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("<left><img src=\"http://i915.photobucket.com/albums/ac357/miste44rmpss/image3456.png\"  ></LEFT> "));
        plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("<body bgcolor=\"#000000\"> "));
        plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("<font color=\"#FFFFFF\"><FONT FACE=\"arial\"><RIGHT><I><FONT SIZE=1>BTCAD.<U> V1.0 beta</U></h1></FONT></FONT></I> </RIGHT> "));
        plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("<FONT SIZE=3> <font color=\"#00FF00\"></h1><a href=\"http://192.168.1.1\">Cliquez ici pour acc&egrave;der &agrave; vos cam&eacute;ras<a></FONT></FONT>"));
        
        
        
        
          ICI LA LIGNE QUE JE VEUX METTRE CI HAUT
          
          
    plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("<img src=\"http://i915.photobucket.com/albums/ac357/miste44rmpss/imagelogo.png\">"));

Met une fois ton code en entier, ça sera plus facile pour voire les éventuelles erreurs.

Autre sujet : est-ce normal que quand j'essais d'ajouter une nouvelle image dans ma page je upload sans prob sauf que la page ne s'ouvre pas. J'ai remonté le bufer j'usqu'à 1500 et j'ai testé l'image et ca fonctionne. Où est le prob ?

Je crois que la réponse est dans ta question ... "J'ai remonté le bufer" .

modit j’ai faite encore une faute de frappe. Ça ne fonctionne pas quand je monte le buffer! Y’A t-il autrechoses à verrifier?

Mon code en entier première partie :

#include “etherShield.h”

// please modify the following two lines. mac and ip have to be unique
// in your local area network. You can not have the same numbers in
// two devices:
static uint8_t mymac[6] = {0x54,0x55,0x58,0x10,0x00,0x24};
static uint8_t myip[4] = {192,168,1,15};
static char baseurl=“http://192.168.1.15/”;
static uint16_t mywwwport =80; // listen port for tcp/www (max range 1-254)

#define BUFFER_SIZE 1500
static uint8_t buf[BUFFER_SIZE+1];
#define STR_BUFFER_SIZE 200
static char strbuf[STR_BUFFER_SIZE+1];

EtherShield es=EtherShield();

// prepare the webpage by writing the data to the tcp send buffer
uint16_t print_webpage(uint8_t *buf, byte on_off1, byte on_off2, byte on_off3);
int8_t analyse_cmd(char *str);

// LED cathode connects the Pin4, anode to 5V through 1K resistor
#define LED_PIN4 4
#define LED_PIN5 5
#define LED_PIN6 6
uint16_t plen, dat_p;
int8_t cmd;
byte on_off1 = 0;
byte on_off2 = 0;
byte on_off3 = 0;

void setup(){

/initialize enc28j60/
es.ES_enc28j60Init(mymac);
es.ES_enc28j60clkout(2); // change clkout from 6.25MHz to 12.5MHz
delay(10);

/* Magjack leds configuration, see enc28j60 datasheet, page 11 */
// LEDA=greed LEDB=yellow
//
// 0x880 is PHLCON LEDB=on, LEDA=on
// enc28j60PhyWrite(PHLCON,0b0000 1000 1000 00 00);
es.ES_enc28j60PhyWrite(PHLCON,0x880);
delay(500);
//
// 0x990 is PHLCON LEDB=off, LEDA=off
// enc28j60PhyWrite(PHLCON,0b0000 1001 1001 00 00);
es.ES_enc28j60PhyWrite(PHLCON,0x990);
delay(500);
//
// 0x880 is PHLCON LEDB=on, LEDA=on
// enc28j60PhyWrite(PHLCON,0b0000 1000 1000 00 00);
es.ES_enc28j60PhyWrite(PHLCON,0x880);
delay(500);
//
// 0x990 is PHLCON LEDB=off, LEDA=off
// enc28j60PhyWrite(PHLCON,0b0000 1001 1001 00 00);
es.ES_enc28j60PhyWrite(PHLCON,0x990);
delay(500);
//
// 0x476 is PHLCON LEDA=links status, LEDB=receive/transmit
// enc28j60PhyWrite(PHLCON,0b0000 0100 0111 01 10);
es.ES_enc28j60PhyWrite(PHLCON,0x476);
delay(100);

//init the ethernet/ip layer:
es.ES_init_ip_arp_udp_tcp(mymac,myip,80);

pinMode(LED_PIN4, OUTPUT);
digitalWrite(LED_PIN4, HIGH); // switch off LED
pinMode(LED_PIN5, OUTPUT);
digitalWrite(LED_PIN5, HIGH); // switch off LED
pinMode(LED_PIN6, OUTPUT);
digitalWrite(LED_PIN6, HIGH); // switch off LED
}

void loop(){

plen = es.ES_enc28j60PacketReceive(BUFFER_SIZE, buf);

/*plen will ne unequal to zero if there is a valid packet (without crc error) */
if(plen!=0){

// arp is broadcast if unknown but a host may also verify the mac address by sending it to a unicast address.
if(es.ES_eth_type_is_arp_and_my_ip(buf,plen)){
es.ES_make_arp_answer_from_request(buf);
return;
}

// check if ip packets are for us:
if(es.ES_eth_type_is_ip_and_my_ip(buf,plen)==0){
return;
}

if(buf[IP_PROTO_P]==IP_PROTO_ICMP_V && buf[ICMP_TYPE_P]==ICMP_TYPE_ECHOREQUEST_V){
es.ES_make_echo_reply_from_request(buf,plen);
return;
}

// tcp port www start, compare only the lower byte
if (buf[IP_PROTO_P]==IP_PROTO_TCP_V&&buf[TCP_DST_PORT_H_P]==0&&buf[TCP_DST_PORT_L_P]==mywwwport){
if (buf[TCP_FLAGS_P] & TCP_FLAGS_SYN_V){
es.ES_make_tcp_synack_from_syn(buf); // make_tcp_synack_from_syn does already send the syn,ack
return;
}
if (buf[TCP_FLAGS_P] & TCP_FLAGS_ACK_V){
es.ES_init_len_info(buf); // init some data structures
dat_p=es.ES_get_tcp_data_pointer();
if (dat_p==0){ // we can possibly have no data, just ack:
if (buf[TCP_FLAGS_P] & TCP_FLAGS_FIN_V){
es.ES_make_tcp_ack_from_any(buf);
}
return;
}
if (strncmp("GET ",(char *)&(buf[dat_p]),4)!=0){

// head, post and other methods for possible status codes see:
// HTTP/1.1: Status Code Definitions
plen=es.ES_fill_tcp_data_p(buf,0,PSTR(“HTTP/1.0 200 OK\r\nContent-Type: text/html\r\n\r\n

200 OK

”));
goto SENDTCP;
}
if (strncmp("/ ",(char *)&(buf[dat_p+4]),2)==0){
plen=print_webpage(buf, on_off1, on_off2, on_off3);
goto SENDTCP;
}
cmd=analyse_cmd((char *)&(buf[dat_p+5]));

if (cmd==2){
on_off1=1;
digitalWrite(LED_PIN4, LOW); // switch on LED
}
else if (cmd==3){
on_off1=0;
digitalWrite(LED_PIN4, HIGH); // switch off LED
}
else if (cmd==4){
on_off2=1;
digitalWrite(LED_PIN5, LOW); // switch on LED
}
else if (cmd==5){
on_off2=0;
digitalWrite(LED_PIN5, HIGH); // switch off LED
}

else if (cmd==6){
on_off3=1;
digitalWrite(LED_PIN6, LOW); // switch on LED
}
else if (cmd==7){
on_off3=0;
digitalWrite(LED_PIN6, HIGH); // switch off LED
}

plen=print_webpage(buf, on_off1, on_off2, on_off3);

plen=print_webpage(buf, on_off1, on_off2, on_off3);
SENDTCP: es.ES_make_tcp_ack_from_any(buf); // send ack for http get
es.ES_make_tcp_ack_with_data(buf,plen); // send data
}
}
}

}
// The returned value is stored in the global var strbuf
uint8_t find_key_val(char *str,char *key)
{

Partie 2 de mon code :

        uint8_t found=0;
        uint8_t i=0;
        char *kp;
        kp=key;
        while(*str &&  *str!=' ' && found==0){
                if (*str == *kp){
                        kp++;
                        if (*kp == '\0'){
                                str++;
                                kp=key;
                                if (*str == '='){
                                        found=1;
                                }
                        }
                }else{
                        kp=key;
                }
                str++;
        }
        if (found==1){
                // copy the value to a buffer and terminate it with '\0'
                while(*str &&  *str!=' ' && *str!='&' && i<STR_BUFFER_SIZE){
                        strbuf[i]=*str;
                        i++;
                        str++;
                }
                strbuf[i]='\0';
        }
        return(found);
}

int8_t analyse_cmd(char *str)
{
        int8_t r=-1;
     
        if (find_key_val(str,"cmd")){
                if (*strbuf < 0x3a && *strbuf > 0x2f){
                        // is a ASCII number, return it
                        r=(*strbuf-0x30);
                }
        }
        return r;
}


uint16_t print_webpage(uint8_t *buf, byte on_off1, byte on_off2, byte  on_off3)
{

       int i=0;
    
        
        uint16_t plen;
        
 
        
        plen=es.ES_fill_tcp_data_p(buf,0,PSTR("HTTP/1.0 200 OK\r\nContent-Type: text/html\r\n\r\n"));
    plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("<left><img src=\"http://i915.photobucket.com/albums/ac357/mistermpss/beaucetelecomlogo.png\"  ></LEFT> "));
        plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("<body bgcolor=\"#000000\"> "));
        plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("<font color=\"#FFFFFF\"><FONT FACE=\"arial\"><RIGHT><I><FONT SIZE=1>BTCAD.<U> V1.0 beta</U></h1></FONT></FONT></I> </RIGHT> "));
        plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("<FONT SIZE=3> <font color=\"#00FF00\"></h1><a href=\"http://192.168.1.1\">Cliquez ici pour acc&egrave;der &agrave; vos cam&eacute;ras<a></FONT></FONT>"));
    



            
   

        plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("<hr>
<form METHOD=get action=\""));
        plen=es.ES_fill_tcp_data(buf,plen,baseurl);
        plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("\">"));
        plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("<h2><font color=\"#FFFFFF\"> S&eacute;lection  </h2> "));
 				plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("<h1><font color=\"#FFFFFF\"> "));
 
    
        

            
        
            
    
        

            if(on_off1)
        	plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("<img src=\"http://i915.photobucket.com/albums/ac357/mistermpss/test2on.gif\" >"));
        else 
        	plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("<img src=\"http://i915.photobucket.com/albums/ac357/mistermpss/test2off-1.gif\" >"));
        
 
        
        if(on_off1){
        	plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("<input type=hidden name=cmd value=3>"));
        	plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("<input type=submit value=\"Moteur #1 ON \"></form>"));
          }
         
        else {
        	plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("<input type=hidden name=cmd value=2>"));
        	plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("<input type=submit value=\"Moteur #1 OFF\"></form>"));
     }


          
        plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("
<form METHOD=get action=\""));
        plen=es.ES_fill_tcp_data(buf,plen,baseurl);
        plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("\">"));
 
        
            if(on_off2)
        	plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("<img src=\"http://i915.photobucket.com/albums/ac357/mistermpss/test2on.gif\" >"));
        else 
        	plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("<img src=\"http://i915.photobucket.com/albums/ac357/mistermpss/test2off-1.gif\" >"));
        

        if(on_off2){
        	plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("<input type=hidden name=cmd value=5>"));
        	plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("<input type=submit value=\"Moteur #2 ON\"></form>"));
        }
           
        else {
        	plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("<input type=hidden name=cmd value=4>"));
        	plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("<input type=submit value=\"Moteur #2 OFF\"></form>"));
         
         
             }
           
        plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("
<form METHOD=get action=\""));
        plen=es.ES_fill_tcp_data(buf,plen,baseurl);
        plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("\">"));
    
       
                if(on_off3)
        	plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("<img src=\"http://i915.photobucket.com/albums/ac357/mistermpss/test2on.gif\" >"));
        else 
        	plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("<img src=\"http://i915.photobucket.com/albums/ac357/mistermpss/test2off-1.gif\" >"));
        
  
        
        if(on_off3){
        	plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("<input type=hidden name=cmd value=7>"));
        	plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("<input type=submit value=\"Moteur #3 ON\"></form>"));
        }
        else  {
        	plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("<input type=hidden name=cmd value=6>"));
        	plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("<input type=submit value=\"Moteur #3 OFF \"></form>"));
        }
        
        
                plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("  </font></h1>
 ") );
        
        plen=es.ES_fill_tcp_data_p(buf,plen,PSTR("</CENTER><hr><hr><FONT FACE=\"arial\"><FONT SIZE=1>Une connexion internet est requise pour acc&egrave;der &agrave; ce lien:</font><FONT SIZE=5> <p> Assistance en ligne <a href=\"http://www.google.com\">www.beaucetelecom.ca<a></font></FONT>"));
  
        return(plen);
}

bon j'ai enlevé des gif pis depuis je suis capable de rajouter des imagesm entk c'est vriament facultatif come trouble les images, reste que mon boutons nouvre pas d'autre fenetre dans une autre page

Bon j'ai finalment contourné le probleme, jme suis faite un fichier .bat que j'ouvre et ma page du webserver va s'ouvrir suivi celle des cameras ip. :slight_smile: Ça me convien!

Maintenant je serais redu au timer et ou cédules. Vous croyé que c'est possible avec un enc28j60 ?