Skip to content

Latest commit

 

History

History
327 lines (194 loc) · 9.22 KB

README.md

File metadata and controls

327 lines (194 loc) · 9.22 KB

starview

screenshot of starview

A simple no-frills windowing + management enviroment influnced by SunView.

Starview is unsually light, requiring about #MB/#KB of RAM, it can run on:

  • Sega dreamcast

  • AtariST Falcon

  • Amiga 3000UX +

  • IBM-PC compatible with a i386 and at least a hercules monochrome graphics card.

  • Sun 3/50

  • DEC VAXStation

  • And anything above the specs of those machines. In short- it can run on a machine consitered a patato in today's specs.

Usage

starview is simply started via the command starview. However, due to partly a choice of not using conventions expected of today's GUI's and due to design choices to ensure a unusally small size (target platforms do include several m68k machines, dreamcast, acorn RISC-PC, late-model VAX systems, i386 +, m88k, & possibly all of the total systems that the current BSD's support that do support graphics & have at least 10MB(expected base OS usage is roughly 5ish) ), starview may not handle like you'd expect it to:

  • what would be commonly called a window is a frame here.

  • Only two titlebar buttons on each side, depending upon what mouse- button you press:

    *left corner: right- close, left- iconify.

    *titlebar: right- move, left- resize.

    *right corner(may be absent in some versions): right- push back on z-order; left- push fowards on z-order.

  • much of the included apps (excluding terminal) don't use a main or context menus, said functionalty expected from menus may be found in the toolbar-like application rows.

  • not much in the way of persionalation, the only options are foreground & background hues.

  • the inabilty to resize windows beyond the left & top sides of the screen.

  • resizing will relocate the cursor to the lower right corrner of the frame.

  • In line with older systems, but not modern ones usally- resizing & movement are indicated via a outline.

  • A noticable lack of colors expect black & white, this is on purpose and for 1-bit graphics using systems. Implemtations on color-using systems can have the widgets use their own background & foreground colors as needed.

Also starview requires at least a 2-button mouse. While it can be configured to use more then 2-buttons (for instance on systems of where a 3-button or more mouse is natual), the deafults assume a 2-button one. In the event that there are no 2-button mice used with the system (eg-m68k color macs)- alt/option + click emulates a 2nd button.

Included apps

The applications found in with a standard install of starview are:

  • Edd: the text editor.

  • Espy: the sunOS Organizer-esque file manager.

  • Terminal: the terminal emulator.

  • veh: feh-like image-viewer. Can use color on systems that use it.

  • SheetCalc: Very-no-frills spreadsheet app.

  • edvis: the starview pixmap editor.

  • rake: simple music tracker on systems that support sound.

  • pig: I/O pin peeker & poker on systems with user-accesable GPIO pins (eg- the raspberry Pi & alike systems).

  • hyperbole: general purpose visual markup viewer, includes support for:

    • HTML on par with netscape 2.0 + tables.

    • genimani.

    • markdown.

  • parcel: the mail(1) & email client + viewer.

  • heat: CPU usage history, GPU usage history, RAM usage history, storage usage history, network usage history, & heat indicator.

  • VTime: On-system clock and date.

  • runlist: active applications list.

  • scorch: application terminator akin to xkill.

  • visxit: Visual session exit wizard, can be canceled.

Configuration

Starview is configured in a manner not unlike sunview, in using a .starview file found in the user's directory that has a mostly simular synthex to X11 that's easier to remember.

Avaible options are:

  • Background(mandatory on color systems):

  • Foreground(manadatory on color systems):

  • RootFrameBg(optional on color systems): Background color seprate from the main background color.

  • RootFrameFg(optional on color systems): Foreground color seprate from the main foreground color.

  • ShadowBg(optional on color systems): Background color seprate from the main background color.

  • ShadowFg(optional on color systems): Foreground color seprate from the main foreground color.

  • SelectBg:Background color seprate from the main background color.

  • SelectFg:Foreground color seprate from the main foreground color.

  • inverted: Inverts the background and foreground colors.

  • rootFramePixmap: The pixmap to use with the root-frame.

  • shadowPixmap: the pixmap for the shadows to use.

  • titleFont: Font used for titlebars.

  • titleJustify: State where the titlebar text should be, options are:

    -left

    -center

    -right

Default is left.

  • appFont: Default font used for applications, hover-context, & menus.

  • hideAction: Hide the action button that's usally visable on the lefthand side of the titlebar.

  • action button(can be excluded from view):

    *function1: shrink

    *function2: close

  • Titlebar:

    *function1: move

    *function2: resize

  • thruster(can be excluded from implemation):

    *function1: lower

    *function2: arise

*quickExit: Usually meant to be a shortcut to quickly exit starview without asking, default keyboard shortcut is Ctrl+alt+esc.

Developing for starview

As said with using starview, devloping apps for it is not what you had encounted before, while it's somewhat more simple, it is a fair amount more constrained if you are using built in functions:

*All aplications include a static icon, said icon is shown by espy or on the root- frame when shrunk..

  • an rather bare-bones included widget set, while the included libs allow for custom widgets, said built-in widget set is small in amount mainly for the least amount of disk-space:

    • button: it can have one item in it (usually a label or image). can have but not recomended to have diffent actions depending upon what mouse button was pressed.

    if needed (but not recomended usually), a button can not show a frame around it (that also includes the shadow), pressing on it inverts the widget area, the button's disabled apperance is slightly "grey"ed out.

    Starview's interactive bits of the frames are composed of frameless buttons.

    • label: is much like the commonly expected label widget.

    label is expected to be the most inherented built-in widget aside from the hover-labels that also use it. it can have the text justifcations of:

      -left
    
      -center
    
      -right
    
    • image: like label, but in place of text- a specified pixmap. Has the following options:

      -none: Don't repeat

      -tile: Do repeat

    starview's root-frame background uses a repeating image.

    • hover-label: used by many of the widgets for context help on hover, it is much like what's found on other platforms.

    • text-field: a area outlined by a black rectangle that can have user-input text entered into it. it's disabled apperance is indisguisable from a disabled frameless button.

    • view-area: the widget most expected to be extended via non-included widgets. It can show items in:

      -coloumns

      -rows

      -rows overflowing into coloumns 'flowrow'

      -coloumns overflowing into rows 'flowcoloumn'

    if desired, the view-area can be set to have item-wraping by the dev or the user.

    • slider: sliders & scrollbars are the one & the same in terms of how they are programed and their apperance in starview. can be set with:

      -width

      -slider size

    • menu: Is much like the modern expected behavior of a menu. can be summoned by right mouse button clicks or widget buttons. Always at the top of the z-order. Menu subwidgets include:

      -menu: Menus can contain other menus.

      -action: A simple button, like any button it can be disabled.

      -toggle:

    • tables: akin to HTML layout tables, can have a border or said border to be invisable. Has the following options:

      -coloumns

      -rows

      -rows overflowing into coloumns 'flowrow'

      -coloumns overflowing into rows 'flowcoloumn'

      -rows overflowing into a button 'row_to1'

      -coloumns overflowing into a button 'coloumn_to1'

      • toggle: a button or series of buttons
  • There are also two main types of frames avaible:

    • normal: the normal frame type.

    • widgets: widget frames, these can be told to go at the topmost or bottommost z-order as needed, has the following subtypes:

      -dialog windows: stuck +1 to the summoning parent app's z-order, will hold parent app's input until delt with.

Modfying & compiling starview

Starview never is distrubited in a fat binary, the user or sysadmin is expected to compile Starview before deployment. The following compile flags are given:

  • _MONObit: Use 1-bit color. disables all color usage & options.

  • _no-selectHue:Do not make selected items unique in hue choice

*_no-RootHue:Do not make root-frame unique in hue choice

*_noShadowHue:Do not make shadows unique in hue choice, ignored if shadows are disabled.

*_no-InvSelectFrames: Do not invert hues on active frame.

*_no-InactiveOutline: Do not draw SunView-esque outlines on the windows.

*_no-Shadows: Do not draw shadows.

*_no-Thrust: Do not draw amiga-esque thrust buttons in the titlebar.

*_UseAltKey: Use the alt/option key in condunction with mouse button1 to emulate a right button click.

In order to have starview compile without make or the comilier complaining, one has to use the platform flags:

  • free = FreeBSD

  • net = NetBSD

  • open = OpenBSD

  • sunos = Solaris & illumos