diff options
| -rw-r--r-- | client/ui.c | 2 | ||||
| -rw-r--r-- | client/ui_dirc.c | 8 | ||||
| -rw-r--r-- | robot/mode_chrg.c | 11 | ||||
| -rw-r--r-- | robot/mode_grid.c | 33 | ||||
| -rw-r--r-- | robot/mode_grid.h | 4 | ||||
| -rw-r--r-- | robot/sercomm.c | 15 | ||||
| -rw-r--r-- | shared/protocol.h | 1 | 
7 files changed, 29 insertions, 45 deletions
| diff --git a/client/ui.c b/client/ui.c index cdf2f3b..6bc0986 100644 --- a/client/ui.c +++ b/client/ui.c @@ -87,7 +87,7 @@ void w2_ui_paint_statusbar() {  	sprintf(temp, "(%s)", g_w2_state.info.build_str);  	w2_wmvaddstr(g_w2_ui_pad_statusbar, 0, g_w2_ui_width / 2 - strlen(temp) / 2, temp); -	sprintf(temp, "%s %i%%", W2_UI_BATT_STAT_BATTERY, g_w2_state.battery_level); +	sprintf(temp, "%s %imv", W2_UI_BATT_STAT_BATTERY, g_w2_state.info.battery_mv);  	w2_wmvaddstr(g_w2_ui_pad_statusbar, 0, g_w2_ui_width - strlen(temp), temp);  	sprintf(temp, "[%s]", g_w2_mode_strings[g_w2_state.mode]); diff --git a/client/ui_dirc.c b/client/ui_dirc.c index db91661..4e864d5 100644 --- a/client/ui_dirc.c +++ b/client/ui_dirc.c @@ -93,10 +93,10 @@ void w2_ui_dirc_paint(int left, int right) {  }  void w2_ui_onkey_dirc(int ch) { -	if (ch == 'e' || ch == 'w') g_w2_lf++; -	if (ch == 'd' || ch == 's') g_w2_lb++; -	if (ch == 'q' || ch == 'w') g_w2_rf++; -	if (ch == 'a' || ch == 's') g_w2_rb++; +	if (ch == 'e' || ch == 'w' || ch == KEY_UP || ch == KEY_RIGHT) g_w2_lf++; +	if (ch == 'd' || ch == 's' || ch == KEY_DOWN) g_w2_lb++; +	if (ch == 'q' || ch == 'w' || ch == KEY_UP || ch == KEY_LEFT) g_w2_rf++; +	if (ch == 'a' || ch == 's' || ch == KEY_DOWN) g_w2_rb++;  	if (ch == ' ') w2_send_mode(W2_M_DIRC);  } diff --git a/robot/mode_chrg.c b/robot/mode_chrg.c index 7cf9a9c..a5910f2 100644 --- a/robot/mode_chrg.c +++ b/robot/mode_chrg.c @@ -16,16 +16,12 @@ void w2_short_drive() {  void w2_home() {  	set_motors(0, 0);  	delay_ms(150); -	clear(); -	print("CHARGING");  	set_motors(30, 30);  	delay_ms(600);  	set_motors(0, 0); -	play_frequency(300, 500, 7);  	delay_ms(600);  	g_w2_position		= read_line(g_w2_sensors, IR_EMITTERS_ON);  	g_w2_charged_status = 1; -	clear();  	delay_ms(2000);  } @@ -42,8 +38,6 @@ void w2_charge_cross_walk() {  		g_w2_position = read_line(g_w2_sensors, IR_EMITTERS_ON);  		if (g_w2_sensors[2] > 100 || g_w2_sensors[3] > 100 || g_w2_sensors[1] > 100) {  			set_motors(0, 0); -			// clear(); -			print("WALK");  			g_w2_transition++;  			if (g_w2_transition == 3) { // TODO: document g_w2_transition  				set_motors(40, 40); @@ -65,9 +59,6 @@ void w2_charge_cross_walk() {  void w2_mode_chrg() {  	unsigned int last_proportional = 0;  	long integral				   = 0; -	// initialize(); -	clear(); -	print("CHARGE");  	while (1) {  		// Get the position of the line.  Note that we *must* provide @@ -116,13 +107,11 @@ void w2_mode_chrg() {  			w2_maze_rotation_full();  			w2_short_drive();  		} else if (g_w2_sensors[0] >= 500 && g_w2_sensors[1] >= 200 && g_w2_sensors[4] < 100) { -			clear();  			w2_maze_rotation_half_left();  		}  		else if (g_w2_sensors[0] >= 500 && g_w2_sensors[1] >= 250 && g_w2_sensors[2] >= 500 &&  				 g_w2_sensors[3] >= 250 && g_w2_sensors[4] >= 500) { -			clear();  			w2_maze_rotation_half_left();  		} else {  			if (power_difference < 0 && diff --git a/robot/mode_grid.c b/robot/mode_grid.c index d493a1a..4364b67 100644 --- a/robot/mode_grid.c +++ b/robot/mode_grid.c @@ -7,29 +7,17 @@ int g_w2_order_number;  int g_w2_maze_status = 0; - -//product coordinates -w2_s_grid_coordinate g_w2_order[4] = { +w2_s_grid_coordinate g_w2_order[16] = {  	{0, 0}, -	{1, 1}, -	{2, 2}, -	{3, 3}, +	{3, 4}, +	{2, 1}, +	{4, 2},  }; +unsigned int g_w2_order_index = 4;  w2_s_grid_coordinate g_w2_location;  w2_s_grid_coordinate g_w2_destination;  w2_e_orientation g_w2_direction; - -//give coordinates for grid -void w2_location_message() { -	clear(); -	print_long(g_w2_location.x); -	print(","); -	print_long(g_w2_location.y); -	delay(200); -} - -  int g_w2_detection = 0;  int g_w2_transition;	//used for the crosswalk, used to count black lines  char g_w2_x_location = 0; //current location in grid @@ -45,8 +33,6 @@ void w2_crosswalk_stroll() {  		g_w2_position = read_line(g_w2_sensors, IR_EMITTERS_ON);  		if (g_w2_sensors[2] > 100 || g_w2_sensors[3] > 100 || g_w2_sensors[1] > 100) {  			set_motors(0, 0); -			clear(); -			print("WALK");  			g_w2_transition++;  			if (g_w2_transition == 3) {  				set_motors(40, 40); @@ -219,9 +205,6 @@ void w2_turn_east() {  //signals when the product is picked  void w2_arrived_message() {  	if (g_w2_location.x == g_w2_destination.x && g_w2_location.y == g_w2_destination.y) { -		clear(); -		print("PRODUCT"); -		print_long(g_w2_order_number);  		play_frequency(400, 500, 7);  		delay(500);  	} @@ -273,20 +256,17 @@ void w2_go_to_y() {  //main function for grid mode  void w2_mode_grid() {  	set_motors(0, 0); -	clear(); -	print("GRID");  	delay(500);  	w2_begin_location();  	// TODO: orders read here -	for (int i = 0; i < 4; i++) { +	for (int i = 0; i < g_w2_order_index; i++) {  		g_w2_order_number = i + 1;  		g_w2_destination.x = g_w2_order[i].x;  		g_w2_destination.y = g_w2_order[i].y; -		w2_location_message();  		delay(1000);  		w2_go_to_x();  		w2_go_to_y(); @@ -294,7 +274,6 @@ void w2_mode_grid() {  	}  	w2_end_destination(); -	w2_location_message();  	delay(1000);  	w2_go_to_y();  	w2_go_to_x(); diff --git a/robot/mode_grid.h b/robot/mode_grid.h index 2df0d33..408a8ff 100644 --- a/robot/mode_grid.h +++ b/robot/mode_grid.h @@ -22,4 +22,6 @@ typedef struct {  	int y;  } w2_s_grid_coordinate; -extern w2_s_grid_coordinate g_w2_order[4]; +extern w2_s_grid_coordinate g_w2_order[16]; +extern unsigned int g_w2_order_index; + diff --git a/robot/sercomm.c b/robot/sercomm.c index efad449..d12fcca 100644 --- a/robot/sercomm.c +++ b/robot/sercomm.c @@ -4,6 +4,7 @@  #include "../shared/bin.h"  #include "../shared/errcatch.h"  #include "../shared/serial_parse.h" +#include "mode_grid.h"  #include "hypervisor.h"  #include "io.h"  #include "mode_dirc.h" @@ -117,7 +118,18 @@ void w2_cmd_dirc_rx(w2_s_bin *data) {  void w2_cmd_cord_rx(w2_s_bin *data) { return; } -void w2_cmd_bomd_rx(w2_s_bin *data) { return; } +// #include <stdio.h> +void w2_cmd_bomd_rx(w2_s_bin *data) { +	/* W2_CAST_BIN(w2_s_cmd_bomd_rx, data, req); + +	char buf[32]; +	clear(); +	sprintf(buf, "%lu, %lu", req->position % W2_MAP_DEFAULT_WIDTH, req->position / W2_MAP_DEFAULT_WIDTH); +	print(buf); +	g_w2_order[g_w2_order_index].x = req->position % W2_MAP_DEFAULT_WIDTH; +	g_w2_order[g_w2_order_index].y = req->position / W2_MAP_DEFAULT_WIDTH; +	g_w2_order_index++; */ +}  void w2_cmd_sres_rx(w2_s_bin *data) {  	W2_CAST_BIN(w2_s_cmd_sres_rx, data, req); @@ -149,6 +161,7 @@ void w2_cmd_info_rx(w2_s_bin *data) {  	res_msg->mode_ms	 = (uint8_t)g_w2_hypervisor_ema_mode_ms;  	res_msg->uptime_s	 = w2_bin_hton32((uint32_t)(g_w2_hypervisor_uptime_ms / 1e3));  	res_msg->mode		 = g_w2_mode_history[g_w2_mode_history_index]; +	res_msg->battery_mv  = w2_bin_hton16(read_battery_millivolts());  	w2_sercomm_append_msg(res_bin);  	free(res_bin); diff --git a/shared/protocol.h b/shared/protocol.h index 5e1a12b..ba16d56 100644 --- a/shared/protocol.h +++ b/shared/protocol.h @@ -146,6 +146,7 @@ typedef struct {  	uint8_t mode_ms;  	uint32_t uptime_s;  	uint8_t mode; +	uint16_t battery_mv;  } w2_s_cmd_info_tx;  typedef struct { |