RISCOS.com

RISCOS Select 3 - Planned Features

Introduction

Building upon the work done in Select 1 and 2, Select 3 improves upon both the significant changes made to both the graphics and networking components as well as adding many new features. The focus on Select 3 has been mostly based around stablising features from Select 2 and improving the desktop usability of the Operating system.

Major highlights

  • Cut and paste
    Text in writeable icons provided by the Window Manager is now able to be selected by keyboard and mouse. Such icons can be used with the standard clipboard operations
  • Thumbnailing
    The filer can now display images as thumbnails, allowing photo albums and other image collections to be browsed more easily.
  • Improved 'buttons'
    Action buttons, as well as groups and other 3D-style icons have been improved and may be made round or given colours. Support for button styles is a 'plugin' interface and other clients may provide different button renderings.
  • Alpha-channel sprites
    A new class of sprites has been created for alpha-channel sprites. These sprites can be used whereever the standard sprite operations would be used through system sprite rendering calls. Alpha-channel sprites allow each pixel to have variable translucency, which means that sprites can blend better to their backgrounds.
  • Recycle bin
    Files deleted by the user can, optionally, be sent to a recycling bin from which they can be retrieved if necessary.
  • Improved Paint application
    !Paint's internal and external operation has had a major overhaul to cater for some of the new features of Select 3, including alpha-channel sprites.

Feature breakdown

In the following breakdown, not all changes have been listed. In particular, fixes to components are not listed unless their effect is significant. Select is supplied with a more complete breakdown of the changes on a per-component basis.
Application changes
  • New !Recyclone application provides a rubbish bin into which files deleted by the user will be placed. A configuration tool is provided to allow the bin to be expired and its location changed.
  • New !NetLights application displays network activity on the iconbar.
  • !Draw can now import any type handled by ImageFileConvert where the type can be converted to a type which is handled natively by Draw. This means that PNG files, Artworks, BMP and other images types can now be imported.
  • !Paint has been given a major overhaul. See the separate section for more details.
