1 /*************************************************************************** 2 * Copyright (c) 2024 Microsoft Corporation 3 * 4 * This program and the accompanying materials are made available under the 5 * terms of the MIT License which is available at 6 * https://opensource.org/licenses/MIT. 7 * 8 * SPDX-License-Identifier: MIT 9 **************************************************************************/ 10 11 12 /**************************************************************************/ 13 /**************************************************************************/ 14 /** */ 15 /** GUIX Component */ 16 /** */ 17 /** Button Management (Button) */ 18 /** */ 19 /**************************************************************************/ 20 21 #define GX_SOURCE_CODE 22 23 24 /* Include necessary system files. */ 25 26 #include "gx_api.h" 27 #include "gx_system.h" 28 #include "gx_widget.h" 29 #include "gx_icon.h" 30 31 32 /**************************************************************************/ 33 /* */ 34 /* FUNCTION RELEASE */ 35 /* */ 36 /* _gx_icon_event_process PORTABLE C */ 37 /* 6.1 */ 38 /* AUTHOR */ 39 /* */ 40 /* Kenneth Maxwell, Microsoft Corporation */ 41 /* */ 42 /* DESCRIPTION */ 43 /* */ 44 /* This function processes events for the specified button. */ 45 /* */ 46 /* INPUT */ 47 /* */ 48 /* icon Pointer to icon control */ 49 /* block */ 50 /* event_ptr Incoming event to process */ 51 /* */ 52 /* OUTPUT */ 53 /* */ 54 /* status Completion status */ 55 /* */ 56 /* CALLS */ 57 /* */ 58 /* _gx_widget_event_process Default widget event process */ 59 /* _gx_icon_pixelmap_update Change the pixelmap */ 60 /* */ 61 /* CALLED BY */ 62 /* */ 63 /* Application Code */ 64 /* GUIX Internal Code */ 65 /* */ 66 /* RELEASE HISTORY */ 67 /* */ 68 /* DATE NAME DESCRIPTION */ 69 /* */ 70 /* 05-19-2020 Kenneth Maxwell Initial Version 6.0 */ 71 /* 09-30-2020 Kenneth Maxwell Modified comment(s), */ 72 /* resulting in version 6.1 */ 73 /* */ 74 /**************************************************************************/ _gx_icon_event_process(GX_ICON * icon,GX_EVENT * event_ptr)75UINT _gx_icon_event_process(GX_ICON *icon, GX_EVENT *event_ptr) 76 { 77 UINT status; 78 GX_WIDGET *widget = (GX_WIDGET *)icon; 79 80 /* Default status to success. */ 81 status = GX_SUCCESS; 82 83 /* Process relative to the type of event. */ 84 switch (event_ptr -> gx_event_type) 85 { 86 case GX_EVENT_SHOW: 87 status = _gx_widget_event_process(widget, event_ptr); 88 _gx_icon_pixelmap_update(icon); 89 break; 90 91 default: 92 93 /* Call the widget default processing. */ 94 status = _gx_widget_event_process(widget, event_ptr); 95 } 96 97 /* Return completion status. */ 98 return(status); 99 } 100 101