trying to use cairo gtk and ros at the same time
I am having problems compiling this code, can someone give me a hint on how to solve it.
thanks in advance. Rodrigo
#include "ros/ros.h"
#include "std_msgs/Int16.h"
#include "std_msgs/Float64.h"
#include "std_msgs/Float32.h"
#include "pubsub/RaposaWheels.h"
#include "pubsub/main.h"
#include <geometry_msgs/Quaternion.h>
#include <std_msgs/Header.h>
#include <iostream>
#include <sstream>
#include <cairo.h>
#include <gtk/gtk.h>
#include <string.h>
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
typedef struct orien_ang{
float x;
float y;
}ang;
GtkWidget* GlobalTable;
GtkWidget* darea1;
GtkWidget* darea2;
cairo_t* cr1;
cairo_t* cr2;
double body_roll;
ang* Gorien;
//Funções para criar o desenho.
static void do_drawing(cairo_t *cr, double x, double y);
static void do_drawing2(cairo_t *cr, double broll);
//Função CallBack
void number_callback(const pubsub::main::ConstPtr& msg)
{
//ROS_INFO("Recieved msg [%f]",msg->pan);
//ROS_INFO("Recieved msg [%d]",msg->electronics_battery_mV);
body_roll = msg->body_roll;
cr1 = gdk_cairo_create (darea1->draw);
cr2 = gdk_cairo_create (darea2->draw);
do_drawing(cr1,(*Gorien).x, (*Gorien).y);
do_drawing2(cr2, body_roll);
}
static void do_drawing(cairo_t *cr, double x, double y)
{
double int_x, int_y;
double radius;
double inset;
double aux_ang1, aux_ang2, aux_ang3, aux_ang4;
int i;
int_x = draw_Wigth/2;
int_y = draw_height/2;
//Make remaining calculations before drawing
radius = draw_Wigth/3 - 5;
cairo_set_source_rgb(cr, 0, 0, 0); //Black
cairo_stroke(cr);
//Ticks
i = 0;
while (i < 36){
cairo_save(cr);
inset = (1.0/18)*radius;
cairo_set_line_width(cr, 0.5 * cairo_get_line_width(cr));
//cairo_set_line_width(cr, 0.5);
cairo_move_to(cr, int_x + (radius - inset)* cos(i * pi /18.0), int_y + (radius - inset)* sin(i * pi /18.0));
cairo_line_to(cr, int_x + radius* cos(i * pi/18.0), int_y + radius* sin(i * pi/18.0));
cairo_stroke(cr);
cairo_restore(cr);
i = i + 1;
}
i = 1;
while ( i < 9)
{
cairo_save(cr);
inset = 0.15 * radius;
cairo_move_to(cr, int_x + (radius - inset) * cos(i * pi/4.0), int_y + (radius-inset)*sin(i * pi / 4.0));
cairo_line_to(cr, int_x + radius * cos(i * pi/4.0), int_y + radius*sin(i * pi / 4.0));
cairo_stroke(cr);
cairo_restore(cr);
i = i + 1;
}
//Drawing main line
cairo_save(cr);
cairo_set_line_width(cr, 4 * cairo_get_line_width(cr));
cairo_set_source_rgb(cr,0, 1, 0); //Green
cairo_move_to(cr, int_x + radius*0.6*( -1* cos((*Gorien).x)), int_y + radius*0.6*sin((*Gorien).x));
cairo_line_to(cr, int_x + radius*0.6*cos((*Gorien).x), int_y + radius*0.6*(-1*sin((*Gorien).x)));
cairo_close_path(cr);
cairo_stroke(cr);
cairo_restore(cr);
//Drawing secondary Lines
cairo_save(cr);
cairo_set_line_width(cr, 4 * cairo_get_line_width(cr));
cairo_set_source_rgb(cr, 0, 1, 0); //Green
//Calculos para determinar os pontos iniciais da 1º linha
aux_ang1 = (int_x + radius*0.6*cos((*Gorien).x));
aux_ang2 = (aux_ang1 + 0.2*radius*sin((*Gorien).x));
aux_ang3 = (int_y - radius*0.6*sin((*Gorien).x));
aux_ang4 = (aux_ang3 + 0.2*radius*cos((*Gorien).x));
cairo_move_to(cr, aux_ang2, aux_ang4);
//Calculos para determinar os pontos finais da 1º linha
aux_ang1 = (int_x + radius*0.6*cos((*Gorien).x));
aux_ang2 = (aux_ang1 - 0.2*radius*sin((*Gorien).x));
aux_ang3 = (int_y - radius*0.6*sin((*Gorien).x));
aux_ang4 = (aux_ang3 - 0.2*radius*cos((*Gorien).x));
cairo_line_to(cr, aux_ang2, aux_ang4);
cairo_close_path(cr);
cairo_stroke(cr);
cairo_restore(cr);
cairo_save(cr);
cairo_set_line_width(cr, 4 * cairo_get_line_width(cr));
cairo_set_source_rgb(cr, 0, 1, 0); //Green
//Calculos para determinar os pontos iniciais da 2º linha
aux_ang1 = (int_x - radius*0.6*cos((*Gorien).x));
aux_ang2 = (aux_ang1 + 0.2*radius*sin((*Gorien).x));
aux_ang3 = (int_y + radius*0.6*sin((*Gorien).x));
aux_ang4 = (aux_ang3 + 0.2*radius*cos((*Gorien).x));
cairo_move_to(cr, aux_ang2, aux_ang4);
//Calculos para determinar os pontos finais da 2º linha
aux_ang1 = (int_x - radius*0.6*cos((*Gorien).x));
aux_ang2 = (aux_ang1 - 0.2*radius*sin((*Gorien).x));
aux_ang3 = (int_y + radius*0.6*sin((*Gorien).x));
aux_ang4 = (aux_ang3 - 0.2*radius*cos((*Gorien).x));
cairo_line_to(cr, aux_ang2, aux_ang4);
cairo_close_path(cr);
cairo_stroke(cr);
cairo_restore(cr);
}
static void do_drawing2(cairo_t *cr, double broll)
{
char angle[10];
cairo_set_source_rgb(cr, 0, 0, 0);
cairo_set_font_size(cr, 14);
cairo_move_to(cr,20,20);
cairo_show_text(cr,"heading");
snprintf(angle, 20, "%4.2f%s", (*Gorien).x*180/pi, "º");
cairo_move_to(cr,20,60);
cairo_show_text(cr,angle);
}
int main(int argc, char **argv)
{
//Inicialização do GTK
GtkWidget *window;
gtk_init(&argc, &argv);
window = gtk_window_new(GTK_WINDOW_TOPLEVEL);
Gorien=(ang *)malloc(sizeof(ang));
(*Gorien).x = 1;
(*Gorien).y = 12;
//Using a table for drawning this widget.
darea1 = gtk_drawing_area_new();
darea2 = gtk_drawing_area_new();
GlobalTable = gtk_grid_new ();
gtk_grid_attach(GTK_GRID(GlobalTable), darea1, 1, 1, 1, 1);
gtk_grid_attach_next_to (GTK_GRID(GlobalTable), darea2, darea1, GTK_POS_RIGHT, 1, 1);
gtk_container_add(GTK_CONTAINER(window), GlobalTable);
gtk_widget_set_size_request(darea1, draw_Wigth, draw_height);
gtk_widget_set_size_request(darea2, draw_Wigth, draw_height);
// g_signal_connect(G_OBJECT(darea1), "draw",
// G_CALLBACK(on_draw_event), NULL);
// g_signal_connect(G_OBJECT(darea2), "draw",
// G_CALLBACK(on_draw_event2), NULL);
// g_signal_connect(window, "destroy",
// G_CALLBACK(gtk_main_quit), NULL);
gtk_window_set_position(GTK_WINDOW(window), GTK_WIN_POS_CENTER);
gtk_window_set_default_size(GTK_WINDOW(window), 360, 180);
gtk_window_set_title(GTK_WINDOW(window), "GTK window");
gtk_widget_show_all(window);
gtk_main();
//Initializing ROS node with a name of demo_topic_subscriber
ros::init(argc, argv,"demo_msg_subscriber");
//Created a nodehandle object
ros::NodeHandle node_obj;
//Create a publisher object
ros::Subscriber number_subscriber = node_obj.subscribe("/republished/raposang/telemetry",10,number_callback);
//Spinning the node
ros::spin();
return 0;
}
Asked by Rodrigo Lourenço on 2018-07-12 08:55:37 UTC
Comments