Галька смотреть сбой на выходе
Я делаю очень простой циферблат моего Pebble. У меня есть три текстовых слоя. Один показывает время, вкл показывает дату, а другой показывает индикатор прогресса за день.
Всякий раз, когда я нажимаю кнопку, чтобы перейти в меню или перейти к другому циферблату, приложение вылетает. Я думал, что, возможно, я не разрушал что-то в процессе деинитита, но я дважды проверил и ничего не могу найти. Вот код (извините за беспорядок, я был в процессе отладки чего-то еще):
#include <pebble.h>
static Window *s_main_window;
static TextLayer *s_time_layer;
static TextLayer *s_date_layer;
static TextLayer *s_progress_layer;
static void update_time() {
// Get a tm structure
time_t temp = time(NULL);
struct tm *tick_time = localtime(&temp);
// Create a long-lived buffer
static char buffer[] = "00:00";
static char date_buffer[] = "00/00/00";
static char progress_buffer[24];
int hour = 0;
if(tick_time->tm_hour == 0) { hour = 1; }
else if(tick_time->tm_hour == 1) { hour = 1; }
else if(tick_time->tm_hour == 2) { hour = 1; }
else if(tick_time->tm_hour == 3) { hour = 2; }
else if(tick_time->tm_hour == 4) { hour = 2; }
else if(tick_time->tm_hour == 5) { hour = 3; }
else if(tick_time->tm_hour == 6) { hour = 3; }
else if(tick_time->tm_hour == 7) { hour = 4; }
else if(tick_time->tm_hour == 8) { hour = 4; }
else if(tick_time->tm_hour == 9) { hour = 5; }
else if(tick_time->tm_hour == 10) { hour = 5; }
else if(tick_time->tm_hour == 11) { hour = 6; }
else if(tick_time->tm_hour == 12) { hour = 6; }
else if(tick_time->tm_hour == 13) { hour = 7; }
else if(tick_time->tm_hour == 14) { hour = 7; }
else if(tick_time->tm_hour == 15) { hour = 8; }
else if(tick_time->tm_hour == 16) { hour = 8; }
else if(tick_time->tm_hour == 17) { hour = 9; }
else if(tick_time->tm_hour == 18) { hour = 9; }
else if(tick_time->tm_hour == 19) { hour = 10; }
else if(tick_time->tm_hour == 20) { hour = 10; }
else if(tick_time->tm_hour == 21) { hour = 11; }
else if(tick_time->tm_hour == 22) { hour = 11; }
else if(tick_time->tm_hour == 23) { hour = 12; }
else if(tick_time->tm_hour == 24) { hour = 12; }
const char src1[] = "•";
const char src2[] = "• •";
const char src3[] = "• • •";
const char src4[] = "• • • •";
const char src5[] = "• • • • •";
const char src6[] = "• • • • • •";
const char src7[] = "• • • • • • •";
const char src8[] = "• • • • • • • •";
const char src9[] = "• • • • • • • • •";
const char src10[] = "• • • • • • • • • •";
const char src11[] = "• • • • • • • • • • •";
const char src12[] = "• • • • • • • • • • • •";
switch(hour){
case 1:
strcpy(progress_buffer, src1);
break;
case 2:
strcpy(progress_buffer, src2);
break;
case 3:
strcpy(progress_buffer, src3);
break;
case 4:
strcpy(progress_buffer, src4);
break;
case 5:
strcpy(progress_buffer, src5);
break;
case 6:
strcpy(progress_buffer, src6);
break;
case 7:
strcpy(progress_buffer, src7);
break;
case 8:
strcpy(progress_buffer, src8);
break;
case 9:
strcpy(progress_buffer, src9);
break;
case 10:
strcpy(progress_buffer, src10);
break;
case 11:
strcpy(progress_buffer, src10);
break;
case 12:
strcpy(progress_buffer, src10);
break;
default:
strcpy(progress_buffer, src1);
break;
}
// Write the current hours and minutes into the buffer
if(clock_is_24h_style() == true) {
// Use 24 hour format
strftime(buffer, sizeof("00:00"), "%H:%M", tick_time);
strftime(date_buffer, sizeof("00/00/00"), "%D", tick_time);
} else {
// Use 12 hour format
strftime(buffer, sizeof("00:00"), "%I:%M", tick_time);
strftime(date_buffer, sizeof("00/00/00"), "%D", tick_time);
}
if (!clock_is_24h_style() && (buffer[0] == '0')) {
memmove(buffer, &buffer[1], sizeof(buffer) - 1);
}
// Display this time on the TextLayer
text_layer_set_text(s_time_layer, buffer);
text_layer_set_text(s_date_layer, date_buffer);
text_layer_set_text(s_progress_layer, progress_buffer);
}
static void tick_handler(struct tm *tick_time, TimeUnits units_changed) {
update_time();
}
static void main_window_load(Window *window) {
window_set_background_color(s_main_window, GColorBlack);
// Create time TextLayer
s_time_layer = text_layer_create(GRect(0, 45, 144, 55));
text_layer_set_background_color(s_time_layer, GColorBlack);
text_layer_set_text_color(s_time_layer, GColorWhite);
// Improve the layout to be more like a watchface
text_layer_set_font(s_time_layer, fonts_get_system_font(FONT_KEY_BITHAM_42_BOLD));
text_layer_set_text_alignment(s_time_layer, GTextAlignmentCenter);
// Add it as a child layer to the Window's root layer
layer_add_child(window_get_root_layer(window), text_layer_get_layer(s_time_layer));
// Create date TextLayer
s_date_layer = text_layer_create(GRect(0, 95, 144, 40));
text_layer_set_background_color(s_date_layer, GColorBlack);
text_layer_set_text_color(s_date_layer, GColorWhite);
// Improve the layout to be more like a watchface
text_layer_set_font(s_date_layer, fonts_get_system_font(FONT_KEY_GOTHIC_24_BOLD));
text_layer_set_text_alignment(s_date_layer, GTextAlignmentCenter);
// Add it as a child layer to the Window's root layer
layer_add_child(window_get_root_layer(window), text_layer_get_layer(s_date_layer));
// Create progress TextLayer
s_progress_layer = text_layer_create(GRect(0, 143, 144, 35));
text_layer_set_background_color(s_progress_layer, GColorBlack);
text_layer_set_text_color(s_progress_layer, GColorWhite);
// Improve the layout to be more like a watchface
text_layer_set_font(s_progress_layer, fonts_get_system_font(FONT_KEY_GOTHIC_14));
text_layer_set_text_alignment(s_progress_layer, GTextAlignmentCenter);
// Add it as a child layer to the Window's root layer
layer_add_child(window_get_root_layer(window), text_layer_get_layer(s_progress_layer));
// Make sure the time is displayed from the start
update_time();
}
static void main_window_unload(Window *window) {
// Destroy TextLayer
text_layer_destroy(s_time_layer);
text_layer_destroy(s_date_layer);
text_layer_destroy(s_progress_layer);
}
static void init() {
// Create main Window element and assign to pointer
s_main_window = window_create();
// Set handlers to manage the elements inside the Window
window_set_window_handlers(s_main_window, (WindowHandlers) {
.load = main_window_load,
.unload = main_window_unload
});
// Show the Window on the watch, with animated=true
window_stack_push(s_main_window, true);
// Register with TickTimerService
tick_timer_service_subscribe(MINUTE_UNIT, tick_handler);
}
static void deinit() {
// Destroy Window
window_destroy(s_main_window);
tick_timer_service_unsubscribe();
}
int main(void) {
init();
app_event_loop();
deinit();
}
2 ответа
Я увеличил размер буфера progress_buffer, и перестал сбой наблюдатель. Я нашел значение как минимум 37 для кода, чтобы работать. Я предполагаю, что буфер должен хранить больше, чем точки, например, пробелы.
(Я не могу понять, почему это исправляет это, или почему это терпит крах сначала, но...)
Если вы удалите window_destroy(s_main_window);
от твоего deinit
функционировать больше не будет.