PMK_industrija_mikro4

Dependencies:   rohm-rpr0521 rohm-sensor-hal Servo TextLCD

main.cpp

Committer:
emilija
Date:
2021-07-05
Revision:
1:c49ad58c141d
Parent:
0:c4a5143aeebc

File content as of revision 1:c49ad58c141d:

/* mbed Microcontroller Library
 * Copyright (c) 2019 ARM Limited
 * SPDX-License-Identifier: Apache-2.0
 */
#include "Servo.h"
#include "color.h"
#include "mbed.h"
#include "platform/mbed_thread.h"
#include <string>
#include <MQTTClientMbedOs.h>
#include "TextLCD.h"
#include "rohm-sensor-hal/rohm-sensor-hal/rohm_hal.h"       //mbed.h, types, DEBUG_print*
#include "rohm-sensor-hal/rohm-sensor-hal/I2CCommon.h"

#include "rohm-rpr0521/rohm-rpr0521/rpr0521_driver.h"
#include "rohm-rpr0521/rohm-rpr0521/rpr0521.h"

// Blinking rate in milliseconds    
#define BLINKING_RATE_MS    
                                                500
int salji_boju=0;
Serial pc(USBTX,USBRX);
InterruptIn button(USER_BUTTON);
int arrivedcount = 0;
TCPSocket socket;
MQTTClient client(&socket);
MQTT::Message message;
int button_pressed=0;

Timeout T3;

char* topic_sub = "PMK_industrija/micro4/#";
char* topic_pub = "PMK_industrija/micro1/proxy3";
char* topic_pub2 = "PMK_industrija/micro1/color3";
char* topic_pub1 = "PMK_industrija/micro1/echo/4";
Servo servo3(D7);


WiFiInterface *wifi;

TextLCD lcd(D3,D4,D13,D12,D11,D10);
DigitalOut vdd(A5);

volatile int mems_event = 0;
uint32_t previous_tick = 0;
uint32_t current_tick = 0;
uint8_t high = 0, low = 0;
float temperature = 0.0f;
char buffer[32];

static char *print_double(char *str, double v, int decimalDigits = 2)
{
    int i = 1;
    int intPart, fractPart;
    int len;
    char *ptr;
 
    /* prepare decimal digits multiplicator */
    for (; decimalDigits != 0; i *= 10, decimalDigits--);
 
    /* calculate integer & fractinal parts */
    intPart = (int)v;
    fractPart = (int)((v - (double)(int)v) * i);
 
    /* fill in integer part */
    sprintf(str, "%i.", intPart);
 
    /* prepare fill in of fractional part */
    len = strlen(str);
    ptr = &str[len];
 
    /* fill in leading fractional zeros */
    for (i /= 10; i > 1; i /= 10, ptr++) {
        if (fractPart >= i) {
            break;
        }
        *ptr = '0';
    }
 
    /* fill in (rest of) fractional part */
    sprintf(ptr, "%i", fractPart);
 
    return str;
}

const char *sec2str(nsapi_security_t sec)
{
    switch (sec) {
        case NSAPI_SECURITY_NONE:
            return "None";
        case NSAPI_SECURITY_WEP:
            return "WEP";
        case NSAPI_SECURITY_WPA:
            return "WPA";
        case NSAPI_SECURITY_WPA2:
            return "WPA2";
        case NSAPI_SECURITY_WPA_WPA2:
            return "WPA/WPA2";
        case NSAPI_SECURITY_UNKNOWN:
        default:
            return "Unknown";
    }
}

int scan_demo(WiFiInterface *wifi)
{
    WiFiAccessPoint *ap;
    printf("Scan:\n");
    int count = wifi->scan(NULL,0);
    if (count <= 0) {
        printf("scan() failed with return value: %d\n", count);
        return 0;
    }
    /* Limit number of network arbitrary to 15 */
    count = count < 15 ? count : 15;
    ap = new WiFiAccessPoint[count];
    count = wifi->scan(ap, count);
    if (count <= 0) {
        printf("scan() failed with return value: %d\n", count);
        return 0;
    }
    for (int i = 0; i < count; i++) {
        printf("Network: %s secured: %s BSSID: %hhX:%hhX:%hhX:%hhx:%hhx:%hhx RSSI: %hhd Ch: %hhd\n", ap[i].get_ssid(),
               sec2str(ap[i].get_security()), ap[i].get_bssid()[0], ap[i].get_bssid()[1], ap[i].get_bssid()[2],
               ap[i].get_bssid()[3], ap[i].get_bssid()[4], ap[i].get_bssid()[5], ap[i].get_rssi(), ap[i].get_channel());
    }
    printf("%d networks available.\n", count);
    delete[] ap;
    return count;
}

