Bunifu.UI.WinForms.BunifuToolTip
Provides enhanced ToolTips with a set of customzation
options to distinctly match your design needs.
Initializes a new instance of the class.
Initializes a new instance of the class with a specified container.
An that represents the container of the ToolTip.
Gets or sets a value indicating whether the ToolTip is active.
Tooltips will only appear if this property is set to .
Gets or sets a value indicating whether to allow conversion
of newline characters in content to HTML break tags.
Determines if the tool tip will be displayed always,
even when the parent window is not active.
Gets or sets a value indicating whether the ToolTip will display
icons if the associated control or controls have specified one.
When set to true, all ToolTip titles set in each control will be
replaced with the default ToolTip Title set in the Properties window.
When set to true, the will be aligned horizontally with the
position. This is especially useful whenever the ToolTipIcon is set.
Gets or sets a value indicating whether display-shadows
will be provided around the ToolTip's borders.
Gets or sets a value indicating whether standard
borders will be drawn around the ToolTip's region.
When set to true, a fade effect is used
when ToolTips are shown or hidden.
When set to true, the ToolTip will be closed automatically when a set period
of time provided by the property 'AutoCloseDuration', is given. However, when
set to false, the ToolTip will be closed once the mouse leaves the associated control.
Gets or sets the ToolTip's inner padding between the container
and its content, that is, the Title and Text information. Use
the 'TextMargin' property to set the vertical distance between
the ToolTip's Title and Text.
Gets or sets the object that contains programmer-supplied data associated with the ToolTip.
Gets or sets the global ToolTipTitle to be implemented
across all associated controls within the parent control.
Gets or sets the opacity of transparency-level of the ToolTip.
Gets or sets the length of time, in milliseconds, it takes before the ToolTip is shown.
Gets or sets the length of time, in milliseconds, it takes before subsequent ToolTips are shown.
Gets or sets the length of time, in milliseconds, that the ToolTip will be displayed.
This property is enabled whenever the property 'AllowAutoClose' is set to true.
The minimum required duration should be greater-than or equal-to 100 (milliseconds).
Gets or sets the ToolTip's entry animation speed in milliseconds.
(Default is 350 milliseconds)
Gets or sets the ToolTip's exit animation speed in milliseconds.
(Default is 200 milliseconds)
Gets or sets the margin (distance) between the ToolTipIcon and ToolTipTitle.
Gets or sets the ToolTip's Text margin, that is,
the distance between the Title and the Text. (Default is 2)
Gets or sets the ToolTip's background color.
Gets or sets the ToolTip's border color.
Gets or sets the ToolTip's Title Fore Color.
Gets or sets the ToolTip's Text ForeColor.
Gets or sets the ToolTip's Title Font.
Gets or sets the ToolTip's Text Font.
Associates ToolTip text with the specified control.
The to associate the ToolTip text with.
The ToolTip text to display when the pointer is on the control.
Retrieves the ToolTip text associated with the specified control.
The for which to retrieve the
text.
A containing the ToolTip text for the specified control.
Associates ToolTip icon with the specified control.
The to associate the ToolTip icon with.
The ToolTip icon to be applied when the ToolTip is displayed.
Retrieves the ToolTip icon associated with the specified control.
The for which to retrieve the icon.
A containing the ToolTip icon for the specified control.
Associates ToolTip title with the specified control.
The to associate the ToolTip title with.
The ToolTip title to display when the pointer is on the control.
Retrieves the ToolTip title associated with the specified control.
The for which to retrieve the title.
A containing the ToolTip title for the specified control.
Determines if the ToolTip is currently visible.
Gets or sets a control that will be displayed in the
ToolTip in-place of the standard ToolTip's view.
Gets or sets a value indicating whether the attached
will be displayed
once a user clicks on the associated ToolTip control.
When set to true, the closing duration will be automagically generated
based on the size of content, that is, the ToolTipTitle and ToolTipText.
Gets or sets the ToolTip's position within the client region.
Gets or sets the name of the component.
Sets the ToolTip content to be associated with the specified control and displays the ToolTip.
The control bound or associated with the ToolTip.
A containing the new ToolTip text.
Sets the ToolTip content to be associated with the specified control and displays the ToolTip.
The control bound or associated with the ToolTip.
A containing the new ToolTip text.
A containing the new ToolTip title.
Sets the ToolTip content to be associated with the specified control and displays the ToolTip.
The control bound or associated with the ToolTip.
A containing the new ToolTip text.
A containing the new ToolTip title.
An to be applied as the ToolTip's icon.
Sets the ToolTip content to be associated with the specified control and displays the ToolTip.
The control bound or associated with the ToolTip.
A containing the new ToolTip text.
A containing the new ToolTip title.
An to be applied as the ToolTip's icon.
The set ToolTip's location once displayed.
Hides the ToolTip when displayed in any associated control(s).
Removes all the applied ToolTips currently associated with the ToolTip component.
Returns true if the ToolTip can offer an extender property to the specified target
component.
The target object to add an extender property to.
Returns true if the class can offer
one or more extender properties; otherwise, false.
Raised whenever the ToolTip is being shown.
Raised whenever the ToolTip is being closed.
Provides data for the ToolTip's event.
Provides data for the ToolTip's event.
Gets the control for which the is being drawn.
Gets the number of times this
has been displayed to the user.
Gets the window to which this is bound.
Gets the size of the when shown.
Gets the location of the when shown.
Gets the current ToolTip Title.
Gets the current ToolTip Text.
Gets the current ToolTip Icon.
Initializes a new instance of the class.
Implementation of this abstract method creates Smart Tag items,
associates their targets, and collects them into a list.
Required designer variable.
Clean up any resources being used.
true if managed resources should be disposed; otherwise, false.
Required method for Designer support - do not modify
the contents of this method with the code editor.
Interface for all types we can perform transitions on.
Each type (e.g. int, double, Color) that we can perform a transition on
needs to have its own class that implements this interface. These classes
tell the transition system how to act on objects of that type.
Returns the Type that the instance is managing.
Returns a deep copy of the object passed in. (In particular this is
needed for types that are objects.)
Returns an object holding the value between the start and end corresponding
to the percentage passed in. (Note: the percentage can be less than 0% or
greater than 100%.)
Called by the Transition framework when its timer ticks to pass in the
time (in ms) since the transition started.
You should return (in an out parameter) the percentage movement towards
the destination value for the time passed in. Note: this does not need to
be a smooth transition from 0% to 100%. You can overshoot with values
greater than 100% or undershoot if you need to (for example, to have some
form of "elasticity").
The percentage should be returned as (for example) 0.1 for 10%.
You should return (in an out parameter) whether the transition has completed.
(This may not be at the same time as the percentage has moved to 100%.)
Class that manages transitions for Color properties. For these we
need to transition the R, G, B and A sub-properties independently.
Returns the type we are managing.
Returns a copy of the color object passed in.
Creates an intermediate value for the colors depending on the percentage passed in.
Manages transitions for double properties.
Returns the type managed by this class.
Returns a copy of the double passed in.
Returns the value between start and end for the percentage passed in.
Returns the type we're managing.
Returns a copy of the float passed in.
Returns the interpolated value for the percentage passed in.
Manages transitions for int properties.
Returns the type we are managing.
Returns a copy of the int passed in.
Returns the value between the start and end for the percentage passed in.
Manages transitions for strings. This doesn't make as much sense as transitions
on other types, but I like the way it looks!
Returns the type we're managing.
Returns a copy of the string passed in.
Returns an "interpolated" string.
Lets you perform animated transitions of properties on arbitrary objects. These
will often be transitions of UI properties, for example an animated fade-in of
a UI object, or an animated move of a UI object from one position to another.
Each transition can simulataneously change multiple properties, including properties
across multiple objects.
Example transition
------------------
a. Transition t = new Transition(new TransitionMethod_Linear(500));
b. t.add(form1, "Width", 500);
c. t.add(form1, "BackColor", Color.Red);
d. t.run();
Line a: Creates a new transition. You specify the transition method.
Lines b. and c: Set the destination values of the properties you are animating.
Line d: Starts the transition.
Transition methods
------------------
TransitionMethod objects specify how the transition is made. Examples include
linear transition, ease-in-ease-out and so on. Different transition methods may
need different parameters.
You should register all managed-types here.
Args passed with the TransitionCompletedEvent.
Event raised when the transition hass completed.
Creates and immediately runs a transition on the property passed in.
Sets the property passed in to the initial value passed in, then creates and
immediately runs a transition on it.
Creates a TransitionChain and runs it.
Constructor. You pass in the object that holds the properties
that you are performing transitions on.
Adds a property that should be animated as part of this transition.
Starts the transition.
Property that returns a list of information about each property managed
by this transition.
We remove the property with the info passed in from the transition.
Called when the transition timer ticks.
Sets a property on the object passed in to the value passed in. This method
invokes itself on the GUI thread if the property is being invoked on a GUI
object.
Returns true if the object passed in is a Control and is disposed
or in the process of disposing. (If this is the case, we don't want
to make any changes to its properties.)
Registers a transition-type. We hold them in a map.
Runs the next transition in the list.
Called when the transition we have just run has completed.
Constructor.
The percentage of elapsed time, expressed as (for example) 75 for 75%.
The value of the animated properties at the EndTime. This is the percentage
movement of the properties between their start and end values. This should
be expressed as (for example) 75 for 75%.
The interpolation method to use when moving between the previous value
and the current one.
This class is responsible for running transitions. It holds the timer that
triggers transaction animation.
This class is a singleton.
We manage the transaction timer here so that we can have a single timer
across all transactions. If each transaction has its own timer, this creates
one thread for each transaction, and this can lead to too many threads in
an application.
This class essentially just manages the timer for the transitions. It calls
back into the running transitions, which do the actual work of the transition.
Singleton's getInstance method.
You register a transition with the manager here. This will start to run
the transition as the manager's timer ticks.
Checks if any existing transitions are acting on the same properties as the
transition passed in. If so, we remove the duplicated properties from the
older transitions.
Finds any properties in the old-transition that are also in the new one,
and removes them from the old one.
Private constructor (for singleton).
Called when the timer ticks.
Called when a transition has completed.
Manages transitions under constant acceleration from a standing start.
Constructor. You pass in the time that the transition
will take (in milliseconds).
Works out the percentage completed given the time passed in.
This uses the formula:
s = ut + 1/2at^2
The initial velocity is 0, and the acceleration to get to 1.0
at t=1.0 is 2, so the formula just becomes:
s = t^2
This transition bounces the property to a destination value and back to the
original value. It is accelerated to the destination and then decelerated back
as if being dropped with gravity and bouncing back against gravity.
Constructor. You pass in the total time taken for the bounce.
This transition animates with an exponential decay. This has a damping effect
similar to the motion of a needle on an electomagnetically controlled dial.
Constructor. You pass in the time that the transition
will take (in milliseconds).
Manages a transition starting from a high speed and decelerating to zero by
the end of the transition.
Constructor. You pass in the time that the transition
will take (in milliseconds).
Works out the percentage completed given the time passed in.
This uses the formula:
s = ut + 1/2at^2
The initial velocity is 2, and the acceleration to get to 1.0
at t=1.0 is -2, so the formula becomes:
s = t(2-t)
Manages an ease-in-ease-out transition. This accelerates during the first
half of the transition, and then decelerates during the second half.
Constructor. You pass in the time that the transition
will take (in milliseconds).
Works out the percentage completed given the time passed in.
This uses the formula:
s = ut + 1/2at^2
We accelerate as at the rate needed (a=4) to get to 0.5 at t=0.5, and
then decelerate at the same rate to end up at 1.0 at t=1.0.
This transition type 'flashes' the properties a specified number of times, ending
up by reverting them to their initial values. You specify the number of bounces and
the length of each bounce.
You specify the number of bounces and the time taken for each bounce.
This class manages a linear transition. The percentage complete for the transition
increases linearly with time.
Constructor. You pass in the time (in milliseconds) that the
transition will take.
We return the percentage completed.
This transition bounces the property to a destination value and back to the
original value. It is decelerated to the destination and then acclerated back
as if being thrown against gravity and then descending back with gravity.
Constructor. You pass in the total time taken for the bounce.
This class allows you to create user-defined transition types. You specify these
as a list of TransitionElements. Each of these defines:
End time , End value, Interpolation method
For example, say you want to make a bouncing effect with a decay:
EndTime% EndValue% Interpolation
-------- --------- -------------
50 100 Acceleration
75 50 Deceleration
85 100 Acceleration
91 75 Deceleration
95 100 Acceleration
98 90 Deceleration
100 100 Acceleration
The time values are expressed as a percentage of the overall transition time. This
means that you can create a user-defined transition-type and then use it for transitions
of different lengths.
The values are percentages of the values between the start and end values of the properties
being animated in the transitions. 0% is the start value and 100% is the end value.
The interpolation is one of the values from the InterpolationMethod enum.
So the example above accelerates to the destination (as if under gravity) by
t=50%, then bounces back up to half the initial height by t=75%, slowing down
(as if against gravity) before falling down again and bouncing to decreasing
heights each time.
Constructor.
Constructor. You pass in the list of TransitionElements and the total time
(in milliseconds) for the transition.
Sets up the transitions.
Called to find the value for the movement of properties for the time passed in.
Returns the element info for the time-fraction passed in.
A class holding static utility functions.
Returns the value of the property passed in.
Sets the value of the property passed in.
Returns a value between d1 and d2 for the percentage passed in.
Returns a value betweeen i1 and i2 for the percentage passed in.
Returns a value betweeen f1 and f2 for the percentage passed in.
Converts a fraction representing linear time to a fraction representing
the distance traveled under an ease-in-ease-out transition.
Converts a fraction representing linear time to a fraction representing
the distance traveled under a constant acceleration transition.
Converts a fraction representing linear time to a fraction representing
the distance traveled under a constant deceleration transition.
Fires the event passed in in a thread-safe way.
This method loops through the targets of the event and invokes each in turn. If the
target supports ISychronizeInvoke (such as forms or controls) and is set to run
on a different thread, then we call BeginInvoke to marshal the event to the target
thread. If the target does not support this interface (such as most non-form classes)
or we are on the same thread as the target, then the event is fired on the same
thread as this is called from.
Provides button-like capabilities and image manipulation features when working with images.
Provides flip-orientation options for images.
Flip image to normal view.
Flip image horizontally.
Flip image vertically.
Provides the various supported image-states
generated from the applied Image.
Returns the normal image.
Returns a totally blurred image.
Returns a medially blurred image.
Returns a partially blurred image.
Gets or sets the distance between the container and the underlying image.
Gets or sets the distance between the container and the underlying image.
Gets or sets the angle of rotation for the image.
Please provide a value between 0 and 360.
Gets or sets the time in milliseconds the zooming animation takes when active.
Flips the image to any given orientation.
Supports both Vertical and Horizontal orientation-flipping options.
Gets or sets the image displayed in the image button.
(This property has been deprecated as of version 1.6.0.0. Please use the property 'ActiveImage' instead.)
Gets or sets the image to be applied whenever the image button is active or hovered onto.
Gets or sets the image to be applied whenever the image button is active or hovered onto.
Gets or sets the default image size.
Gets or sets the maximum size of the image when hovered onto or active.
This defaults to the standard set size of the control.
Allows you to easily get or set some ToolTip information to
be displayed to the user on mouse-hovering over the control.
Gets or sets a value indicating whether the control
will show cursor changes during mouse-hover events.
Sets a value indicating whether the 'ActiveImage'
will be applied on mouse-hover.
Gets or sets a value indicating whether zooming is enabled.
Gets or sets a value indicating whether animations are enabled.
Automatically fades the image when inactive.
Gets a value indicating whether the image button is currently zoomed-in.
Gets or sets a value indicating whether the size markers
displayed at the control's top-area will be visible during design-time.
Gets or sets a value indicating whether borders will
be viewed for the image applied during design-time.
Overrides the CreateParams method to stop flickering issues
by setting the "WS_EX_COMPOSITED" (0x02000000) style.
Gets or sets the path or URL for the image to display in the Image Button.
Gets or sets a value indicating whether an image is loaded synchronously.
Gets or sets the image displayed in the Image
Button when the main image is loading.
Gets or sets the image displayed in the Image
Button when an error occurs during the image-loading
process or if the image load is canceled.
Calculates the correct image-size as per the applied state.
Renders the required image as per the applied state.
The image-state-type to be used.
Renders the required image as per the applied state.
The image-state to be used.
Zooms in the image to the preset size.
Zooms out the image to its default size.
Rotates the image to a set angle of rotation.
Allow animation the rotation event? If yes, the rotation will be animated from one angle to another.
The angle of rotation to apply. Please provide a value between 0 and 360.
The rotating animation speed in milliseconds to apply. Default speed is 500(ms).
Sets the ImageLocation to the specified URL and displays the image indicated.
The path for the image to display in the Image Button.
Exceptions:
Thrown if url is null or an empty string.
Thrown if url refers to an image on the Web that cannot be accessed.
Thrown if url refers to a file that is not an image.
Thrown if url refers to a file that does not exist.
Displays the image specified by the ImageLocation property of the Image Button.
Exceptions:
Thrown if ImageLocation is null or an empty string.
Loads the image asynchronously.
Loads the image at the specified location, asynchronously.
The path for the image to display in the Image Button.
Cancels an asynchronous image load.
Determines whether the hosting process is in design-mode.
Required designer variable.
Clean up any resources being used.
true if managed resources should be disposed; otherwise, false.
Required method for Designer support - do not modify
the contents of this method with the code editor.
Image-rendering extensions class for Bunifu Image Button.
Provides flip-orientation options for image containers.
Flip image to normal setting.
Flip image horizontally.
Flip image vertically.
Rotates an image container to a specified angle or degree.
The graphics object to be used.
The angle of rotation.
The final width of the image.
The final height of the image.
Flips an image container to a specified position.
The graphics object to be used.
The flip orientation.
The final width of the image.
The final height of the image.
Flips an image container to a specified position.
The graphics object to be used.
The flip orientation.
Flips an image container to a specified position without an angle of rotation.
The flip orientation.
Provides rich HTML text-rendering capabilities with native CSS 2.0 styling enhancements and inline style-tags.
Creates a new Bunifu Label.
Bunifu Label Text Alignments options.
Positions the text to the Left of the container.
Positions the text to the Right of the container.
Positions the text to the Center of the container.
Provides a list of text-formatting options
for Bunifu Labels.
Retains the default text format.
Converts the text to upper-case.
Converts the text to lower-case.
Converts the text to title-case.
Converts the text to sentence-case.
Gets or sets a value indicating whether the label will inherit
its parent font and fore color properties.
Gets or sets the label text.
Gets or sets the background color of the label.
The text rendering hint to be used for rendering text.
The text rendering hint.
Gets or sets the border style.
The border style.
Gets or sets the font of the text displayed by the control.
Gets or sets the foreground color of the label.
The color of the label.
Gets or sets a value indicating whether control's elements are aligned to support
locales using right-to-left fonts. You can also use the following inline CSS style:
style="text-align: right; direction: Rtl;"
Determines the position of the text within the label.
Provides a number of text-formatting options.
Determines the position of the text within the label.
(This property is no longer supported. Please use 'TextAlignment' instead.)
Gets or sets the cursor that is displayed when the mouse pointer is over the control.
The cursor.
Gets or sets the ellipsis format to be applied whenever the range of text exceeds the control's width.
Gets or sets a value indicating whether the ellipsis character (...) appears at the right edge (default position)
of the control, denoting that the label's text extends beyond the length of the label.
This is only possible if the properties and
are set to .
Use GDI+ text rendering to measure/draw text.
true If [use GDI text rendering]; otherwise, false.
GDI+ text rendering is less smooth than GDI text rendering bnut it natively supports alpha chanel
thus allows creating transparent images.
While using GDI+ text rendering, you can control the text rendering using , note that
using doesn't work well with transparent background.
Gets or sets a value indicating whether to allow conversion of newline characters to HTML break tags.
If to use cursors defined by the operating system or .NET cursors
true if [use system cursors]; otherwise, false.
Gets or sets a value indicating whether to use the wait cursor for the current
control and all child controls.
Gets or sets a value indicating if anti-aliasing should be avoided for geometry like backgrounds and borders (default - false).
true if [avoid geometry antialias]; otherwise, false.
Is content selection is enabled for the rendered html (default - true).
If set to 'false' the rendered html will be static only with ability to click on links.
true if this instance is selection enabled; otherwise, false.
Is the build-in context menu enabled and will be shown on mouse right click (default - true)
true if this instance is context menu enabled; otherwise, false.
Automatically sets the height of the label by content height (width is not effected).
true if [automatic size height only]; otherwise, false.
Automatically sets the size of the label by content size
true if [automatic size]; otherwise, false.
Gets or sets a value indicating whether the control can accept data that the user drags onto it.
Returns [true] if drag-and-drop operations are allowed in the control; otherwise, [false]. The default is [false].
Set base stylesheet to be used by html rendered in the panel.
The base stylesheet.
Gets or sets the max size the control get be set by or .
The maximum size.
Gets or sets the min size the control get be set by or .
The minimum size.
[Variant] Gets or sets the cursor that is displayed when the mouse pointer is over the control.
Get the currently selected text segment in the html.
The selected text.
Copy the currently selected html segment with style.
The selected HTML.
Override to support border for the control.
The create parameters.
Get html from the current DOM tree with inline style.
generated html
Get the rectangle of html element as calculated by html layout.
Element if found by id (id attribute on the html element).
Note: to get the screen rectangle you need to adjust by the hosting control.
the id of the element to get its rectangle
the rectangle of the element or null if not found
Clear the current selection.
Determines whether the hosting process is in design-mode as per the LicenseManager module.
Converts a string to sentence-case format.
Renders the text content in HTML format.
Render in RightToLeft (RTL) format?
Override the proc processing method to set OS specific hand cursor.
The Windows to process.
Release the html container resources.
true to release both managed and unmanaged resources; false to release only unmanaged resources.
Raised when the EllipsisFormat property value changes.
Raised when the BorderStyle property value changes.
Raised when the set html document has been fully loaded.
Allows manipulation of the html dom, scroll position, etc.
Raised when the user clicks on a link in the html.
Allows canceling the execution of the link.
Raised when an error occurred during html rendering.
Raised when an image is about to be loaded by file path or URI.
This event allows to provide the image manually, if not handled the image will be loaded from file or download from URI.
Raises the event.
The instance containing the event data.
Propagate the LoadComplete event from root container.
The instance containing the event data.
Propagate the LinkClicked event from root container.
The instance containing the event data.
Propagate the Render Error event from root container.
The instance containing the event data.
Propagate the image load event from root container.
The instance containing the event data.
Handle html renderer invalidate and re-layout as requested.
The instance containing the event data.
Handles the event.
The sender.
The instance containing the event data.
Handles the event.
The sender.
The instance containing the event data.
Handles the event.
The sender.
The instance containing the event data.
Handles the event.
The sender.
The instance containing the event data.
Handles the event.
The sender.
The instance containing the event data.
Raises the
event when the property
value of the control's container changes.
An
that contains the event data.
Raises the event
when the parent font changes.
Raises the event
when the parent control changes.
Perform text-rendering while control is being resized.
Perform the layout of the html in the control.
The instance containing the event data.
Perform paint of the html in the control.
The instance containing the event data.
Handle mouse move to handle hover cursor and text selection.
The instance containing the event data.
Handle mouse down to handle selection.
The instance containing the event data.
Handle mouse leave to handle cursor change.
The instance containing the event data.
Handle mouse up to handle selection and link click.
The instance containing the event data.
Handle mouse double click to select word under the mouse.
The instance containing the event data.
Provides ellipsis-handling tasks and features for controls.
String used as a placeholder for trimmed text.
Specifies ellipsis format and alignment.
Text is not modified.
Text is trimmed at the end of the string. An ellipsis (...) is drawn in place of remaining text.
Text is trimmed at the begining of the string. An ellipsis (...) is drawn in place of remaining text.
Text is trimmed in the middle of the string. An ellipsis (...) is drawn in place of remaining text.
Preserve as much as possible of the drive and filename information. Must be combined with alignment information.
Text is trimmed at a word boundary. Must be combined with alignment information.
Truncates a text string to fit within a given control width by replacing trimmed text with ellipses.
The text or string to be trimmed.
The control whose Text property will be trimmed-down.
The Text must fit within control's width.
The control's Font is used to measure the Text string.
The format and alignment of the ellipsis.
This function returns the text trimmed to the specified control's width.
Required designer variable.
Clean up any resources being used.
true if managed resources should be disposed; otherwise, false.
Required method for Designer support - do not modify
the contents of this method with the code editor.
Occurs whenever the ToolTip is being closed.
Required designer variable.
Clean up any resources being used.
true if managed resources should be disposed; otherwise, false.
Required method for Designer support - do not modify
the contents of this method with the code editor.
Adapter for WinForms brushes objects for core.
The actual WinForms brush instance.
If to dispose the brush when is called.
Ignore dispose for cached brushes.
Init.
The actual WinForms brush instance.
Adapter for WinForms context menu for core.
the underline win forms context menu
Init.
Adapter for WinForms Control for core.
the underline win forms control.
Use GDI+ text rendering to measure/draw text.
Init.
Get the underline win forms control
Adapter for WinForms Font object for core.
the underline win-forms font.
a handle to this Font.
the vertical offset of the font underline location from the top of the font.
Cached font height.
Cached font whitespace width.
Init.
the underline win-forms font.
Get the handle to this Font.
Set font metrics to be cached for the font for future use.
the full height of the font
the vertical offset of the font underline location from the top of the font.
Adapter for WinForms Font family object for core.
the underline win-forms font.
Init.
the underline win-forms font family.
Adapter for WinForms Graphics for core.
used for calculation.
used for calculation.
Used for GDI+ measure string.
The string format to use for measuring strings for GDI+ text rendering
The string format to use for rendering strings for GDI+ text rendering
The wrapped WinForms graphics object
Use GDI+ text rendering to measure/draw text.
the initialized HDC used
if to release the graphics object on dispose
If text alignment was set to RTL
Init static resources.
Init.
the win forms graphics object to use
Use GDI+ text rendering to measure/draw text
optional: if to release the graphics object on dispose (default - false)
Release current HDC to be able to use methods.
Init HDC for the current graphics object to be used to call GDI directly.
Set a resource (e.g. a font) for the specified device context.
WARNING: Calling Font.ToHfont() many times without releasing the font handle crashes the app.
Set the text color of the device context.
Change text align to Left-to-Right or Right-to-Left if required.
Special draw logic to draw transparent text using GDI.
1. Create in-memory DC
2. Copy background to in-memory DC
3. Draw the text to in-memory DC
4. Copy the in-memory DC to the proper location with alpha blend
Change text align to Left-to-Right or Right-to-Left if required.
Adapter for WinForms graphics path object for core.
The actual WinForms graphics path instance.
the last point added to the path to begin next segment from
The actual WinForms graphics path instance.
Get arc start angle for the given corner.
Adapter for WinForms Image object for core.
the underline win-forms image.
Initializes a new instance of the class.
the underline win-forms image.
Adapter for WinForms pens objects for core.
The actual WinForms brush instance.
Init.
The actual WinForms brush instance.
Adapter for WinForms platforms.
Singleton instance of global adapter.
Init installed font families and set default font families mapping.
Singleton instance of global adapter.
Helper to encode and set HTML fragment to clipboard.
See http://theartofdev.wordpress.com/2012/11/11/setting-html-and-plain-text-formatting-to-clipboard/.
.
The MIT License (MIT) Copyright (c) 2014 Arthur Teplitzki.
The string contains index references to other spots in the string, so we need placeholders so we can compute the offsets.
The _ strings are just placeholders. We'll back-patch them actual values afterwards.
The string layout () also ensures that it can't appear in the body of the html because the
character must be escaped.
html comment to point the beginning of html fragment
html comment to point the end of html fragment
Used to calculate characters byte count in UTF-8
Create with given html and plain-text ready to be used for clipboard or drag and drop.
Handle missing ]]> tags, specified start\end segments and Unicode characters.
Windows Clipboard works with UTF-8 Unicode encoding while .NET strings use with UTF-16 so for clipboard to correctly
decode Unicode string added to it from .NET we needs to be re-encoded it using UTF-8 encoding.
Builds the CF_HTML header correctly for all possible HTMLs
If given html contains start/end fragments then it will use them in the header:
hello world