##Intro A framework for creating screensavers, incorporates the following functionality:
- Handles the resizing and displaying of a screensaver
- Closes the screensaver if the user moves their mouse or clicks
- Makes creating a screensaver possible just by implementing a class with a draw() and an iterate() method
- Compiles to a .exe file that can easily be changed to a .scr file
Features to come:
- Configuration functionality
- Automatic saving to Screensavers folder
It also includes a couple demo screensavers
- Lines draws several colorful straight lines that form an illusion of a curve. The lines begin large enough to cover the screen, then gradually reduce in size.
- Mandelbrot draws a Mandelbrot set, coloring each point based on the number of iterations until it is proven not to be in the set (See Mandelbrot on Wikipedia for more information)
An example of the lines program running:
An example of the Mandelbrot program running:
##Requirements Visual Studio, with tools for WPF (Windows Forms) desktop application development
##How to Use
- First, fork/download this repository, and open the solution
- Then, create a class, and subclass
ScreenSaverIterator
- Make a constructor for your class that includes at least width & height, and call the base constructor
- Change the
maxIteration
andframeRate
fields to the maximum number of frames to display before resetting your screensaver, and the number of frames per second (or 0 for as fast as possible) - Implement the
setUp()
function, which is run every time your screensaver is reset (once when it is beginning to display, then again every timecurrentIteration
hitsmaxIteration
) - Implement the
iterate()
function, which runs every frame, before draw. Put any update logic. If you need the current iteration, use the fieldthis.currentIteration
. Be sure to includethis.currentIteration++
In order to track your current iteration! - Implement the
draw()
function, which returns a Bitmap to be drawn. (Add any drawing logic here) - Modify the function
getNewScreensaver
inScreenSaverManager.cs
so that it constructs and returns an instance of your class with the given width, height, and any other parameters it needs (Configuration to be added later) - Run the program in Release mode
- Move the
ScreensaverFramework.exe
file to some other location on your desktop (If it has dependancies, copy the whole folder) - Rename the .exe file so that it has the extension
.scr
(This is the extension for Windows screensavers) - Right click the new file, and click Install from the options menu.
- Make sure that your screensaver is enabled.
- Enjoy looking like a pro.
You can use the following template, if you don't feel like writing this:
public class MyScreenSaver: ScreenSaverIterator {
public MyScreenSaver(width, height, ...): base(width,height) {
this.maxIteration = 60;
this.frameRate = 60;
}
public override void iterate() {
//Put some update logic here
this.currentIteration++;
}
public override Bitmap draw() {
//Put some drawing logic here
return new Bitmap(this.width, this.height);
}
public override void setUp() {
//Put any resetting code here
}
}
##Tips
- If you're drawing primitive things, use a Graphics object to modify your bitmap.
- If you find an issue, raise it on the Issues tab
- If you're getting errors about unsafe code, you have to enable it in your build properties. The managed (safe) Bitmap is extremely slow to set pixels, so the unsafe version is a lot better.
##Credits The code for FastBitmap comes from this website. The Mandelbrot drawing code was also based on the code from that site.