void messageArrived(MQTT::MessageData& md)
{
    MQTTString &topic = md.topicName;
    string topic_name = topic.lenstring.data;
    printf("Topic name %d : %s\r\n",topic.lenstring.len,topic_name.c_str() );
    MQTT::Message &message = md.message;
    printf("Message arrived: qos %d, retained %d, dup %d, packetid %d\r\n", message.qos, message.retained, message.dup, message.id);
    printf("Payload %.*s\r\n", message.payloadlen, (char*)message.payload);
    char* poruka = (char*)message.payload;
    if(topic_name.find("servo3")!=std::string::npos) {
         T3.detach();
         printf("AKTIVIRAN SERVO3\n"); 
         for(float p=0; p<1.0; p += 0.1) {
        servo3 = p;
        
        }
        wait(2);
        for(float p=1.0; p>0.0; p -= 0.1) {
        servo3 = p;
        
        }
        sprintf(buf, "servo3-AKTIVIRAN \r\n");
            message.qos = MQTT::QOS0;
            message.retained = false;
            message.dup = false;
            message.payload = (void*)buf;
            message.payloadlen = strlen(buf)+1;
            client.publish(topic_pub1, message); 
    }
    else if(topic_name.find("color3")!=std::string::npos){
    salji_boju=1;
    }
    
    
    else if(topic_name.find("LCD")!=std::string::npos){
        
        lcd.cls();
        lcd.printf("%s ",poruka);
        
        
        }
        else if(topic_name.find("echo")!=std::string::npos){
            if(poruka.find("connect")!=std::string::npos){
            fleg_start=1;
            sprintf(buf, "echo4 \r\n");
            message.qos = MQTT::QOS0;
            message.retained = false;
            message.dup = false;
            message.payload = (void*)buf;
            message.payloadlen = strlen(buf)+1;
            client.publish(topic_pub1, message); 
            }
            else if(poruka.find("echo")!=std::string::npos){
                T3.detach();
            }
            }
    
    ++arrivedcount;
}


void buttonFunction() {    
    button_pressed=1;   
}

