MagicMirror Forum
    • Recent
    • Tags
    • Unsolved
    • Solved
    • MagicMirror² Repository
    • Documentation
    • 3rd-Party-Modules
    • Donate
    • Discord
    • Register
    • Login
    A New Chapter for MagicMirror: The Community Takes the Lead
    Read the statement by Michael Teeuw here.

    MMM-GroveGestures

    Scheduled Pinned Locked Moved System
    51 Posts 8 Posters 20.7k Views 12 Watching
    Loading More Posts
    • Oldest to Newest
    • Newest to Oldest
    • Most Votes
    Reply
    • Reply as topic
    Log in to reply
    This topic has been deleted. Only users with topic management privileges can see it.
    • B Offline
      bolish
      last edited by bolish

      @Benjaminh86

      Here is an extract of mine that should help you to understand. You just have to tweak the notification and pages based on your setup.

      		{
      			// 22
      			module: "MMM-GroveGestures",
      			position: "top_right",
      			config: {
      				autoStart: true, //When Mirror starts, recognition will start.
      				verbose:true, // If set as `true`, useful messages will be logged.
      				recognitionTimeout: 1000, //Gesture sequence will be ended after this time from last recognized gesture.
      				cancelGesture: "WAVE", //If set, You can cancel gesture sequence with this gesture.
      				visible: true, //Recognized gesture sequence will be displayed on position
      				idleTimer: "0", // `0` for disable, After this time from last gesture, onIdle will be executed.
      				defaultCommandSet: "DEFAULT_MODE",
      				commandSet: {
      					"DEFAULT_MODE": {
      							"LEFT": {
      						        notificationExec: {
      						          notification: "PAGE_INCREMENT",
      						        }
      	      						},
      							"RIGHT": {
      						        notificationExec: {
      						          notification: "PAGE_DECREMENT",
      						        }
      	      						},
      						},
      					"0": { // this corresponds to the page N° sent back by MMM-Pages 
      							"LEFT": {
      						        notificationExec: {
      						          notification: "PAGE_INCREMENT",
      						        }
      	      						},
      							"RIGHT": {
      						        notificationExec: {
      						          notification: "PAGE_DECREMENT",
      						        }
      	      						},
      							"UP": {
      						        notificationExec: {
      						          notification: "CALEXT2_SCENE_NEXT",
            						              payload: null,
      							}
      	      						},
      							"DOWN": {
      						        notificationExec: {
      						          notification: "CALEXT2_SCENE_PREVIOUS",
            						              payload: null,
      							}
      	      						},
      						},
      					"1": {
      						        "LEFT-RIGHT-LEFT": {
      						        notificationExec: {
      						          notification: "REMOTE_ACTION",
      							    payload: {
      							  	action: "SHOW",
      							  	module: "module_13_MMM-BackgroundSlideshow",
      								     },	
      						        }
      	      						},
      						        "RIGHT-LEFT-RIGHT": {
      						        notificationExec: {
      						          notification: "REMOTE_ACTION",
      							    payload: {
      							  	action: "HIDE",
      							  	module: "module_13_MMM-BackgroundSlideshow",
      								     },	
      						        }
      	      						},
      						        "UP-DOWN-UP": {
      						        notificationExec: {
      						          notification: "REMOTE_ACTION",
      							    payload: {
      							  	action: "SHOW",
      							  	module: "module_14_MMM-BackgroundSlideshowInfo",
      								     },	
      						        }
      	      						},
      		        				"DOWN-UP-DOWN": {
      						        notificationExec: {
      						          notification: "REMOTE_ACTION",
      							    payload: {
      							  	action: "HIDE",
      							  	module: "module_14_MMM-BackgroundSlideshowInfo",
      								     },	
      						        }
      	      						},
      							"LEFT": {
      						        notificationExec: {
      						          notification: "PAGE_INCREMENT",
      						        }
      	      						},
      							"RIGHT": {
      						        notificationExec: {
      						          notification: "PAGE_DECREMENT",
      						        }
      	      						},
      							"UP": {
      						        notificationExec: {
      						          notification: "ARTICLE_MORE_DETAILS",
      						        }
      	      						},
      							"DOWN": {
      						        notificationExec: {
      						          notification: "ARTICLE_LESS_DETAILS",
      						        }
      	      						},
      							"CLOCKWISE": {
      						        notificationExec: {
      						          notification: "BACKGROUNDSLIDESHOW_NEXT",
      						        }
      	      						},
      							"ANTICLOCKWISE": {
      						        notificationExec: {
      						          notification: "ARTICLE_PREVIOUS",
      						        }
      	      						},
      						},
      					"2": {
      							"LEFT": {
      						        notificationExec: {
      						          notification: "PAGE_INCREMENT",
      						        }
      	      						},
      							"RIGHT": {
      						        notificationExec: {
      						          notification: "PAGE_DECREMENT",
      						        }
      	      						},
      							"UP": {
      						        notificationExec: {
      						          notification: "SWD_NEXT",
      						        }
      	      						},
      							"DOWN": {
      						        notificationExec: {
      						          notification: "SWD_PREV",
      						        }
      	      						},
      							"FORWARD-BACKWARD": {
      						        notificationExec: {
      						          notification: "SWD_PAUSE",
      						        }
      	      						},
      							"BACKWARD-FORWARD": {
      						        notificationExec: {
      						          notification: "SWD_PLAY",
      						        }
      	      						},
      						}
      					},
      					commandSetTrigger: {
      					  "DEFAULT_MODE": "DEFAULT_MODE",
        					  "PAGE_NUMBER_IS": (payload) => { return payload } // this is what set the right command set based on MMM-Pages feedback "PAGE_NUMBER_IS"
      					},
      				}
      		},
      		{
      			//22
      			module: "MMM-NotificationTrigger",
      			config: {
      				useWebhook: false,
      				triggers: [
      					{
      						// Is hiding the compliments module when newsfeed article is toggled fullscreen
      						trigger: "ARTICLE_MORE_DETAILS",
      						fires: [
      							{		
      								fire: "REMOTE_ACTION",
      								  payload: {
          									action: "HIDE",
          									module: "module_6_compliments",
      									},
      							}
      							]
      					},
      					{
      						// Is showing the compliments module again when newsfeed is minimized.
      						trigger: "ARTICLE_LESS_DETAILS",
      						fires: [
      							{		
      								fire: "REMOTE_ACTION",
      								  payload: {
          									action: "SHOW",
          									module: "module_6_compliments",
      									},
      							}
      							]
      					},
      					{
      						// Is triggering PAGE NUMBER NOTIFICATION when pages is changing
      						trigger: "PAGE_DECREMENT",
      						fires: [
      							{		
      								fire: "QUERY_PAGE_NUMBER",
      							}
      							]
      					},
      					{
      						// Is triggering PAGE NUMBER NOTIFICATION when pages is changing
      						trigger: "PAGE_INCREMENT",
      						fires: [
      							{		
      								fire: "QUERY_PAGE_NUMBER",
      							}
      							]
      					},
      					{
      						// Slideshow_Show.
      						trigger: "SLIDESHOW_SHOW",
      						fires: [
      							{		
      								fire: "REMOTE_ACTION",
      								  payload: {
          									action: "SHOW",
          									module: "module_13_MMM-BackgroundSlideshow",
      									},
      							}
      							]
      					},
      					{
      						// Slideshow_Hide.
      						trigger: "SLIDESHOW_HIDE",
      						fires: [
      							{		
      								fire: "REMOTE_ACTION",
      								  payload: {
          									action: "HIDE",
          									module: "module_13_MMM-BackgroundSlideshow",
      									},
      							}
      							]
      					},
      					{
      						// SlideshowInfo_Show.
      						trigger: "SLIDESHOWINFO_SHOW",
      						fires: [
      							{		
      								fire: "REMOTE_ACTION",
      								  payload: {
          									action: "SHOW",
          									module: "module_14_MMM-BackgroundSlideshowInfo",
      									},
      							}
      							]
      					},
      					{
      						// SlideshowInfo_Hide.
      						trigger: "SLIDESHOWINFO_HIDE",
      						fires: [
      							{		
      								fire: "REMOTE_ACTION",
      								  payload: {
          									action: "HIDE",
          									module: "module_14_MMM-BackgroundSlideshowInfo",
      									},
      							}
      							]
      					},
      					{
      						// Is showing the compliments module again when newsfeed is minimized.
      						trigger: "ARTICLE_LESS_DETAILS",
      						fires: [
      							{		
      								fire: "REMOTE_ACTION",
      								  payload: {
          									action: "SHOW",
          									module: "module_6_compliments",
      									},
      							}
      							]
      					},
      					{
      						// AT START - Is hiding MMM-ImageSlideshow at start.
      						trigger: "ALL_MODULES_STARTED",
      						fires: [
      							{		
      								fire: "REMOTE_ACTION",
      								  payload: {
          									action: "HIDE",
          									module: "module_13_MMM-BackgroundSlideshow",
      									},
      							},
      							{		
      								fire: "REMOTE_ACTION",
      								  payload: {
          									action: "HIDE",
          									module: "module_14_MMM-BackgroundSlideshowInfo",
      									},
      							},
      							{		
      								fire: "QUERY_PAGE_NUMBER",
      							},
      							{		
      								fire: "PAGE_INCREMENT",
      							},
      							]
      					},
      					{
      						// SHUTDONW - turns screen off and shutdown pi
      						trigger: "SCREENOFFSHUTDOWN",
      						fires: [
      							{		
      								fire: "REMOTE_ACTION",
      								  payload: {
          									action: "MONITOROFF",
      									},
      							},
      							{		
      								fire: "REMOTE_ACTION",
      								  payload: {
          									action: "SHUTDOWN",
      									},
      							},
      							]
      					}
      					]
      				}				
      		},
      
      B 2 Replies Last reply Reply Quote 0
      • B Offline
        Benjaminh86 @bolish
        last edited by

        Hello @bolish,

        thanks for sharing the script. I will watch this carefully ;)

        BenH

        1 Reply Last reply Reply Quote 0
        • B Offline
          Benjaminh86 @bolish
          last edited by

          @bolish
          I see in your MMM-notificationtrigger module that you have a MONITOROFF action.
          I imagine that we can associate a gesture command in Grove Gestures, for example: I make the gesture high, it turns on the screen.
          I would like to do that but I do not understand how to integrate it into Grove Gestures …
          If I do :

          “UP”: {
          notificationExec: {
          notification: “REMOTE_ACTION”,
          payload: {
          action: “MONITORON”,
          module: “MMM-Remote-Control”,
          }

          And in MMM-notificationtrigger:

          {
          // MONITOR_ON - turns screen on
          trigger: “MONITOR_ON”,
          fires: [
          {
          fire: “REMOTE_ACTION”,
          payload: {
          action: “MONITORON”,
                                   module: “MMM-Remote-Control”,
          }
          }
          ]
          }

          is it good?..

          1 Reply Last reply Reply Quote 0
          • B Offline
            bolish
            last edited by

            @Benjaminh86
            Not really…

            “MONITORON” is already an action which is managed by MMM-REMOTECONTROL so you don’t need MMM-Notificationtrigger for that.

            You just need MMM-GroveGesture to send it :

            		        				"UP": {
            						        notificationExec: {
            						          notification: "REMOTE_ACTION",
            							    payload: {
            							  	action: "MONITORON",
            								     },	 // you don't need to refer to a module name for the MONITORONN action (only necessary for HIDE and SHOW)
            						        }
            

            But you need to make sure that MMM-REMOTEControl is configured in the right way so that when it receives “MONITORON” it sends the right command (depending if you use HDMI, CEC, etc…)

            Regards

            B 1 Reply Last reply Reply Quote 0
            • B Offline
              Benjaminh86 @bolish
              last edited by

              @bolish
              thank you
              when you say: “But you need to make sure that MMM-REMOTEControl is configured in the right way”, when I send the request http://192.168.xxx.xxx:8080…MONITOROFF, it works.
              is that enough, or do I have to add something to the MMM-Remote-Control script?

              1 Reply Last reply Reply Quote 0
              • B Offline
                bolish
                last edited by

                No, if it’s works by sending the request, it should work with Gesture also!

                B 2 Replies Last reply Reply Quote 0
                • B Offline
                  Benjaminh86 @bolish
                  last edited by

                  @bolish

                  Great!
                  I will try tonight the adaptation I made of your script.
                  I put the action “MONITOROFF” in the “Default_Mode” part of Grove Gestures, that’s it?

                  1 Reply Last reply Reply Quote 0
                  • B Offline
                    Benjaminh86 @bolish
                    last edited by

                    Hello @bolish,

                    thanks to you! everything is working!
                    however, I thought Grove Gestures would activate automatically, but I have to make the command line for the sensor to be active:
                    cd ~ / MagicMirror / modules / MMM-GroveGestures / py
                    cp grove_gesture_sensor.py.RPI grove_gesture_sensor.py
                    Is this normal?
                    Another question about MMM-Pages; I would like to display the Google Calendar calendar on page 1 and the holiday calendar on page 2, but I do not know how to differentiate and name them on MMM-Pages …
                    Do you have an idea?

                    ? 1 Reply Last reply Reply Quote 0
                    • ? Offline
                      A Former User @Benjaminh86
                      last edited by

                      @Benjaminh86 said in MMM-GroveGestures:

                      cd ~ / MagicMirror / modules / MMM-GroveGestures / py
                      cp grove_gesture_sensor.py.RPI grove_gesture_sensor.py

                      It is described on instruction for installation. And that command is not for activation. I provide 2 scripts for each of Raspberry Pi and Asus TinkerBoard. you need to select one for your device. You don’t need to do that job again after once you did.

                      The real activation would be performed in the module itself on every running of MM.

                      B 2 Replies Last reply Reply Quote 0
                      • B Offline
                        bolish
                        last edited by

                        @Benjaminh86
                        You have to search a bit on the forum.
                        One idea could be to create 2 calendars instances.
                        See below post extract :

                        well… I believe it’s far from being perfect…but at least it seems to do the job…
                        
                        I created a “new” module which does exactly same / has the same code as the one I want to use, but has a different name (folder named “MMM-Calendar2” -> file named “MMM-Calendar2.js” -> within the line Module.register(‘MMM_Calendar2’)).
                        Not in the default module folder but into the 3rd party module folder…
                        

                        And put instance 1 on page 1 and isntance 2 on page 2.

                        B 2 Replies Last reply Reply Quote 0
                        • 1
                        • 2
                        • 3
                        • 4
                        • 5
                        • 6
                        • 3 / 6
                        • First post
                          Last post
                        Enjoying MagicMirror? Please consider a donation!
                        MagicMirror created by Michael Teeuw.
                        Forum managed by Sam, technical setup by Karsten.
                        This forum is using NodeBB as its core | Contributors
                        Contact | Privacy Policy