/auto_mouse_mover

Simple automatic mouse mover application

Primary LanguageC#MIT LicenseMIT

Automatic mouse mover application

Build Status License: MIT

Introduction

This small GUI application simulates a periodical user input by automatically moving the mouse cursor. It's written in C# using Visual Studio 2017.
It may seem useless at a first glance, but I use it quite often on company laptops where the power options are locked and cannot be modified. My typical use case is for running demos in fairs or in front of customers, when you cannot move the mouse and you don't want the laptop to automatically lock the screen. In this way, you don't have to remember to move the mouse every now and them and you can concentrate on the demo.

How it works

Once started, the application is minimized to the tray bar and runs in background. The user can choose if showing the tray bar icon to make it completely invisible.
The application periodically checks the mouse position and simulates a mouse moving. In order to avoid disturbing the user if he's using the PC, the mouse is moved only if its position remained the same since the last time.
The cursor is moved back and forth, so it always remains in the same spot and does not go outside the screen. If the cursor is detected outside the main screen, it'll be reset at its center. This happens also if you use multiple screens and you don't have the cursor in the main one. It has never been a problem for me, but you can extend the code to check for multiple screens if you need.
In order to move the mouse automatically while in background, the application directly imports and calls the Windows APIs for sending input to the operating system and getting the cursor position, since there is no native function in C# for doing this (at least when I coded it).

Building

Just open the Visual Studio solution and build the project in Debug or Release.
The output folder is VS2017_Project\AutoMouseMover\bin.

Usage

For a basic usage, just open the application and click the Start button leaving the default settings.
If you want (but it's not necessary, I only added it for completeness), you can select the time period in seconds and the number of pixels to move the cursor. In addition to this, you can choose if minimizing the application to tray bar (suggested) and if showing the tray bar icon. In case the tray bar icon is not shown, the only way to close the application after started is using the Task Manager.
When minimized to the tray bar, you can open the application again by double-clicking the icon. You can also close it directly by right-clicking the icon and select Close.
If you don't want to see the cursor moving by itself, just choose a small amount of moving pixels. The default value of 5 pixels should be enough (unless you stare at the cursor), at least on modern high-resolution screens.
All the settings are saved when the application is closed and loaded when started, so you don't have to set them every time.

License

This software is available under the MIT license.