void rpr0521_print_one_value(){
    bool error;
    uint16_t data[3];
    
    error = rpr0521_read_data(&data[0]);
    if (!error) {
        printf("PS[%4u], Als0[%4u], Als1[%4u]\n\r", data[0], data[1], data[2]);
        }
    else {
        printf("\n\r");
        }
}
int main()
{   vdd=1;
    // Initialise the digital pin LED1 as an output
    bool error;
    //ColorSensor cs(PA_5,PA_6,PA_7,PB_6,PC_7);
    uint16_t dataProx[3];
    DigitalOut led(LED1); 
    button.rise(&buttonFunction);
    const char* hostname = "broker.mqttdashboard.com";
    int port = 1883;    
    
    I2CCommonBegin();
    rpr0521_wait_until_found();
    pc.printf("\nSensor found.\n\r");
    rpr0521_initial_setup();
    
    wifi = WiFiInterface::get_default_instance();
    if (!wifi) {
        printf("ERROR: No WiFiInterface found.\n");
        return -1;
    }

    int count = scan_demo(wifi);
    if (count == 0) {
        printf("No WIFI APs found - can't continue further.\n");
        return -1;
    }

    printf("\nConnecting to %s...\n", MBED_CONF_APP_WIFI_SSID);
    int ret = wifi->connect(MBED_CONF_APP_WIFI_SSID, MBED_CONF_APP_WIFI_PASSWORD, NSAPI_SECURITY_WPA_WPA2);
    if (ret != 0) {
        printf("\nConnection error: %d\n", ret);
        return -1;
    }

    printf("Success\n\n");
    printf("MAC: %s\n", wifi->get_mac_address());
    printf("IP: %s\n", wifi->get_ip_address());
    printf("Netmask: %s\n", wifi->get_netmask());
    printf("Gateway: %s\n", wifi->get_gateway());
    printf("RSSI: %d\n\n", wifi->get_rssi());

    socket.open(wifi);
    socket.connect(hostname, port);
    
    int rc=0;
    
    MQTTPacket_connectData data = MQTTPacket_connectData_initializer;
    data.MQTTVersion = 3;
    data.clientID.cstring = "PMK-client4";
    //data.username.cstring = "testuser";
    //data.password.cstring = "testpassword";
    
    if ((rc = client.connect(data)) != 0)
        printf("rc from MQTT connect is %d\r\n", rc);

    
    if ((rc = client.subscribe(topic_sub, MQTT::QOS2, messageArrived)) != 0)
        printf("rc from MQTT subscribe is %d\r\n", rc);    
    
    
    
    while (true) {
        led = !led;
        thread_sleep_for(BLINKING_RATE_MS);
     
    
        error = rpr0521_read_data(&dataProx[0]);
        if (!error){
            T3.attach(&interuptT3,5);
            if(dataProx[0] > 50 && !fleg_proxy) {
                fleg_proxy1=1; 
                printf("Pristigao je cep na lokaciju O.O O:'( \r\n ");
                char buf[100];
                sprintf(buf, "proxy3-AKTIV PS = %d",dataProx[0]);
                message.qos = MQTT::QOS0;
                message.retained = false;
                message.dup = false;
                message.payload = (void*)buf;
                message.payloadlen = strlen(buf)+1;
                client.publish(topic_pub, message);    
                //salji_boju=1;
                }
                else{fleg_proxy=0;}
        
        }
        if (salji_boju==1) {
            T3.detach();
            //salji_boju=0;    
            //printf("Publishing data\r\n");    
            // QoS 0
            //char buf[100];
            //float treshold=0.1;
            
            //int Boja[3]={cs.getRed(), cs.getGreen(),cs.getBlue()};
            
            //while(Boja[0]<30 && Boja[1]<30 && Boja[2]<30){
                //wait(1);
                //Boja[0]=cs.getRed();
                //Boja[1]=cs.getGreen();
                //Boja[2]=cs.getBlue();
                //printf("LOSE MERENJE \r\n");
                //printf("R:%d , G:%d , B:%d",Boja[0],Boja[1],Boja[2]);
              //  }
            //int strongCol=max(Boja[0],max(Boja[1],Boja[2]));
            //float BojaScal[3];
            //BojaScal[0]=Boja[0]/(strongCol*1.0);
            //BojaScal[1]=Boja[1]/(strongCol*1.0);
            //BojaScal[2]=Boja[2]/(strongCol*1.0);        
            
            //if(BojaScal[1]<r1[1]+treshold && BojaScal[1]>r1[1]-treshold && BojaScal[2]<r1[2]+treshold && BojaScal[0]>r1[0]-treshold && BojaScal[0]<r1[0]+treshold && BojaScal[2]>r1[2]-treshold ) {
              //  sprintf(buf, "RGB: CRVENA \r\n");}
            //else if(BojaScal[1]<g1[1]+treshold && BojaScal[1]>g1[1]-treshold && BojaScal[2]<g1[2]+treshold && BojaScal[0]>g1[0]-treshold && BojaScal[0]<g1[0]+treshold && BojaScal[2]>g1[2]-treshold ) {
                //sprintf(buf, "RGB: ZELENA \r\n");}
                //else if(BojaScal[1]<b1[1]+treshold && BojaScal[1]>b1[1]-treshold && BojaScal[2]<b1[2]+treshold && BojaScal[0]>b1[0]-treshold && BojaScal[0]<b1[0]+treshold && BojaScal[2]>b1[2]-treshold ) {
                //sprintf(buf, "RGB: PLAVA \r\n");}
              //  else { sprintf(buf, "RGB: NEKA DRUGA BOJA \r\n");}
            
            //printf("R: %.3f", BojaScal[0]);
            //printf("G: %.3f", BojaScal[1]);
           // printf("B: %.3f\r\n", BojaScal[2]);
            
            //printf(" Crvena R: %.3f", r1[0]);
            //printf("G: %.3f", r1[1]);
            //printf("B: %.3f\r\n", r1[2]);
            
        
            //message.qos = MQTT::QOS0;
            //message.retained = false;
            //message.dup = false;
            //message.payload = (void*)buf;
            //message.payloadlen = strlen(buf)+1;
            //client.publish(topic_pub, message);
            T3.attach(&interruptT3,5);
        salji_boju=0;    
        }
        
        
        if (button_pressed==1) {
            button_pressed=0;    
            printf("Publishing data\r\n");    
            // QoS 0
            char buf[100];
          
            //sprintf(buf, "RGB: %7s C\r\n", print_double(buffer, cs.getRed()*100000000+cs.getGreen()*10000+cs.getBlue()));
            
           //message.qos = MQTT::QOS0;
            //message.retained = false;
            //message.dup = false;
            //message.payload = (void*)buf;
            //message.payloadlen = strlen(buf)+1;
            //client.publish(topic_pub, message);
            
        }
       // printf("Yielding"); 
        client.yield(1000);
        //printf(" -> Yielded\r\n"); 
    }
}