* Dolphin Animation Refactoring, part 1 * Remove animations from desktop * Remove excess, first start * Split animation_manager with callbacks * allocate view inside animation_view * Work on ViewComposed * Draw white rectangles under bubble corners * Fix bubbles sequence * RPC: remove obsolete include "status.pb.h" * Add animations manifest decoding * Flipper file: add strict mode * FFF: Animation structures parsing * Assembling structure of animation * Lot of view fixes: Add multi-line bubbles Add support for passive bubbles (frame_order values starts from passive now) Add hard-coded delay (active_shift) for active state enabling Fix active state handling Fix leaks Fix parsing uncorrect bubble_animation meta file Fix bubble rules of showing * Animation load/unload & view freeze/unfreeze * Blocking & system animations, fixes: View correct activation Refactoring + blocking animation Freeze first passive/active frames Many insert/eject SD tests fixes Add system animations Add Loader events app started/finished Add system no_sd animation * Assets: dolphin packer. Scripts: minor refactoring. * Desktop: update logging tags. Scripts: add metadata to dolphin bundling process, extra sorting for fs traversing. Make: phony assets rules. * Github: rebuild assets on build * Docker: add missing dependencies for assets compilation * Docker: fix run command syntax * ReadMe: update naming rules with link to source * Assets: recompile icons * Loader: add loader event * Desktop, Gui, Furi Core: const shenanigans macros Co-authored-by: Aleksandr Kutuzov <alleteam@gmail.com>
		
			
				
	
	
		
			62 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			62 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
#include "../desktop_i.h"
 | 
						|
#include "../views/desktop_lock_menu.h"
 | 
						|
#include <toolbox/saved_struct.h>
 | 
						|
#include <stdbool.h>
 | 
						|
 | 
						|
void desktop_scene_lock_menu_callback(DesktopEvent event, void* context) {
 | 
						|
    Desktop* desktop = (Desktop*)context;
 | 
						|
    view_dispatcher_send_custom_event(desktop->view_dispatcher, event);
 | 
						|
}
 | 
						|
 | 
						|
void desktop_scene_lock_menu_on_enter(void* context) {
 | 
						|
    Desktop* desktop = (Desktop*)context;
 | 
						|
 | 
						|
    LOAD_DESKTOP_SETTINGS(&desktop->settings);
 | 
						|
 | 
						|
    desktop_lock_menu_set_callback(desktop->lock_menu, desktop_scene_lock_menu_callback, desktop);
 | 
						|
    desktop_lock_menu_pin_set(desktop->lock_menu, desktop->settings.pincode.length > 0);
 | 
						|
    view_dispatcher_switch_to_view(desktop->view_dispatcher, DesktopViewLockMenu);
 | 
						|
}
 | 
						|
 | 
						|
bool desktop_scene_lock_menu_on_event(void* context, SceneManagerEvent event) {
 | 
						|
    Desktop* desktop = (Desktop*)context;
 | 
						|
    bool consumed = false;
 | 
						|
 | 
						|
    if(event.type == SceneManagerEventTypeCustom) {
 | 
						|
        switch(event.event) {
 | 
						|
        case DesktopLockMenuEventLock:
 | 
						|
            scene_manager_set_scene_state(
 | 
						|
                desktop->scene_manager, DesktopSceneLocked, DesktopLockedNoPin);
 | 
						|
            scene_manager_next_scene(desktop->scene_manager, DesktopSceneLocked);
 | 
						|
            consumed = true;
 | 
						|
            break;
 | 
						|
        case DesktopLockMenuEventPinLock:
 | 
						|
            if(desktop->settings.pincode.length > 0) {
 | 
						|
                furi_hal_rtc_set_flag(FuriHalRtcFlagLock);
 | 
						|
                furi_hal_usb_disable();
 | 
						|
                scene_manager_set_scene_state(
 | 
						|
                    desktop->scene_manager, DesktopSceneLocked, DesktopLockedWithPin);
 | 
						|
                scene_manager_next_scene(desktop->scene_manager, DesktopSceneLocked);
 | 
						|
            } else {
 | 
						|
                scene_manager_next_scene(desktop->scene_manager, DesktopScenePinSetup);
 | 
						|
            }
 | 
						|
 | 
						|
            consumed = true;
 | 
						|
            break;
 | 
						|
        case DesktopLockMenuEventExit:
 | 
						|
            scene_manager_search_and_switch_to_previous_scene(
 | 
						|
                desktop->scene_manager, DesktopSceneMain);
 | 
						|
            consumed = true;
 | 
						|
            break;
 | 
						|
        default:
 | 
						|
            break;
 | 
						|
        }
 | 
						|
    }
 | 
						|
    return consumed;
 | 
						|
}
 | 
						|
 | 
						|
void desktop_scene_lock_menu_on_exit(void* context) {
 | 
						|
    Desktop* desktop = (Desktop*)context;
 | 
						|
    desktop_lock_menu_reset_idx(desktop->lock_menu);
 | 
						|
}
 |