Desktop changes
  • DragASprite no longer uses a 'drop' shadow when translucency is active.
  • DragAnObject's sprite creation code has been optimised slightly.
  • Wimp now supports a 'priority' sprite pool which is able to forcibly override anything in the other sprite pools.
  • 'IconBorder' plugin system allows the default slabbed borders to be rendered in a customisable manner. FilterManager has been updated to support multiple icon border filter clients. Example bordering source code will be supplied.
  • 'Auto-open submenus' option now opens submenus and windows in the correct position regardless of where the mouse is placed.
  • Selection of text within writeable icons and its use with cut and paste operations is now supported by the Window Manager. This furthers the work started in Select 1 to make the entire OS capable of using the cut and paste system.
  • Tinting of icons is now more reliable and can use any tint type provided by the ColourMap module.
  • Command windows generated by single tasking applications when run from the desktop are now centred on the screen.
  • FilerAction proxying is now an option which may be disabled under the clients control. This might be used by rubbish bin applications to invoke 'delete' operations on items already in the bin.
  • When in EY0 modes, Pinboard now correctly sizes its background window on a mode change.
  • Pinboard configuration application can now be accessed by its main menu. Optimisation for redraw speed of tiled ImageFileRender images.
  • Pinboard and Filer have both been updated to provide StyleGuide compliant save dialogue boxes.
  • Attempting to delete !Boot will now raise a warning.
  • Attempting to copy a directory called !Boot over your !Boot directory will now invoke the boot merge tool.
  • Should Filer fail to launch the filer action window for a delete operation, the confirm deletes option is now honoured.
  • In Filer, the Help option is now greyed if a directory and application combination are selected.
  • Filer windows have been updated to be more style-guide compliant and to address issues raised by the use of icon bordering.
  • Filer now offers to share directories as read only by default, rather than read-write. It makes sense not to share folders as public read/write by default.
  • Filer now provides a fourth display option beside those for Large, Small and information icons. The 'Thumbnails' display renders images using the ImageFileRender components, allowing any known image format to be displayed within the Filer.
  • Directories starting with a ! but without a !Run file are no longer treated as an application, allowing such names to be used safely if necessary.
  • RAMFSFiler will share the disc as read only by default.
  • The Sprite Pool has been updated with a number of slight modifications:
    • RAMFS icon now fits in with the new style of icons
    • JPEG icon now follows the bitmap style
    • Shared CD discs now look more like the CDROM icon
    • Addition of Zip, GIF, PNM, XBM, Sun raster, PCX, ICO, Clear, and BMP sprite icons.
    • LanManFS icon updated to fit better with correct style.
  • TaskManager can now launch Configure from the menu. The info box now describes the OS as RISC OS Select, and has been improved to address some issues with Icon Bordering.
  • Toolbox "Discard, Cancel, Save" icons have been resized to be 'standard' size.
  • TextGadget scrolling list boxes now display associated sprites more sensibly when selected; previously these would be displayed lighter than the rest of the line. The text is now positioned a little further across the window, away from the sprite in order to reduce the tight look that had been created.
  • ImageFileGadget correctly positions its window now; previously it would inset the window by a pixel. When resizing the gadget, the entire window is redrawn to ensure that it remains up to date. The facilities provided to developers for using ImageFileGadget have been greatly improved.
  • ImageFileGadget is now able to report mouse click events and has a much greater array of image manipulation options.
  • TextArea gadget now supports standard clipboard operations properly, allows for 'key notifications', and renders much more quickly in most cases.
  • Toolbox slider gadgets would respond to clicks and scrolls over the wells of the gadget even when the slider was set to be display only. They no longer react to such events.
  • Free space client templates tweaked to address issues relating to Icon Bordering.
  • The sprite file DesktopBanner$File is now loaded by the Desktop module, if it is present, and used as the welcome banner on entry to the desktop.
  • ShareFS 'Share directory' window is now updated to represent the current settings of the share if one is present, including the name of the Share.
  • TaskWindow now includes a fix for 'The MessageTrans Bug'.
