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");
}
}