What is a SCR file? The.scr file extension is used for a system file format that was developed by Microsoft. These SCR files are screensaver files that are used by Windows for energy-saving purposes.These Windows screensavers were originally created to prolong the life of CRT and plasma display monitors. Jul 08, 2020 An SCR file is a screen saver file used by Microsoft Windows. It contains a graphic, animation, slide show, or video that you can use as a Windows screensaver. SCR files are typically stored in Windows's main directory.
- Advertisement
- AT File Mole v.2.2.3Low-level editing ANI, CUR, ICO, WAV files. Extracting icons, cursors and bitmaps from EXE, DLL, OCX, CPL, SCRfiles and saving theirs in ICO, CUR, BMP, JPG, GIF, PNG formats or copying to clipboard. Support alpha blending. Zoom for preview ...
- Arm Icon Extractor v.2.5Arm Icon Extractor allows you to explore or 'extract' Windows icons from inside of EXE, DLL, DRV, SCRfiles on your computer and save them into ICO and Icon Library file. Many different type of files on your computer contain one or even many icons ...
- SWF Scout v.2.23Flash movie (SWF) creation programming library with SWF reading and SWF templates support. Can be used in Visual Basic, VB.NET, Visual C#, ASP and ASP.NET. Can use FLV, SWF, EMF, JPG, BMP, PNG, TIFF, GIF as input, can export EXE and SCRfiles ...
- Bytescout SWF Scout v.2.33.4Flash movie (SWF) creation programming library with SWF reading and SWF templates support. Can be used in Visual Basic, VB.NET, Visual C#, ASP and ASP.NET. Can use FLV, SWF, EMF, JPG, BMP, PNG, TIFF, GIF as input, can export EXE and SCRfiles ...
- Any Logo Screensaver Creator v.1.2.3Any Logo Screensaver Creator is a tool that lets you create custom and branded Screensavers using a wizard interface. The sceensavers are a self-contained .SCR and can also make a self-installing .EXE.
- AMS Media Show Pro v.1.0AMS Media Show Pro allows to create and play presentations with background music and beautiful transition effects.
- PPTX to Screensaver Converter v.3.21PPTX to Screensaver Converter, PPTX to SCR ...
- Change Logon Screen Saver v.1.2This small utility will allow you to change the Screen Saver ...
- Softany Screensaver Remover v.1.0This tool Helps you delete screensavers from your computer.
- Top Screen Saver Builder v.1.0Easy to use screen saver builder ...
- Media Show Pro v.1.45Media Show Pro creates presentation in stand-alone .EXE file. Using a clean-looking, intuitive interface, you select pictures from any combination of folders on your system. The program allows to use beautiful transition effects and background ...
- GIF to LED Animation Screensaver Maker v.1.2GIF to LED Animation Screensaver Maker 1.2 is regarded as a convenient as well as simple to use tool which lets you convert GIF animations into virtual LED animation screensavers. No programming skills needed: just load a gif image to workspace with ...
- Pretty Icon Maker v.1.5Pretty Icon Maker can create, extract, and convert all icons from black-white to 32-bit color depth. A comprehensive collection of drawing tools and effects are included. All drawing tools have anti-alias and smoothness functions and excellent 3D ...
- GStarCAD 2011 Professional v.110628GStarCAD is based on the well-known IntelliCAD software & 99% identical to AutoC ...
- SCR Builder 3 v.3.3With SCR Builder you can create your own screen savers using your own media.
- Duplicate files manager v.4.0Duplicate files manager help you find out and clean duplicate files,expand disk space and optimize disk. You could find files with same content , same file name or same size . And compare two folders,find out same files between these two groups .
- Lock Files and Folders v.1.4Lock Files & Folders can lock your files and folders without encrypting them. It stops users from moving, renaming, deleting and opening files.
- Compare Excel Files v.2.1Excel compare offers computer aided comparison of Excel files and saves trouble of manually searching for differences. It compares data straight from worksheets and presents results on new Excel sheet as difference report ready to print or save.
- Dark Files v.6.2.1.1Dark Files can help you keep your files protected. You can choose who gets access to what files on your computer. This program provides three levels of protection to suit any user : 'Hidden', 'Read Only', 'Full Control'.
- NoClone - Find Duplicate Files v.3.2NoClone - Find and Delete TRUE duplicate files by byte-to-byte comparison. Smart Marker helps to clean up hard drive.
- Compare Excel Files Excel compare offers computer aided comparison of Excel
- PPT to SCR Converter PPT to SCR Converter (PowerPoint to Screensaver Creator
- Lock Files and Folders Lock Files & Folders can lock your files and folders
- AVI Files Desktop avi-converter.net AVI Files Desktop 0.53 is a tool which
- PCMesh Hide Files and Folders Use PCMesh Hide Files and Folders to make your
- Salvage Files Data Recovery Software Salvage Files offers a great range of data recovery
- Files Compare Tool Files Compare is a visual tool for files and
- NTFS Files Recovery Tool Windows NTFS files recovery software recovers
- Recover Files Data Recovery Data Recovery Software, Recover a Hard Drive, Camera Card,
- RM Files Converter RM Files Converter is an efficient tool for converting
Screensaver Sample
The Screensaver sample is a complete application that demonstrates how to search the Common Feed List for Really Simple Syndication (RSS) feed items that contain images as enclosures, and display those images on the screen along with the headline and text of the item. Based on the Windows screensaver that is available as part of the Microsoft Visual C# Starter Kit, the sample incorporates the functionality of the Windows RSS Platform. The project comes ready to compile and run. You can customize the application and share your work with others.
Download the code: Windows RSS Platform Sample Screensaver.
This topic contains the following sections.
- Getting Started
- System Requirements
- Building and Running the Sample
- How to Create an .SCR File
- Using the Screensaver from Windows
- Interacting with the Screensaver
- Project Files
- Concepts
- Command Line Options
- Enumerating Feeds
- Timer Events
- Expanding the Screensaver
- Download Missing Enclosures
- Open Current Item in Browser
- More Suggestions
Getting Started
When the screensaver is launched, it scans the Common Feed List for RSS feed items that contain enclosures (binary attachments) that can be displayed. Then it creates a full-screen Windows Form and displays data from the feeds. A timer is used to update the currently selected topic and change the background image.
If You move or click the mouse at any point or press a key, the program exits immediately.
This section contains the following subsections:
- System Requirements
- Building and Running the Sample
- How to Create an .SCR File
- Using the Screensaver from Windows
- Interacting with the Screensaver
System Requirements
The Windows RSS Platform Screensaver sample project requires Visual C# 2005 and uses version 2.0 of the Microsoft .NET Framework.
The Framework is installed as part of Microsoft Visual Studio, but it can also be installed directly from the Microsoft .NET Framework Developer Center. Any computer that runs the application must have version 2.0 of the Framework installed. If you plan to share your screensaver with friends, you should let them know that they must also install Framework version 2.0.
Building and Running the Sample
After your project is loaded into the Visual C# 2005 environment, you can compile and run it in one step.
To build and run the screensaver application: |
---|
|
If the screensaver does not build, ensure that the latest release of the Feeds
reference is loaded. Also note that the capitalization of some property names has been changed for the final release of the Windows RSS Platform, such as IFeed.Name and IFeed.Path.
To add a reference to the interop assembly: |
---|
|
How to Create an .SCR File
The ScreenSaver project file has been extended with a custom build task that renames the output of the build (an executable file) with the .SCR extension. The following lines in ScreenSaver.csproj perform the copy as an 'AfterBuild' step.
See How to: Extend the Visual Studio Build Process for more information.
Using the Screensaver from Windows
After you have built the application, you can install it as a Windows screensaver.
To 'install' the screensaver by hand: |
---|
|
Alternatively, you can specify a post-build step that performs the copy for you.
To copy the output files as part of the build: |
---|
|
To complete the installation, you must set the RSS screensaver as the default screensaver for Windows.
To set the active screensaver for Windows: |
---|
|
You have now installed the screensaver. When Windows activates the screensaver due to a period of inactivity, it launches the ssNews.scr executable.
Interacting with the Screensaver
While the screensaver is active, you can use keyboard shortcuts to view the loaded list of feeds and items, and move forward and backward through the images.
Key | Description |
---|---|
Alt+F | View Feed List |
Alt+I | View Item List |
Up Arrow | Move to Previous Item |
Down Arrow | Move to Next Item |
Project Files
The project contains the following source files:
Program.cs | Contains the Main() method–the location where the program begins execution–and the code for handling the command line switches. |
ScreenSaverForm.cs | Contains the main screensaver Windows Form. The images and feed item headlines are displayed on this full-screen form. |
OptionsForm.cs | Contains the Windows Form that displays the settings options. From this dialog box, you can configure the behavior of the screensaver. |
CommonFeedListUtils.cs | Contains the CommonFeedList class, which is used to recursively enumerate all the feeds in a base folder. |
FeedList.cs | Contains the active list of RssFeed objects. This class collects items with image enclosures and fetches the next and previous items in the list. |
RssFeed.cs | Contains the class representing the RSS feed. The feed can be loaded from XML text, an XML node, a Uniform Resource Identifier (URI), or from an IFeed object. |
RssItem.cs | Contains the class representing the RSS feed item. For the purposes of the sample, the class will not load the item if it does not contain an enclosure of the expected type (.JPG, .GIF, .PNG, or .BMP). |
IItem.cs | Contains the class representing an item–an object with a title and a description. This object is rendered using the ItemListView and ItemDescriptionView types. |
ItemDescriptionView.cs | Contains code that displays the description of an item from an RSS feed. It slowly fades in the text of the item, and then fades it out again. |
ItemListView.cs | Contains code that displays the title of an item from an RSS feed. It keeps track of a currently selected article, which it can scroll forward or backward. |
FeedListView.cs | Contains code that displays the list of RSS feed titles. |
The project also contains the following resource files:
App.ico | The screensaver application icon. |
DefaultRss.xml | Contains the text of a default feed, used if no suitable feed enclosures can be found. |
SSaverBackground.jpg | A built-in image defined by the default feed. |
SSaverBackground2.jpg | Another built-in image defined by the default feed. |
Concepts
This section contains the following subsections:
- Command Line Options
- Enumerating Feeds
- Timer Events
Command Line Options
When Windows runs your screensaver, it launches it with one of three command line options:
/s
– Start the screensaver in full-screen mode./c
– Show the configuration settings dialog box./p ####
– Display a preview of the screensaver using the specified window handle.
The screensaver sample handles these arguments in the Program.cs source file; however, the /p
argument is not implemented.
In addition to these arguments, the sample also supports the following option:
/d
– Start the screensaver in debug mode.
The debug mode flag is passed as a command line parameter when debugging in Visual Studio. In debug mode, the feed and item list are displayed by default. In addition, the form reverts to a standard sizeable border style to simplify the debugging process.
Enumerating Feeds
To simplify the process of walking the hierarchy of the feedlist, CommonFeedListUtils.cs declares a helper class to keep track of the progress of the enumeration. It relies on a mechanism that is new to version 2.0 of the Framework, the yield keyword, to return each feed object sequentially to the calling process. Internally, the method uses the Queue class to manage a list of folders. The method takes a single parameter, the folder object, to use as the base of the enumeration.
The CommonFeedList() method is used to load the list of feeds in FeedList.cs. The method is designed to be used in a foreach loop, as follows:
Timer Events
Two System.Windows.Forms.Timer objects produce the events that keep the screensaver in motion.
- checkCflTimer – Before the screensaver starts, it loads a list of feed items that contain attached images from the Common Feed List. While the screensaver is running, timer events from checkCflTimer cause the screensaver to refresh the internal list of items based on the LastWriteTime property of the feed. This timer is visible on the ScreenSaverForm in design mode.
- fadeTimer – Another timer is created in the constructor of ItemDescriptionView that is used to fade the item description in and out, and to move to the next item in the list. There are two event handlers for this timer, one in ItemDescriptionView.cs, the other in ScreenSaverForm.cs.
By default, the interval of fadeTimer is set to 40 msecs. At each tick event, two things happen: the opacity level of the ItemDescriptionView is adjusted by the value of textAlphaDelta, and the ScreenSaverForm is refreshed and repainted. Two 'terminal' effects also occur when the opacity reaches its maximum and minimum values.
First, at maximum opacity, the Interval property of fadeTimer is changed to the value of fadePauseInterval, which is 2000 msecs by default. During this pause, the screen will not refresh automatically, so you must explicitly call Refresh() in response to events that update the screen, such as KeyDown events. You can modify the length of the pause in the Configuration dialog box.
Next, at minimum opacity, the fadeTimer_Tick() event handler triggers a secondary event of the view called FadingComplete. The event handler for this event moves the current index of the FeedList to the next item.
Expanding the Screensaver
You are invited to expand the screensaver using the following features or create other features.
- Download Missing Enclosures
- Open Current Item in Browser
- More Suggestions
Scr Files Download
Download Missing Enclosures
If Windows Internet Explorer doesn't download enclosures automatically, how does the screensaver find images to display? The answer is: it doesn't. If an image has not been downloaded, the screensaver displays a blank screen. Even if you have clicked on the link in the browser and the image has been downloaded to the Temporary Internet Files (TIF) folder; the screensaver can only discover and display files that have been downloaded to the enclosures folder associated with the feed.
To fix this problem, select the 'Automatically download enclosures' option when you subscribe to a picture feed. This option can be enabled in the Properties dialog box for the feed. However, you can also do it programmatically through the Windows RSS Platform.
The sample currently displays enclosures based on their file name extensions. The FeedList.cs file contains a declaration of a list of extensions for this purpose.
In the RssItem.cs file, the file name extension of the downloaded enclosure is compared to the list of file name extensions, and the object is finalized if a match is found.
Checking the file name extension works only for enclosures that have already been downloaded. If the file doesn't exist, you must to check the MIME type of the enclosure. You can also parse the file name extension of the URL. The URL may include query parameters, or refer to a file type different from the file type it returns, for example, PHP or ASPX.
First, add a new list of MIME types associated with images.
Next, add the following code to RssItem.cs.
Verify the extension of the file after it has been downloaded to ensure that it is the file type that you expected to receive.
Open Current Item in Browser
Now that the screensaver is working, you might notice that only a portion of the item's descriptive text can be displayed in the main window. If your feeds have been updated recently, you may discover items that you have not seen before. After the item is in view, you can open the browser and view the full article, or view other items from the same feed.
To open the current item in the browser, do the following:
- Locate the URL of the Current Item.
- Launch the Browser.
- Add a Keyboard Shortcut.
- Start a New Thread.
- Secure a Locked Workstation.
Locate the URL of the Current Item.
To open the current item in the browser, you must use the URL of the item. The Link property of the feed item is copied to the RssItem objects as they are constructed. The FeedList class, which maintains the list of feeds and the current item in the feed, can be used to find the URL.
The following code creates a new member function of the FeedList class that retrieves the URL from the current item.
Some feeds use a relative URL for the item link. You can create an absolute URI from the base URL of the current feed and item.Link
using the System.Uri constructor to combine the two. If the item link is not a relative URL, the base value is ignored.
Launch the Browser.
You can launch Internet Explorer 7 with the retrieved URL as a command line argument. Use the ProcessStartInfo class to declare the elements used to start the new process. The following code assumes you have imported the types defined in the Systems.Diagnostics namespace with the using directive.
Add a Keyboard Shortcut.
To expose the new functionality from the interface, add a call to OpenItem() to the ScreenSaverForm_KeyDown event handler in ScreenSaverForm.cs. The following code uses the Enter key, but you can choose a different key. Make sure the new code is added after the call to Close() because the form must exit so that you can access the browser window.
Take a moment to test the new feature. Notice that the browser appears as expected if you launch the screensaver from the debugger; however, nothing seems to happen if the screensaver is launched from the operating system.
Start a New Thread.
The difference in behavior results from the process that is used to launch the screensaver. When the main screensaver thread exits, the operating system stops any child processes that are still running. When the screensaver is in the Visual Studio debugger, the Internet Explorer process is not linked to the screensaver as a child process. However, when the screensaver is launched from the Windows Logon Process (Winlogon.exe), the child process has barely enough time to start before it is asked to shut down.
Open .scr Files
The solution to this dilemma is a new thread. To prevent the screensaver application from exiting until the browser window is closed, call WaitForExit() on the newly created process to wait for the child process to end before continuing. You must close the screensaver form so that the browser is visible.
There are two parts to this procedure. First, create a new class to encapsulate the functionality to run in a new thread, as in the following example:
Next, start the new thread from the OpenItem() method created above. The following code passes the URL to the thread using a ParameterizedThreadStart class, available in version 2.0 of the Framework.
Test the feature again. As long as the browser window remains open, there is at least one active thread running in the application, which prevents it from exiting when the main ScreenSaverForm is closed.
Secure a Locked Workstation.
There Is Still A Lot You Can Do. If None Of The Above Methods Seem To Work For You, Then Try These Methods : Try To Find A Safe Computer From Wh...
For many users, the screensaver is a means of securing the desktop from intruders. If the workstation is locked, the screensaver must not allow access to the system unless a password is entered. Unfortunately, implementing the preceding code opens a very large security hole. When the user presses the Enter key, the browser appears whether the desktop is locked or not. With the browser open, the file system and desktop are readily accessible.
Before a screensaver appears, Windows creates a new virtual desktop for it. The screensaver process is created on this second desktop, which is never locked. Any other processes that the screensaver creates will inherit this virtual desktop, unless the application switches back to the default desktop. To successfully switch back to the default desktop, certain access rights must be granted. If the switch fails, the workstation is most likely locked.
The following code implements this functionality.
To complete this step, verify that Desktop.IsNotLocked() is true before you create the browser thread.
More Suggestions
See More Results
The screensaver application is designed to be easily expanded and customized. Some ideas for extending it are:
- Randomly select the item to display: Mix up the images to keep things interesting.
- Respond to feed and folder events: Rewrite the polling feature to listen for FeedDownloadCompleted or FeedItemCountChanged events, and refresh the FeedList only when necessary.
- Set the desktop wallpaper: Add a keyboard shortcut to set the current image as the background image of the desktop. Use SystemParametersInfo with
SPI_SETDESKWALLPAPER
to specify the image file. - Transition between images: Create mesmerizing visual effects with Microsoft DirectX Image Transformations.
- Render HTML markup in the item description: Host the Internet Explorer WebBrowser Control to do the work.
- Show weather information: Display current local weather conditions from a syndicated weather service.