Graphics changes
  • Rendering of sprites with 1bpp masks, using no scaling or colour translation, where the sprite data ends on a word boundary, but the mask data does not end on a word boundary, and the output alignment is not a word boundary due to a graphics window being present... now works properly.
  • SpriteExtend would fail to generate code when translucent sprites were rendered in paletted screen modes where the eigen factor was EX0 or EY0. This allows sprites to be visibly dragged in such modes.
  • FontManager can now safely resize its dynamic area. The version supplied in Select 2 had problems on certain systems which has now been addressed.
  • ImageFileRender now provides *ImageFileRenderers command for listing the supported renderers. This is mirrored in a new SWI to enumerate the renderers.
  • A default viewer application can now be specified through ImageFileRender and will be set up as system variables for all renderable types.
  • ImageFileRender's sprite renderer now supports information requests previous versions were would return the colour type incorrectly for certain sprite types. Sprite rendering will now render sprites of 8bpp or less through a wide translation table which improves their appearance when colourmapping is used in 16bbp or higher.
  • New ImageFileConvert module is used with the Convert* modules to provide a generic conversion method, allowing conversion between different file formats through a number of SWI calls. *ImageFileConverters will list the supported converters.
  • DrawFile will now render sprites in 8bpp or less through a wide translation table which improves their appearance when colourmapping is used in 16bbp or higher.
  • JPEG rendering where DPI based JPEGs are given as ratios are now taken into account in a similar manner to that used by !Draw. JPEGs which supply a ratio, DPI or DPC (dots per centimetre) of 0 will now be treated as 90 DPI. JPEGs with low values for DPI or DPC will now be treated as is this was a ratio.
  • CompressJPEG module now registers as a sprite to JPEG converter with ImageFileConvert.
  • JPEG handling is much more robust now, and should never generate aborts for either valid or corrupt compressed data.
  • ImageFileRender_Artworks module added to render Artworks documents.
  • New ConvertGIF added to ROM to generate a 'dummy' image. This is a placeholder module which avoids the requirement for a Unisys patent for the use of the LZW algorithm.
  • New ConvertXBM added to ROM to convert XBM image files to sprites.
  • New ConvertSun added to ROM to convert Sun raster image files to sprites.
  • New ConvertBMP added to ROM to convert Windows BMP image files to sprites.
  • New ConvertPNM added to ROM, supporting type 1-6 PNM files.
  • New ConvertICO added to ROM to convert Windows .ico files to sprites.
  • New ConvertPCX added to ROM to convert PCX files to sprites.
  • New ConvertClear added to ROM to convert Translator 'Clear' files to sprites.
  • New ConvertSprite module added , which supports creation of sprites through ImageFileConvert from any format which ImageFileRender can handle. ConvertSprite provides a proxy ImageFileConvert handler for ImageFileRender in much the same way that ImageFileRender automatically provides a proxy ImageFileRender handler for ImageFileConvert. ConvertSprite can also provide callback and SWI functions to render images to a sprite.
  • ConvertPNG has almost full support for creating PNGs from sprites (including alpha-channel sprites), with only CMYK sprites presently unsupported. Sprites can be created from any form of PNG, generating alpha-channel sprites where necessary.
  • DrawFile module now supports creation of SVG files from DrawFiles using the ImageFileConvert interface.
  • New ColourMap module allows generation of colourmapping descriptors without recourse to assembler. Currently supported mappings are :
    Blend, Brighten, Contrast, Gamma, Identity, Invert, Monochrome, Monochrome and scale and User.
    Colour map descriptors can be chained together to create more complex effects.
  • SpriteExtend, Kernel and ColourTrans have been updated to provide a new sprite type for alpha-channel sprites. Alpha-channel sprites allow the images to be rendered with varying levels of translucency per pixel. Previously, sprites could only provide binary (pixel on or off) masks.
  • SpriteUtil (System sprite area provider) has had a number of commands fixed to remove errors when no system sprite area is present.
  • InverseTable 'destination tracking' is now improved and should no longer result in corrupt font colours or alpha channel rendering.
Networking changes
  • Internet, ShareFS and Freeway have had issues relating to large file transfers addressed.
  • InetConfigure can now configure static IP addresses properly. Previous versions would retain the addresses stored in CMOS rather than using the new addresses supplied by the user.
  • Internet module has had a fix for interfaces with no addresses never issuing service calls.
  • Aliased interfaces are no longer dynamically named; the names used on their creation are now retained, allowing deterministic operation.
  • Internet can now handle changes in interface addresses more reliably. Previous versions had issues relating to multiple aliased interfaces and ARP requests which could cause machines to seemingly 'vanish'.
  • Added support for ZeroConf IP configuration. ZeroConf is a means by which an address can be obtained for a machine on a network without any configuration process. This is similar to the configuration used by the Access, but standardised across multiple platforms by a global group.
  • DHCPClient and ZeroConf client both respond to *ShowStat to provided their statistics.
  • DHCP client now supports address changed due to its deletion of the interface address. Previously this was not an issue, because Internet never issued service for address deletion, but now that this has been done it is now aware of this case.
  • The AppleTalk client is now supplied in ROM. This allows RISC OS systems to contact AppleTalk file and print servers.
  • LanManFS has been improved, resulting in faster resolution of names on local networks. The 'Transact' SWI call has been updated to allow a larger number of Transact communications to be made, including old WinPopup messaging.
