Search Results for

    Show / Hide Table of Contents

    Class Toplevel

    Toplevel views can be modally executed.
    Inheritance
    System.Object
    Responder
    View
    Toplevel
    Border.ToplevelContainer
    Window
    Implements
    System.IDisposable
    System.ComponentModel.ISupportInitializeNotification
    System.ComponentModel.ISupportInitialize
    Inherited Members
    View.Added
    View.Removed
    View.Enter
    View.Leave
    View.MouseEnter
    View.MouseLeave
    View.MouseClick
    View.CanFocusChanged
    View.EnabledChanged
    View.VisibleChanged
    View.HotKey
    View.HotKeySpecifier
    View.Shortcut
    View.ShortcutTag
    View.ShortcutAction
    View.Data
    View.Driver
    View.Subviews
    View.TabIndexes
    View.TabIndex
    View.TabStop
    View.Id
    View.IsCurrentTop
    View.WantMousePositionReports
    View.WantContinuousButtonPressed
    View.Frame
    View.LayoutStyle
    View.Bounds
    View.X
    View.Y
    View.Width
    View.Height
    View.SuperView
    View.SetNeedsDisplay()
    View.ClearLayoutNeeded()
    View.SetNeedsDisplay(Rect)
    View.SetChildNeedsDisplay()
    View.Add(View[])
    View.BringSubviewToFront(View)
    View.SendSubviewToBack(View)
    View.SendSubviewBackwards(View)
    View.BringSubviewForward(View)
    View.Clear()
    View.Clear(Rect)
    View.ScreenToView(Int32, Int32)
    View.ClipToBounds()
    View.SetClip(Rect)
    View.DrawFrame(Rect, Int32, Boolean)
    View.DrawHotString(ustring, Attribute, Attribute)
    View.DrawHotString(ustring, Boolean, ColorScheme)
    View.Move(Int32, Int32)
    View.HasFocus
    View.OnAdded(View)
    View.OnRemoved(View)
    View.OnEnter(View)
    View.OnLeave(View)
    View.Focused
    View.MostFocused
    View.ColorScheme
    View.AddRune(Int32, Int32, Rune)
    View.ClearNeedsDisplay()
    View.DrawContent
    View.OnDrawContent(Rect)
    View.SetFocus()
    View.KeyPress
    View.ProcessHotKey(KeyEvent)
    View.KeyDown
    View.KeyUp
    View.EnsureFocus()
    View.FocusFirst()
    View.FocusLast()
    View.FocusPrev()
    View.FocusNext()
    View.LayoutStarted
    View.LayoutComplete
    View.Initialized
    View.LayoutSubviews()
    View.Text
    View.AutoSize
    View.TextAlignment
    View.VerticalTextAlignment
    View.TextDirection
    View.IsInitialized
    View.Enabled
    View.Visible
    View.Border
    View.ToString()
    View.OnMouseEnter(MouseEvent)
    View.OnMouseLeave(MouseEvent)
    View.OnMouseEvent(MouseEvent)
    View.OnMouseClick(View.MouseEventArgs)
    View.OnCanFocusChanged()
    View.OnEnabledChanged()
    View.OnVisibleChanged()
    View.Dispose(Boolean)
    View.BeginInit()
    View.EndInit()
    View.SetWidth(Int32, Int32)
    View.SetHeight(Int32, Int32)
    View.GetCurrentWidth(Int32)
    View.GetCurrentHeight(Int32)
    View.GetNormalColor()
    Responder.Dispose()
    System.Object.Equals(System.Object)
    System.Object.Equals(System.Object, System.Object)
    System.Object.GetHashCode()
    System.Object.GetType()
    System.Object.MemberwiseClone()
    System.Object.ReferenceEquals(System.Object, System.Object)
    Namespace: Terminal.Gui
    Assembly: Terminal.Gui.dll
    Syntax
    public class Toplevel : View, IDisposable, ISupportInitializeNotification, ISupportInitialize
    Remarks

    Toplevels can be modally executing views, started by calling Run(Toplevel, Func<Exception, Boolean>). They return control to the caller when RequestStop(Toplevel) has been called (which sets the Running property to false).

    A Toplevel is created when an application initializes Terminal.Gui by calling Init(ConsoleDriver, IMainLoopDriver). The application Toplevel can be accessed via Top. Additional Toplevels can be created and run (e.g. Dialogs. To run a Toplevel, create the Toplevel and call Run(Toplevel, Func<Exception, Boolean>).

    Toplevels can also opt-in to more sophisticated initialization by implementing System.ComponentModel.ISupportInitialize. When they do so, the System.ComponentModel.ISupportInitialize.BeginInit() and System.ComponentModel.ISupportInitialize.EndInit() methods will be called before running the view. If first-run-only initialization is preferred, the System.ComponentModel.ISupportInitializeNotification can be implemented too, in which case the System.ComponentModel.ISupportInitialize methods will only be called if System.ComponentModel.ISupportInitializeNotification.IsInitialized is false. This allows proper View inheritance hierarchies to override base class layout code optimally by doing so only on first run, instead of on every run.

    Constructors

    Toplevel()

    Initializes a new instance of the Toplevel class with Computed layout, defaulting to full screen.
    Declaration
    public Toplevel()

    Toplevel(Rect)

    Initializes a new instance of the Toplevel class with the specified absolute layout.
    Declaration
    public Toplevel(Rect frame)
    Parameters
    Type Name Description
    Rect frame A superview-relative rectangle specifying the location and size for the new Toplevel

    Properties

    CanFocus

    Gets or sets a value indicating whether this Toplevel can focus.
    Declaration
    public override bool CanFocus { get; }
    Property Value
    Type Description
    System.Boolean true if can focus; otherwise, false.
    Overrides
    View.CanFocus

    IsMdiChild

    Gets or sets if this Toplevel is a Mdi child.
    Declaration
    public bool IsMdiChild { get; }
    Property Value
    Type Description
    System.Boolean

    IsMdiContainer

    Gets or sets if this Toplevel is a Mdi container.
    Declaration
    public bool IsMdiContainer { get; set; }
    Property Value
    Type Description
    System.Boolean

    MenuBar

    Gets or sets the menu for this Toplevel
    Declaration
    public virtual MenuBar MenuBar { get; set; }
    Property Value
    Type Description
    MenuBar

    Modal

    Determines whether the Toplevel is modal or not. Causes ProcessKey(KeyEvent) to propagate keys upwards by default unless set to true.
    Declaration
    public bool Modal { get; set; }
    Property Value
    Type Description
    System.Boolean

    Running

    Gets or sets whether the MainLoop for this Toplevel is running or not.
    Declaration
    public bool Running { get; set; }
    Property Value
    Type Description
    System.Boolean
    Remarks
    Setting this property directly is discouraged. Use RequestStop(Toplevel) instead.

    StatusBar

    Gets or sets the status bar for this Toplevel
    Declaration
    public virtual StatusBar StatusBar { get; set; }
    Property Value
    Type Description
    StatusBar

    Methods

    Add(View)

    Declaration
    public override void Add(View view)
    Parameters
    Type Name Description
    View view
    Overrides
    View.Add(View)

    Create()

    Convenience factory method that creates a new Toplevel with the current terminal dimensions.
    Declaration
    public static Toplevel Create()
    Returns
    Type Description
    Toplevel The create.

    GetTopMdiChild(Type, String[])

    Gets the current visible toplevel Mdi child that match the arguments pattern.
    Declaration
    public View GetTopMdiChild(Type type = null, string[] exclude = null)
    Parameters
    Type Name Description
    System.Type type The type.
    System.String[] exclude The strings to exclude.
    Returns
    Type Description
    View The matched view.

    MouseEvent(MouseEvent)

    Declaration
    public override bool MouseEvent(MouseEvent mouseEvent)
    Parameters
    Type Name Description
    MouseEvent mouseEvent
    Returns
    Type Description
    System.Boolean
    Overrides
    Responder.MouseEvent(MouseEvent)

    MoveNext()

    Move to the next Mdi child from the MdiTop.
    Declaration
    public virtual void MoveNext()

    MovePrevious()

    Move to the previous Mdi child from the MdiTop.
    Declaration
    public virtual void MovePrevious()

    OnKeyDown(KeyEvent)

    Declaration
    public override bool OnKeyDown(KeyEvent keyEvent)
    Parameters
    Type Name Description
    KeyEvent keyEvent
    Returns
    Type Description
    System.Boolean
    Overrides
    View.OnKeyDown(KeyEvent)

    OnKeyUp(KeyEvent)

    Declaration
    public override bool OnKeyUp(KeyEvent keyEvent)
    Parameters
    Type Name Description
    KeyEvent keyEvent
    Returns
    Type Description
    System.Boolean
    Overrides
    View.OnKeyUp(KeyEvent)

    PositionCursor()

    Declaration
    public override void PositionCursor()
    Overrides
    View.PositionCursor()

    PositionToplevel(Toplevel)

    Virtual method which allow to be overridden to implement specific positions for inherited Toplevel.
    Declaration
    public virtual void PositionToplevel(Toplevel top)
    Parameters
    Type Name Description
    Toplevel top The toplevel.

    ProcessColdKey(KeyEvent)

    Declaration
    public override bool ProcessColdKey(KeyEvent keyEvent)
    Parameters
    Type Name Description
    KeyEvent keyEvent
    Returns
    Type Description
    System.Boolean
    Overrides
    View.ProcessColdKey(KeyEvent)

    ProcessKey(KeyEvent)

    Declaration
    public override bool ProcessKey(KeyEvent keyEvent)
    Parameters
    Type Name Description
    KeyEvent keyEvent
    Returns
    Type Description
    System.Boolean
    Overrides
    View.ProcessKey(KeyEvent)

    Redraw(Rect)

    Declaration
    public override void Redraw(Rect bounds)
    Parameters
    Type Name Description
    Rect bounds
    Overrides
    View.Redraw(Rect)

    Remove(View)

    Declaration
    public override void Remove(View view)
    Parameters
    Type Name Description
    View view
    Overrides
    View.Remove(View)

    RemoveAll()

    Declaration
    public override void RemoveAll()
    Overrides
    View.RemoveAll()

    RequestStop()

    Stops running this Toplevel.
    Declaration
    public virtual void RequestStop()

    RequestStop(Toplevel)

    Stops running the top Toplevel.
    Declaration
    public virtual void RequestStop(Toplevel top)
    Parameters
    Type Name Description
    Toplevel top The toplevel to request stop.

    ShowChild(Toplevel)

    Shows the Mdi child indicated by the top setting as Current.
    Declaration
    public virtual bool ShowChild(Toplevel top = null)
    Parameters
    Type Name Description
    Toplevel top The toplevel.
    Returns
    Type Description
    System.Boolean true if the toplevel can be showed.false otherwise.

    WillPresent()

    Invoked by Begin(Toplevel) as part of the Run(Toplevel, Func<Exception, Boolean>) after the views have been laid out, and before the views are drawn for the first time.
    Declaration
    public virtual void WillPresent()

    Events

    Activate

    Invoked once the Toplevel's Application.RunState becomes the Current.
    Declaration
    public event Action<Toplevel> Activate
    Event Type
    Type Description
    System.Action<Toplevel>

    AllChildClosed

    Invoked once the last child Toplevel's Application.RunState is closed from the Terminal.Gui.Application.End(Terminal.Gui.View)
    Declaration
    public event Action AllChildClosed
    Event Type
    Type Description
    System.Action

    ChildClosed

    Invoked once the child Toplevel's Application.RunState is closed from the Terminal.Gui.Application.End(Terminal.Gui.View)
    Declaration
    public event Action<Toplevel> ChildClosed
    Event Type
    Type Description
    System.Action<Toplevel>

    ChildLoaded

    Invoked once the child Toplevel's Application.RunState has begin loaded.
    Declaration
    public event Action<Toplevel> ChildLoaded
    Event Type
    Type Description
    System.Action<Toplevel>

    ChildUnloaded

    Invoked once the child Toplevel's Application.RunState has begin unloaded.
    Declaration
    public event Action<Toplevel> ChildUnloaded
    Event Type
    Type Description
    System.Action<Toplevel>

    Closed

    Invoked once the Toplevel's Application.RunState is closed from the Terminal.Gui.Application.End(Terminal.Gui.View)
    Declaration
    public event Action<Toplevel> Closed
    Event Type
    Type Description
    System.Action<Toplevel>

    Closing

    Invoked once the Toplevel's Application.RunState is being closing from the RequestStop(Toplevel)
    Declaration
    public event Action<ToplevelClosingEventArgs> Closing
    Event Type
    Type Description
    System.Action<ToplevelClosingEventArgs>

    Deactivate

    Invoked once the Toplevel's Application.RunState ceases to be the Current.
    Declaration
    public event Action<Toplevel> Deactivate
    Event Type
    Type Description
    System.Action<Toplevel>

    Loaded

    Fired once the Toplevel's Application.RunState has begin loaded. A Loaded event handler is a good place to finalize initialization before calling `RunLoop(Application.RunState, Boolean).
    Declaration
    public event Action Loaded
    Event Type
    Type Description
    System.Action

    Ready

    Fired once the Toplevel's MainLoop has started it's first iteration. Subscribe to this event to perform tasks when the Toplevel has been laid out and focus has been set. changes. A Ready event handler is a good place to finalize initialization after calling `Run(Func<Exception, Boolean>)(topLevel)`.
    Declaration
    public event Action Ready
    Event Type
    Type Description
    System.Action

    Unloaded

    Fired once the Toplevel's Application.RunState has begin unloaded. A Unloaded event handler is a good place to disposing after calling `End(Application.RunState).
    Declaration
    public event Action Unloaded
    Event Type
    Type Description
    System.Action

    Implements

    System.IDisposable
    System.ComponentModel.ISupportInitializeNotification
    System.ComponentModel.ISupportInitialize
    In This Article
    Back to top Generated by DocFX