venerdì 11 agosto 2017

Livreria QR code dentro livecode

A partire dalla versione 9dp8 (disponibile) la libreria per i codici QR è inclusa in livecode, anche per le versioni gratuite.
Abbiamo a disposizione :

giovedì 10 agosto 2017

Libreria Dropbox dentro livecode

Ora livecode contiene delle librerie per lavorare con Dropbox, sono state rese disponibili per tutti, anche per la versione gratuita, a partire da livecode 9 dp8.

Guardate qua quante sono (48) : http://livecode.wikia.com/wiki/Category:Dropbox

mercoledì 9 agosto 2017

I colori

I colori possono essere espressi attraverso una tripletta che indica i valori di rosso, verde e blu (RGB) tipo

set the backgroundcolor of button 1 to "160,0,255"

oppure attraverso un nome, dalla lista che trovate qui: http://livecode.wikia.com/wiki/ColorNames

set the backgroundcolor of button 1 to "MediumOrchid2"

oppure attraverso il codice HTML:

set the backgroundcolor of button 1 to "#F63526"

Qui trovate un simpatico programma di aiuto: https://mega.nz/#!1IRinbDR!k0iCy7r3VUEZw7_AUsKdVzrRuAnT2SFUZp38Jb7xO5g

lunedì 7 agosto 2017

Sockets

Ci ho messo molto per fare questo post perchè i socket in livecode non sono spiegati molto bene.
Prima di tutto cerchiamo di capire cosa siano e perchè sono così importanti.
Un socket è una via di comunicazione riservata tra due computer. Al contrario di una pagina web, che tutti possono vederla perchè è pubblica e basta sapere l'indirizzo del server per leggerla, il socket è una strada riservata tra due computer.
In linea generate il funzionamento è il seguente:
  1. il server apre una porta sul proprio indirizzo IP, questa porta sarà la comunicazione per chi vuole parlare con lui
  2. uno o più client si mettono in comunicazione col server su quella porta. Per ogni client il server genera un numero di riconoscimento univoco, così riesce a stabilire con chi parlare e cosa dirgli
Attraverso i  socket potreste crearvi il vostro servizio di messaggistica tipo whatsapp o molto altro.
Nel dettaglio lo schema di funzionamento è il seguente, per capirlo bene leggetevi il codice dopo lo schema:
Vediamo il codice.
Il server sarà fatto così:
Basterà cliccare su attivo per aprire la porta 12345, il codice del pulsante Attivo è:

on mouseUp
   if the hilite of me then
      accept connections on port 12345 with message "clientConnected"
   else
      close socket "12345"
   end if
end mouseUp

on clientConnected tSocket   
   put the seconds & " connesso col socket: " & tsocket & return after field "log"
   read from socket tSocket until "§" with message "messageReceived"
end clientConnected

on messageReceived tSocket, pMsg
   put the seconds & space & tsocket & ": " & char 1 to -2 of pMsg & return after field "log"
   write ("Ricevuto messaggio " & char 1 to -2 of pMsg & "§" ) to socket tSocket
   read from socket tSocket until "§" with message "messageReceived"
end messageReceived


Semplice, vero?
Il  codice apre la porta e mette in ascolto il messaggio ClientConnected, se qualche computer si collega il messaggio si attiva per eventuali comandi alla connessione. Il messaggio ClientConnected si attiva per ogni client che si connette.
Subito dopo ClientConnected si attiva messageReceived quando il client ci dice qualcosa. messageReceived richiama sempre se stesso per essere sempre in ascolto di nuovi messaggi.
Come separatore di nuovi messaggi ho scelto il carattere §, ma può essere qualunque altra cosa che il client trasmetta.
Per il client facciamo qualcosa di leggermente più complesso:
Ecco il codice del pulsante Attivo:

local pSocket

-- Disconnect the client from the broadcast server.
command broadcastClientStop
   close socket pSocket
end broadcastClientStop

-- Sent once the client has connected to the broadcaset server.
-- Store the socket for futurure reference and begin reading data
-- from the server.
on broadcastClientConnected tSocket
   put tSocket into pSocket
   read from socket pSocket until "§" with message "broadcaseClientMessageReceived"
end broadcastClientConnected

-- Sent when a message has been received from the server. Output the
-- message and continue reading data from the server.
on broadcaseClientMessageReceived tSocket, pMsg
   put the seconds & ": " & char 1 to -2 of pMsg & return after field "log"
   read from socket tSocket until "§" with message "broadcaseClientMessageReceived" #so we continue to listen
end broadcaseClientMessageReceived

-- Sent when there is an error opening the socket. Log the error.
-- and close the socket.
on socketError tSocket, pError
   close socket tSocket
   put pError & return after field "log"
end socketError

on sendmessage
   write (the text of field "mex") & "§" to socket pSocket
end sendmessage

on mouseUp
   if the hilite of me then
      put the text of field "IPserver" into temp      
      open socket to (temp & ":12345") with message "broadcastClientConnected"
   else
      close socket pSocket
   end if
end mouseUp


Qui abbiamo anche da memorizzare il codice del socket che utilizziamo e indicare al cliente quale è l'indirizzo del server.
Server e client si parlano, per ogni messaggio che arriva al server, il server risponde al client. In questo modo potete fare di tutto, messaggistica, controllo remoto e qualunque cosa vi venga in mente.
Come nel caso del server abbiamo un messaggio che si attiva quando si stabilisce la connessioni (broadcastClientConnected) e un messaggio in ripetizione continua per ascoltare il server (broadcatClientMessagereceived).
Per scrivere ad un socket basta usare write, ricordatevi sempre di indicare un carattere di fine messaggio o una lunghezza fissa predeterminata di caratteri da leggere con il comando read.
Potete scaricare i file da qui: https://mega.nz/#!dN5HWaoY!Wtbb7heTZVAyM3D8O9ddwOp_n7aRHgYyreQKZZTaH_g
Se avete dubbi chiedete nei commenti.

giovedì 20 luglio 2017

Little arrows in un datagrid

A grande richiesta vi illustro il codice da mettere nelle little arrows per modificare il valore di una cella. Per prima cosa modificate il datagrid come illustrato qui aggiungendo le little arrows: http://livecodeitalia.blogspot.it/2016/03/personalizzare-le-colonne-di-un-datagrid.html

Poi mettete come codice delle little arrows il seguente:

on scrollbarLineDec
   put the long id of the owner of me into temp
   add 1 to field 1 of temp
end scrollbarLineDec

on ScrollbarLineInc
   put the long id of the owner of me into temp
   add -1 to field 1 of temp
end ScrollbarLineInc

E tutto funzionerà perfettamente così:
postimage

mercoledì 19 luglio 2017

Evoluzione del codice di Livecode

Qui potete vedere un video che mostra l'evoluzione del codice di livecode creata con gource:
Anche se certe volte non sembra, ci sono sempre parecchie modifiche.


martedì 11 luglio 2017

Menu di scelta su cellulari

Per far fare una scelta sui cellulari abbiamo diverse opzioni percorribili. Possiamo fare con un mobile picker, il metodo più semplice:

on mouseUp
   mobilePick field "countryList"
   put the result into field "countryChoice"
end mouseUp


ecco i risultati:

Oppure usare dei radio buttons, modificati in modo da essere più belli e adatti sui cellulari:

Per modificare un radio buttons, basta modificare le proprietà icon e hiliteIcon.