Miscellaneous changes
  • OS_CLI is handled by an external module, CLIV.
  • Some calls have been moved from the kernel to a new module called LegacyBBC.
  • BEL (VDU 7) no longer uses OS_Word 7, but is passed to Sound calls directly.
  • FileTypes now declares PCX, PNG, SunRaster, BMP, Clear, ICO and XBM file type names.
  • FileSwitch is now able to reference path variables (pseudo-filing systems) through $, eg Music:$ for <Music$Path>. Writing to a path variable with multiple entries where a <path>$Write variable exists will now use the $Write directory for the operation.
  • FileSwitch no longer leaves streams open if a 'close' fails.
  • ResourceFS will now only issue 'changed' messages where the files changed are opened by it, thus reducing the impact on menus opened by the user when ShareFS discs become available over the network.
  • ParallelDeviceDriver is now capable of reading Device IDs. This allows the auto-detection of the make and model of Printer connected.
  • PCI memory reservation has been removed from the kernel, freeing 256M of logical address space for use by dynamic areas.
  • Conversions module has a minor for for ReadUnsigned returning an invalid V flag on some conversions.
  • ScreenBlanker now supports a second-level blanking using DPMS. ScreenBlanker no longer uses CMOS to get its initial settings and defaults to 'off'.
  • CDFS legacy support for built in conversions removed.
  • EvaluateExpression module takes over from the Kernel's OS_EvaluateExpression. Additionally, expressions can now extract directory or leaf names from a string, canonicalise a filename and generate a string from the current time.
Configuration tools
  • Softload ROM images are now sorted into date order, making selection of ROMs much simpler. ROM images are now supplied in archives together with their change lists; these lists are recorded with the ROM when installed to allow them to be viewed at a later date.
  • Resolver configuration is now able to locate DNS servers on the local network, even with bind variants.
  • Interface configuration can now take effect immediately, rather than requiring a reboot.
  • Re-written Filer configuration tool includes the new thumbnail configuration options.
  • All tools now warn if the configuration application is closed when changes have been made. Tools where changes have been made are indicated by a '*' in the title of the window, in line with standard RISC OS practice.
  • CPIShell is now able to be passed command line arguments to pass to the launched plugin. This is used to allow installation of components through Filer_Action (dragging over !Boot).
  • TimeSetup is now capable of setting the timezone.
Scrapfile naming

Previously, when a network interface is active on a machine the ScrapDirectory is set to a Directory named after the MAC Address of the first installed Network card. If NetFS was active, this would be replaced by the station ID.

With Select 3, the scrap directory naming is now based solely on the hardware configuration, as detected by HWScan. For most users this will be disabled and so the scrap directory will be named 'Disabled'.

New IconSetUp Configuration Tool

The new IconSetup configuration tool allows the setting of options for the standard IconBorderRound module. The following options are supported for buttons and borders :

  • Rounded edges with Small, Medium, Normal or Large curves
  • Apply to (sunken) writeable fields, display fields, or groups
  • 'Special' colour schemes with choice of Foreground and Background colour for Action buttons, Default buttons, and Groups

All the above colours may be applied as solid colour or as a tint of the original colour.

Furthermore button icons and information fields may have the colour applied as a Blend (top to bottom blend of the border colours, applying the button colour as a strong tint).

Button icons may have a rim highlight and may have either thick or thin borders.

Paint

The Paint application has been updated to support the new alpha-channel sprite format provided by Select 3. Paint can create sprites with alpha-channels, add an alpha-channel to an existing sprite, and allow editing of the alpha-channel.

Paint's user interface has also been brought up to date, with a separate attached toolbox for each sprite (similar to !Draw) so each sprite has it's own "working set" of toolbox settings. Shortcuts for zoom and select colour have been added along with a new colour display area. The menu tree has been revised to be more logical and Styleguide compliant.

Paint makes better use of the ImageFileConvert system in Select 3 and can directly load any filetypes supported by ImageFileConvert (PNG, JPEG, Clear, ICO, BMP etc). Paint allows saving of an image in JPEG and PNG format as well as sprite.

A good number of bug fixes and performance improvements have also been added along with usability features such as a true graphic brush display and improved clipboard support.

 


Return to section Index

 
© 3QD Developments Ltd 2013