# :stopdoc:
# This file is automatically generated by the WXRuby3 documentation
# generator. Do not alter this file.
# :startdoc:
module Wx::PG
# Basic property with boolean value.
# Supported special attributes:
#
# - {Wx::PG::PG_BOOL_USE_CHECKBOX}: Set to true to use check box editor instead of combo box.
# - {Wx::PG::PG_BOOL_USE_DOUBLE_CLICK_CYCLING}: Set to true to cycle combo box instead showing the list.
#
class BoolProperty < PGProperty
# @param label [String]
# @param name [String]
# @param value [Boolean]
# @return [Wx::PG::BoolProperty]
def initialize(label=Wx::PG::PG_LABEL, name=Wx::PG::PG_LABEL, value=false) end
# Converts property value into a text representation.
# Default implementation calls {Wx::PG::BoolProperty#generate_composed_value}.
# @param value [Wx::Variant] Value to be converted.
# @param argFlags [Integer] If 0 (default value), then displayed string is returned. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_FULL_VALUE} is set, returns complete, storable string value instead of displayable. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_EDITABLE_VALUE} is set, returns string value that must be editable in textctrl. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_COMPOSITE_FRAGMENT} is set, returns text that is appropriate to display as a part of string property's composite text representation.
# @return [String]
def value_to_string(value, argFlags=0) end
# Converts text into {Wx::Variant} value appropriate for this property.
# Returns true if resulting {Wx::Variant} value was different.
#
# Default implementation converts semicolon delimited tokens into child values. Only works for properties with children.
#
# You might want to take into account that m_value is Null variant if property value is unspecified (which is usually only case if you explicitly enabled that sort behaviour).
# @param variant [Wx::Variant] On function entry this is the old value (should not be {Wx::NullVariant} in normal cases). Translated value must be assigned back to it.
# @param text [String] Text to be translated into variant.
# @param argFlags [Integer] If {Wx::PG::PG_MISC_ARG_FLAGS::PG_FULL_VALUE} is set, returns complete, storable value instead of displayable one (they may be different). If {Wx::PG::PG_MISC_ARG_FLAGS::PG_COMPOSITE_FRAGMENT} is set, text is interpreted as a part of composite property string value (as generated by {Wx::PG::BoolProperty#value_to_string} called with this same flag).
# @return [Boolean]
def string_to_value(variant, text, argFlags=0) end
# Converts integer (possibly a choice selection) into {Wx::Variant} value appropriate for this property.
# Returns true if resulting {Wx::Variant} value was different.
#
# - If property is not supposed to use choice or spinctrl or other editor with int-based value, it is not necessary to implement this method.
# - Default implementation simply assign given int to m_value.
# - If property uses choice control, and displays a dialog on some choice items, then it is preferred to display that dialog in IntToValue instead of OnEvent.
# - You might want to take into account that m_value is Mull variant if property value is unspecified (which is usually only case if you explicitly enabled that sort behaviour).
# @param variant [Wx::Variant] On function entry this is the old value (should not be {Wx::NullVariant} in normal cases). Translated value must be assigned back to it.
# @param number [Integer] Integer to be translated into variant.
# @param argFlags [Integer] If {Wx::PG::PG_MISC_ARG_FLAGS::PG_FULL_VALUE} is set, returns complete, storable value instead of displayable one.
# @return [Boolean]
def int_to_value(variant, number, argFlags=0) end
# Reimplement this member function to add special handling for attributes of this property.
# Return false to have the attribute automatically stored in m_attributes. Default implementation simply does that and nothing else.
#
# To actually set property attribute values from the application, use {Wx::PG::PGProperty#set_attribute} instead.
# @param name [String]
# @param value [Wx::Variant]
# @return [Boolean]
def do_set_attribute(name, value) end
#
# @return [Wx::Variant]
def value_; end
#
# @param val [nil,String,Integer,Float,Time,Wx::Font,Wx::Colour,Wx::Variant,Array,Array,ObjectWx::PG::ColourPropertyValue]
# @return [void]
def value_=(val); end
end # BoolProperty
# Property representing {Wx::DateTime}.
# Supported special attributes:
#
# - {Wx::PG::PG_DATE_FORMAT}: Determines displayed date format.
# - {Wx::PG::PG_DATE_PICKER_STYLE}: Determines window style used with {Wx::DatePickerCtrl}. Default is {Wx::DP_DEFAULT} | {Wx::DP_SHOWCENTURY}. Using {Wx::DP_ALLOWNONE} enables additional support for unspecified property value.
#
class DateProperty < PGProperty
# @param label [String]
# @param name [String]
# @param value [Time,Date,DateTime]
# @return [Wx::PG::DateProperty]
def initialize(label=Wx::PG::PG_LABEL, name=Wx::PG::PG_LABEL, value=(Wx::DateTime.new())) end
# This virtual function is called after m_value has been set.
# - If m_value was set to Null variant (i.e. unspecified value), {Wx::PG::DateProperty#on_set_value} will not be called.
# - m_value may be of any variant type. Typically properties internally support only one variant type, and as such {Wx::PG::DateProperty#on_set_value} provides a good opportunity to convert supported values into internal type.
# - Default implementation does nothing.
# @return [void]
def on_set_value; end
# Converts property value into a text representation.
# Default implementation calls {Wx::PG::DateProperty#generate_composed_value}.
# @param value [Wx::Variant] Value to be converted.
# @param argFlags [Integer] If 0 (default value), then displayed string is returned. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_FULL_VALUE} is set, returns complete, storable string value instead of displayable. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_EDITABLE_VALUE} is set, returns string value that must be editable in textctrl. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_COMPOSITE_FRAGMENT} is set, returns text that is appropriate to display as a part of string property's composite text representation.
# @return [String]
def value_to_string(value, argFlags=0) end
# Converts text into {Wx::Variant} value appropriate for this property.
# Returns true if resulting {Wx::Variant} value was different.
#
# Default implementation converts semicolon delimited tokens into child values. Only works for properties with children.
#
# You might want to take into account that m_value is Null variant if property value is unspecified (which is usually only case if you explicitly enabled that sort behaviour).
# @param variant [Wx::Variant] On function entry this is the old value (should not be {Wx::NullVariant} in normal cases). Translated value must be assigned back to it.
# @param text [String] Text to be translated into variant.
# @param argFlags [Integer] If {Wx::PG::PG_MISC_ARG_FLAGS::PG_FULL_VALUE} is set, returns complete, storable value instead of displayable one (they may be different). If {Wx::PG::PG_MISC_ARG_FLAGS::PG_COMPOSITE_FRAGMENT} is set, text is interpreted as a part of composite property string value (as generated by {Wx::PG::DateProperty#value_to_string} called with this same flag).
# @return [Boolean]
def string_to_value(variant, text, argFlags=0) end
# Reimplement this member function to add special handling for attributes of this property.
# Return false to have the attribute automatically stored in m_attributes. Default implementation simply does that and nothing else.
#
# To actually set property attribute values from the application, use {Wx::PG::PGProperty#set_attribute} instead.
# @param name [String]
# @param value [Wx::Variant]
# @return [Boolean]
def do_set_attribute(name, value) end
# @param format [String]
# @return [void]
def set_format(format) end
alias_method :format=, :set_format
# @return [Wx::String]
def get_format; end
alias_method :format, :get_format
# @param dt [Time,Date,DateTime]
# @return [void]
def set_date_value(dt) end
alias_method :date_value=, :set_date_value
# @return [Time,Date,DateTime]
def get_date_value; end
alias_method :date_value, :get_date_value
# @return [Integer]
def get_date_picker_style; end
alias_method :date_picker_style, :get_date_picker_style
#
#
#
# @return [String]
def format_; end
#
#
#
# @param val [String]
# @return [void]
def format_=(val); end
#
#
#
# @return [Integer]
def dp_style_; end
#
#
#
# @param val [Integer]
# @return [void]
def dp_style_=(val); end
#
# @return [Wx::Variant]
def value_; end
#
# @param val [nil,String,Integer,Float,Time,Wx::Font,Wx::Colour,Wx::Variant,Array,Array,ObjectWx::PG::ColourPropertyValue]
# @return [void]
def value_=(val); end
end # DateProperty
# Represents a bit set that fits in a long integer.
# {Wx::PG::BoolProperty} sub-properties are created for editing individual bits. Textctrl is created to manually edit the flags as a text; a continuous sequence of spaces, commas and semicolons is considered as a flag id separator. Note: When changing "choices" (ie. flag labels) of {Wx::PG::FlagsProperty}, you will need to use SetPropertyChoices - otherwise they will not get updated properly.
#
class FlagsProperty < PGProperty
# @overload initialize(label, name, choices, value=0)
# @param label [String]
# @param name [String]
# @param choices [Wx::PG::PGChoices]
# @param value [Integer]
# @return [Wx::PG::FlagsProperty]
# @overload initialize(label=Wx::PG::PG_LABEL, name=Wx::PG::PG_LABEL, labels=(Wx::ArrayString.new()), values=(Wx::ArrayInt.new()), value=0)
# @param label [String]
# @param name [String]
# @param labels [Array]
# @param values [Array]
# @param value [Integer]
# @return [Wx::PG::FlagsProperty]
def initialize(*args) end
# This virtual function is called after m_value has been set.
# - If m_value was set to Null variant (i.e. unspecified value), {Wx::PG::FlagsProperty#on_set_value} will not be called.
# - m_value may be of any variant type. Typically properties internally support only one variant type, and as such {Wx::PG::FlagsProperty#on_set_value} provides a good opportunity to convert supported values into internal type.
# - Default implementation does nothing.
# @return [void]
def on_set_value; end
# Converts property value into a text representation.
# Default implementation calls {Wx::PG::FlagsProperty#generate_composed_value}.
# @param value [Wx::Variant] Value to be converted.
# @param argFlags [Integer] If 0 (default value), then displayed string is returned. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_FULL_VALUE} is set, returns complete, storable string value instead of displayable. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_EDITABLE_VALUE} is set, returns string value that must be editable in textctrl. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_COMPOSITE_FRAGMENT} is set, returns text that is appropriate to display as a part of string property's composite text representation.
# @return [String]
def value_to_string(value, argFlags=0) end
# Converts text into {Wx::Variant} value appropriate for this property.
# Returns true if resulting {Wx::Variant} value was different.
#
# Default implementation converts semicolon delimited tokens into child values. Only works for properties with children.
#
# You might want to take into account that m_value is Null variant if property value is unspecified (which is usually only case if you explicitly enabled that sort behaviour).
# @param variant [Wx::Variant] On function entry this is the old value (should not be {Wx::NullVariant} in normal cases). Translated value must be assigned back to it.
# @param text [String] Text to be translated into variant.
# @param argFlags [Integer] If {Wx::PG::PG_MISC_ARG_FLAGS::PG_FULL_VALUE} is set, returns complete, storable value instead of displayable one (they may be different). If {Wx::PG::PG_MISC_ARG_FLAGS::PG_COMPOSITE_FRAGMENT} is set, text is interpreted as a part of composite property string value (as generated by {Wx::PG::FlagsProperty#value_to_string} called with this same flag).
# @return [Boolean]
def string_to_value(variant, text, argFlags) end
# Called after value of a child property has been altered.
# Must return new value of the whole property (after any alterations warranted by child's new value).
# Note that this function is usually called at the time that value of this property, or given child property, is still pending for change, and as such, result of {Wx::PG::FlagsProperty#get_value} or m_value should not be relied on.
# Sample pseudo-code implementation:
#
# ```ruby
# class MyProperty < Wx::PG::FlagsProperty
#
# def child_changed(thisValue, childIndex, childValue)
# # Acquire reference to actual type of data stored in variant
# flags = thisValue.object;
# case childIndex
# when 0
# flags.sub_prop1 = childValue.to_i
# when 1
# flags.sub_prop2 = childValue.to_s
# # ...
# end
# # return altered data
# Wx::Variant.new(flags)
# end
#
# end
# ```
#
# Modified value of the whole property.
# @param thisValue [Wx::Variant] Value of this property. Changed value should be returned (in previous versions of {Wx::PG::PropertyGrid} it was only necessary to write value back to this argument).
# @param childIndex [Integer] Index of child changed (you can use Item(childIndex) to get child property).
# @param childValue [Wx::Variant] (Pending) value of the child property.
# @return [Wx::Variant]
def child_changed(thisValue, childIndex, childValue) end
# Refresh values of child properties.
# Automatically called after value is set.
# @return [void]
def refresh_children; end
# Reimplement this member function to add special handling for attributes of this property.
# Return false to have the attribute automatically stored in m_attributes. Default implementation simply does that and nothing else.
#
# To actually set property attribute values from the application, use {Wx::PG::PGProperty#set_attribute} instead.
# @param name [String]
# @param value [Wx::Variant]
# @return [Boolean]
def do_set_attribute(name, value) end
# Returns which choice is currently selected.
# Only applies to properties which have choices.
# Needs to reimplemented in derived class if property value does not map directly to a choice. Integer as index, bool, and string usually do.
# @return [Integer]
def get_choice_selection; end
alias_method :choice_selection, :get_choice_selection
# @return [Integer]
def get_item_count; end
alias_method :item_count, :get_item_count
# @param ind [Integer]
# @return [Wx::String]
def get_item_label(ind) end
alias_method :item_label, :get_item_label
#
# @return [Wx::Variant]
def value_; end
#
# @param val [nil,String,Integer,Float,Time,Wx::Font,Wx::Colour,Wx::Variant,Array,Array,ObjectWx::PG::ColourPropertyValue]
# @return [void]
def value_=(val); end
end # FlagsProperty
# Basic property with string value.
# Supported special attributes:
#
# - {Wx::PG::PG_STRING_PASSWORD}: set to true in order to enable {Wx::TE_PASSWORD} on the editor.
#
# - If value "" is set, then actual value is formed (or composed) from values of child properties.
#
class StringProperty < PGProperty
# @param label [String]
# @param name [String]
# @param value [String]
# @return [Wx::PG::StringProperty]
def initialize(label=Wx::PG::PG_LABEL, name=Wx::PG::PG_LABEL, value=('')) end
# Converts property value into a text representation.
# Default implementation calls {Wx::PG::StringProperty#generate_composed_value}.
# @param value [Wx::Variant] Value to be converted.
# @param argFlags [Integer] If 0 (default value), then displayed string is returned. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_FULL_VALUE} is set, returns complete, storable string value instead of displayable. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_EDITABLE_VALUE} is set, returns string value that must be editable in textctrl. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_COMPOSITE_FRAGMENT} is set, returns text that is appropriate to display as a part of string property's composite text representation.
# @return [String]
def value_to_string(value, argFlags=0) end
# Converts text into {Wx::Variant} value appropriate for this property.
# Returns true if resulting {Wx::Variant} value was different.
#
# Default implementation converts semicolon delimited tokens into child values. Only works for properties with children.
#
# You might want to take into account that m_value is Null variant if property value is unspecified (which is usually only case if you explicitly enabled that sort behaviour).
# @param variant [Wx::Variant] On function entry this is the old value (should not be {Wx::NullVariant} in normal cases). Translated value must be assigned back to it.
# @param text [String] Text to be translated into variant.
# @param argFlags [Integer] If {Wx::PG::PG_MISC_ARG_FLAGS::PG_FULL_VALUE} is set, returns complete, storable value instead of displayable one (they may be different). If {Wx::PG::PG_MISC_ARG_FLAGS::PG_COMPOSITE_FRAGMENT} is set, text is interpreted as a part of composite property string value (as generated by {Wx::PG::StringProperty#value_to_string} called with this same flag).
# @return [Boolean]
def string_to_value(variant, text, argFlags=0) end
# Reimplement this member function to add special handling for attributes of this property.
# Return false to have the attribute automatically stored in m_attributes. Default implementation simply does that and nothing else.
#
# To actually set property attribute values from the application, use {Wx::PG::PGProperty#set_attribute} instead.
# @param name [String]
# @param value [Wx::Variant]
# @return [Boolean]
def do_set_attribute(name, value) end
# This is updated so "" special value can be handled.
# @return [void]
def on_set_value; end
#
# @return [Wx::Variant]
def value_; end
#
# @param val [nil,String,Integer,Float,Time,Wx::Font,Wx::Colour,Wx::Variant,Array,Array,ObjectWx::PG::ColourPropertyValue]
# @return [void]
def value_=(val); end
end # StringProperty
# Category (caption) property.
#
#
class PropertyCategory < PGProperty
# @overload initialize()
# Default constructor is only used in special cases.
# @return [Wx::PG::PropertyCategory]
# @overload initialize(label, name=Wx::PG::PG_LABEL)
# @param label [String]
# @param name [String]
# @return [Wx::PG::PropertyCategory]
def initialize(*args) end
# @param wnd [Wx::Window]
# @param font [Wx::Font,Wx::FontInfo]
# @return [Integer]
def get_text_extent(wnd, font) end
alias_method :text_extent, :get_text_extent
# Converts property value into a text representation.
# Default implementation calls {Wx::PG::PropertyCategory#generate_composed_value}.
# @param value [Wx::Variant] Value to be converted.
# @param argFlags [Integer] If 0 (default value), then displayed string is returned. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_FULL_VALUE} is set, returns complete, storable string value instead of displayable. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_EDITABLE_VALUE} is set, returns string value that must be editable in textctrl. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_COMPOSITE_FRAGMENT} is set, returns text that is appropriate to display as a part of string property's composite text representation.
# @return [String]
def value_to_string(value, argFlags) end
# Returns text representation of property's value.
# In older versions, this function used to be overridden to convert property's value into a string representation. This function is now handled by {Wx::PG::PropertyCategory#value_to_string}, and overriding this function now will result in run-time assertion failure.
# @param argFlags [Integer] If 0 (default value), then displayed string is returned. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_FULL_VALUE} is set, returns complete, storable string value instead of displayable. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_EDITABLE_VALUE} is set, returns string value that must be editable in textctrl. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_COMPOSITE_FRAGMENT} is set, returns text that is appropriate to display as a part of string property's composite text representation.
# @return [String]
def get_value_as_string(argFlags=0) end
alias_method :value_as_string, :get_value_as_string
#
# @return [Wx::Variant]
def value_; end
#
# @param val [nil,String,Integer,Float,Time,Wx::Font,Wx::Colour,Wx::Variant,Array,Array,ObjectWx::PG::ColourPropertyValue]
# @return [void]
def value_=(val); end
end # PropertyCategory
# This is an abstract class which serves as a base class for the properties having a button triggering an editor dialog, like e.g.
# {Wx::PG::LongStringProperty}, {Wx::PG::DirProperty}, {Wx::PG::FileProperty}.
# Supported special attributes:
#
# - {Wx::PG::PG_DIALOG_TITLE}: Sets a specific title for the editor dialog.
#
class EditorDialogProperty < PGProperty
# Returns instance of a new {Wx::PG::PGEditorDialogAdapter} instance, which is used when user presses the (optional) button next to the editor control;.
# Default implementation returns NULL (i.e. no action is generated when button is pressed).
# @return [Wx::PG::PGEditorDialogAdapter]
def get_editor_dialog; end
alias_method :editor_dialog, :get_editor_dialog
# Reimplement this member function to add special handling for attributes of this property.
# Return false to have the attribute automatically stored in m_attributes. Default implementation simply does that and nothing else.
#
# To actually set property attribute values from the application, use {Wx::PG::PGProperty#set_attribute} instead.
# @param name [String]
# @param value [Wx::Variant]
# @return [Boolean]
def do_set_attribute(name, value) end
#
#
#
# @return [String]
def dlg_title_; end
#
#
#
# @param val [String]
# @return [void]
def dlg_title_=(val); end
#
#
#
# @return [Integer]
def dlg_style_; end
#
#
#
# @param val [Integer]
# @return [void]
def dlg_style_=(val); end
#
# @return [Wx::Variant]
def value_; end
#
# @param val [nil,String,Integer,Float,Time,Wx::Font,Wx::Colour,Wx::Variant,Array,Array,ObjectWx::PG::ColourPropertyValue]
# @return [void]
def value_=(val); end
protected
# Constructor is protected because {Wx::PG::EditorDialogProperty} is only the base class for other property classes.
# @param label [String]
# @param name [String]
# @return [Wx::PG::EditorDialogProperty]
def initialize(label, name) end
# Shows editor dialog.
# Value to be edited should be read from value, and if dialog is not cancelled, it should be stored back and true should be returned.
#
# Returns true if editor dialog was not cancelled and value was updated.
# @param pg [Wx::PG::PropertyGrid] Property grid in which property is displayed.
# @param value [Wx::Variant] Value to be edited.
# @return [Boolean]
def display_editor_dialog(pg, value) end
end # EditorDialogProperty
# Property that manages a list of strings.
# Supported special attributes:
#
# - {Wx::PG::PG_ARRAY_DELIMITER}: Sets string delimiter character.
# - {Wx::PG::PG_DIALOG_TITLE}: Sets a specific title for the editor dialog (since 3.1.3).
#
class ArrayStringProperty < EditorDialogProperty
#
#
#
#
class ConversionFlags < Wx::Enum
#
#
Escape = Wx::PG::ArrayStringProperty::ConversionFlags.new(1)
#
#
QuoteStrings = Wx::PG::ArrayStringProperty::ConversionFlags.new(2)
end # ConversionFlags
# @param label [String]
# @param name [String]
# @param value [Array]
# @return [Wx::PG::ArrayStringProperty]
def initialize(label=Wx::PG::PG_LABEL, name=Wx::PG::PG_LABEL, value=(Wx::ArrayString.new())) end
# This virtual function is called after m_value has been set.
# - If m_value was set to Null variant (i.e. unspecified value), {Wx::PG::ArrayStringProperty#on_set_value} will not be called.
# - m_value may be of any variant type. Typically properties internally support only one variant type, and as such {Wx::PG::ArrayStringProperty#on_set_value} provides a good opportunity to convert supported values into internal type.
# - Default implementation does nothing.
# @return [void]
def on_set_value; end
# Converts property value into a text representation.
# Default implementation calls {Wx::PG::ArrayStringProperty#generate_composed_value}.
# @param value [Wx::Variant] Value to be converted.
# @param argFlags [Integer] If 0 (default value), then displayed string is returned. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_FULL_VALUE} is set, returns complete, storable string value instead of displayable. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_EDITABLE_VALUE} is set, returns string value that must be editable in textctrl. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_COMPOSITE_FRAGMENT} is set, returns text that is appropriate to display as a part of string property's composite text representation.
# @return [String]
def value_to_string(value, argFlags=0) end
# Converts text into {Wx::Variant} value appropriate for this property.
# Returns true if resulting {Wx::Variant} value was different.
#
# Default implementation converts semicolon delimited tokens into child values. Only works for properties with children.
#
# You might want to take into account that m_value is Null variant if property value is unspecified (which is usually only case if you explicitly enabled that sort behaviour).
# @param variant [Wx::Variant] On function entry this is the old value (should not be {Wx::NullVariant} in normal cases). Translated value must be assigned back to it.
# @param text [String] Text to be translated into variant.
# @param argFlags [Integer] If {Wx::PG::PG_MISC_ARG_FLAGS::PG_FULL_VALUE} is set, returns complete, storable value instead of displayable one (they may be different). If {Wx::PG::PG_MISC_ARG_FLAGS::PG_COMPOSITE_FRAGMENT} is set, text is interpreted as a part of composite property string value (as generated by {Wx::PG::ArrayStringProperty#value_to_string} called with this same flag).
# @return [Boolean]
def string_to_value(variant, text, argFlags=0) end
# Reimplement this member function to add special handling for attributes of this property.
# Return false to have the attribute automatically stored in m_attributes. Default implementation simply does that and nothing else.
#
# To actually set property attribute values from the application, use {Wx::PG::PGProperty#set_attribute} instead.
# @param name [String]
# @param value [Wx::Variant]
# @return [Boolean]
def do_set_attribute(name, value) end
# Implement in derived class for custom array-to-string conversion.
# @param arr [Array]
# @param delimiter [String]
# @return [String]
def convert_array_to_string(arr, delimiter) end
# Shows string editor dialog to edit the individual item.
# Value to be edited should be read from value, and if dialog is not cancelled, it should be stored back and true should be returned if that was the case.
# @param parent [Wx::Window]
# @return [String]
def on_custom_string_edit(parent) end
# Creates {Wx::PG::PGArrayEditorDialog} for string editing.
# @return [Wx::PG::PGArrayEditorDialog]
def create_editor_dialog; end
# Generates string based on the contents of {Wx::ArrayString} src.
# @param src [Array]
# @param delimiter [String]
# @param flags [Integer]
# @return [String]
def self.array_string_to_string(src, delimiter, flags) end
#
#
#
# @return [String]
def display_; end
#
#
#
# @param val [String]
# @return [void]
def display_=(val); end
#
#
#
# @return [String]
def delimiter_; end
#
#
#
# @param val [String]
# @return [void]
def delimiter_=(val); end
#
#
#
# @return [String]
def custom_btn_text_; end
#
#
#
# @param val [String]
# @return [void]
def custom_btn_text_=(val); end
#
# @return [Wx::Variant]
def value_; end
#
# @param val [nil,String,Integer,Float,Time,Wx::Font,Wx::Colour,Wx::Variant,Array,Array,ObjectWx::PG::ColourPropertyValue]
# @return [void]
def value_=(val); end
protected
# Shows editor dialog.
# Value to be edited should be read from value, and if dialog is not cancelled, it should be stored back and true should be returned.
#
# Returns true if editor dialog was not cancelled and value was updated.
# @param pg [Wx::PG::PropertyGrid] Property grid in which property is displayed.
# @param value [Wx::Variant] Value to be edited.
# @return [Boolean]
def display_editor_dialog(pg, value) end
end # ArrayStringProperty
# Like {Wx::PG::LongStringProperty}, but the button triggers directory selector instead.
# Supported special attributes:
#
# - {Wx::PG::PG_DIALOG_TITLE}: Sets a specific title for the file dialog (since 3.1.3).
#
class DirProperty < EditorDialogProperty
# @param label [String]
# @param name [String]
# @param value [String]
# @return [Wx::PG::DirProperty]
def initialize(label=Wx::PG::PG_LABEL, name=Wx::PG::PG_LABEL, value=('')) end
# Converts property value into a text representation.
# Default implementation calls {Wx::PG::DirProperty#generate_composed_value}.
# @param value [Wx::Variant] Value to be converted.
# @param argFlags [Integer] If 0 (default value), then displayed string is returned. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_FULL_VALUE} is set, returns complete, storable string value instead of displayable. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_EDITABLE_VALUE} is set, returns string value that must be editable in textctrl. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_COMPOSITE_FRAGMENT} is set, returns text that is appropriate to display as a part of string property's composite text representation.
# @return [String]
def value_to_string(value, argFlags=0) end
# Converts text into {Wx::Variant} value appropriate for this property.
# Returns true if resulting {Wx::Variant} value was different.
#
# Default implementation converts semicolon delimited tokens into child values. Only works for properties with children.
#
# You might want to take into account that m_value is Null variant if property value is unspecified (which is usually only case if you explicitly enabled that sort behaviour).
# @param variant [Wx::Variant] On function entry this is the old value (should not be {Wx::NullVariant} in normal cases). Translated value must be assigned back to it.
# @param text [String] Text to be translated into variant.
# @param argFlags [Integer] If {Wx::PG::PG_MISC_ARG_FLAGS::PG_FULL_VALUE} is set, returns complete, storable value instead of displayable one (they may be different). If {Wx::PG::PG_MISC_ARG_FLAGS::PG_COMPOSITE_FRAGMENT} is set, text is interpreted as a part of composite property string value (as generated by {Wx::PG::DirProperty#value_to_string} called with this same flag).
# @return [Boolean]
def string_to_value(variant, text, argFlags=0) end
# Returns pointer to the {Wx::Validator} that should be used with the editor of this property (NULL for no validator).
# Setting validator explicitly via #set_property_validator will override this.
# In most situations, code like this should work well:
#
# ```ruby
# class MyPropertyClass < Wx::PG::DirProperty
#
# class << self
# def validator
# @validator ||= MyValidator.new(...)
# end
# end
#
# # ...
#
# def do_get_validator
# MyPropertyClass.validator
# end
#
# # ...
#
# end
# ```
#
# You can get common filename validator by returning {Wx::PG::FileProperty.get_class_validator}. {Wx::PG::DirProperty}, for example, uses it.
# @return [Wx::Validator]
def do_get_validator; end
#
# @return [Wx::Variant]
def value_; end
#
# @param val [nil,String,Integer,Float,Time,Wx::Font,Wx::Colour,Wx::Variant,Array,Array,ObjectWx::PG::ColourPropertyValue]
# @return [void]
def value_=(val); end
protected
# Shows editor dialog.
# Value to be edited should be read from value, and if dialog is not cancelled, it should be stored back and true should be returned.
#
# Returns true if editor dialog was not cancelled and value was updated.
# @param pg [Wx::PG::PropertyGrid] Property grid in which property is displayed.
# @param value [Wx::Variant] Value to be edited.
# @return [Boolean]
def display_editor_dialog(pg, value) end
end # DirProperty
# Like {Wx::PG::LongStringProperty}, but the button triggers file selector instead.
# Supported special attributes:
#
# - {Wx::PG::PG_DIALOG_TITLE}: Sets a specific title for the file dialog (since 3.1.3).
# - {Wx::PG::PG_FILE_DIALOG_STYLE}: Sets a specific {Wx::FileDialog} style for the file dialog (since 2.9.4).
# - {Wx::PG::PG_FILE_WILDCARD}: Sets wildcard (see {Wx::FileDialog} for format details), "All files..." is default.
# - {Wx::PG::PG_FILE_SHOW_FULL_PATH}: Default true. When false, only the file name is shown (i.e. drive and directory are hidden).
# - {Wx::PG::PG_FILE_SHOW_RELATIVE_PATH}: If set, then the filename is shown relative to the given path string.
# - {Wx::PG::PG_FILE_INITIAL_PATH}: Sets the initial path of where to look for files.
#
class FileProperty < EditorDialogProperty
# @param label [String]
# @param name [String]
# @param value [String]
# @return [Wx::PG::FileProperty]
def initialize(label=Wx::PG::PG_LABEL, name=Wx::PG::PG_LABEL, value=('')) end
# This virtual function is called after m_value has been set.
# - If m_value was set to Null variant (i.e. unspecified value), {Wx::PG::FileProperty#on_set_value} will not be called.
# - m_value may be of any variant type. Typically properties internally support only one variant type, and as such {Wx::PG::FileProperty#on_set_value} provides a good opportunity to convert supported values into internal type.
# - Default implementation does nothing.
# @return [void]
def on_set_value; end
# Converts property value into a text representation.
# Default implementation calls {Wx::PG::FileProperty#generate_composed_value}.
# @param value [Wx::Variant] Value to be converted.
# @param argFlags [Integer] If 0 (default value), then displayed string is returned. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_FULL_VALUE} is set, returns complete, storable string value instead of displayable. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_EDITABLE_VALUE} is set, returns string value that must be editable in textctrl. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_COMPOSITE_FRAGMENT} is set, returns text that is appropriate to display as a part of string property's composite text representation.
# @return [String]
def value_to_string(value, argFlags=0) end
# Converts text into {Wx::Variant} value appropriate for this property.
# Returns true if resulting {Wx::Variant} value was different.
#
# Default implementation converts semicolon delimited tokens into child values. Only works for properties with children.
#
# You might want to take into account that m_value is Null variant if property value is unspecified (which is usually only case if you explicitly enabled that sort behaviour).
# @param variant [Wx::Variant] On function entry this is the old value (should not be {Wx::NullVariant} in normal cases). Translated value must be assigned back to it.
# @param text [String] Text to be translated into variant.
# @param argFlags [Integer] If {Wx::PG::PG_MISC_ARG_FLAGS::PG_FULL_VALUE} is set, returns complete, storable value instead of displayable one (they may be different). If {Wx::PG::PG_MISC_ARG_FLAGS::PG_COMPOSITE_FRAGMENT} is set, text is interpreted as a part of composite property string value (as generated by {Wx::PG::FileProperty#value_to_string} called with this same flag).
# @return [Boolean]
def string_to_value(variant, text, argFlags=0) end
# Reimplement this member function to add special handling for attributes of this property.
# Return false to have the attribute automatically stored in m_attributes. Default implementation simply does that and nothing else.
#
# To actually set property attribute values from the application, use {Wx::PG::PGProperty#set_attribute} instead.
# @param name [String]
# @param value [Wx::Variant]
# @return [Boolean]
def do_set_attribute(name, value) end
# Returns pointer to the {Wx::Validator} that should be used with the editor of this property (NULL for no validator).
# Setting validator explicitly via #set_property_validator will override this.
# In most situations, code like this should work well:
#
# ```ruby
# class MyPropertyClass < Wx::PG::FileProperty
#
# class << self
# def validator
# @validator ||= MyValidator.new(...)
# end
# end
#
# # ...
#
# def do_get_validator
# MyPropertyClass.validator
# end
#
# # ...
#
# end
# ```
#
# You can get common filename validator by returning {Wx::PG::FileProperty.get_class_validator}. {Wx::PG::DirProperty}, for example, uses it.
# @return [Wx::Validator]
def do_get_validator; end
# Returns filename to file represented by current value.
# @return [String]
def get_file_name; end
alias_method :file_name, :get_file_name
# @return [Wx::Validator]
def self.get_class_validator; end
#
#
#
# @return [String]
def m_wildcard; end
#
#
#
# @param val [String]
# @return [void]
def m_wildcard=(val); end
#
#
#
# @return [String]
def m_base_path; end
#
#
#
# @param val [String]
# @return [void]
def m_base_path=(val); end
#
#
#
# @return [String]
def m_initial_path; end
#
#
#
# @param val [String]
# @return [void]
def m_initial_path=(val); end
#
#
#
# @return [Integer]
def m_ind_filter; end
#
#
#
# @param val [Integer]
# @return [void]
def m_ind_filter=(val); end
#
# @return [Wx::Variant]
def value_; end
#
# @param val [nil,String,Integer,Float,Time,Wx::Font,Wx::Colour,Wx::Variant,Array,Array,ObjectWx::PG::ColourPropertyValue]
# @return [void]
def value_=(val); end
protected
# Shows editor dialog.
# Value to be edited should be read from value, and if dialog is not cancelled, it should be stored back and true should be returned.
#
# Returns true if editor dialog was not cancelled and value was updated.
# @param pg [Wx::PG::PropertyGrid] Property grid in which property is displayed.
# @param value [Wx::Variant] Value to be edited.
# @return [Boolean]
def display_editor_dialog(pg, value) end
end # FileProperty
# Property representing image file(name).
# Supported special attributes:
#
# - {Wx::PG::PG_DIALOG_TITLE}: Sets a specific title for the file dialog (since 3.1.3).
# - {Wx::PG::PG_FILE_DIALOG_STYLE}: Sets a specific {Wx::FileDialog} style for the file dialog.
# - {Wx::PG::PG_FILE_WILDCARD}: Sets wildcard (see {Wx::FileDialog} for format details), "All
# files..." is default.
# - {Wx::PG::PG_FILE_SHOW_FULL_PATH}: Default true. When false, only the file name is shown (i.e. drive and directory are hidden).
# - {Wx::PG::PG_FILE_SHOW_RELATIVE_PATH}: If set, then the filename is shown relative to the given path string.
# - {Wx::PG::PG_FILE_INITIAL_PATH}: Sets the initial path of where to look for files.
#
class ImageFileProperty < FileProperty
# @param label [String]
# @param name [String]
# @param value [String]
# @return [Wx::PG::ImageFileProperty]
def initialize(label=Wx::PG::PG_LABEL, name=Wx::PG::PG_LABEL, value=('')) end
# This virtual function is called after m_value has been set.
# - If m_value was set to Null variant (i.e. unspecified value), {Wx::PG::ImageFileProperty#on_set_value} will not be called.
# - m_value may be of any variant type. Typically properties internally support only one variant type, and as such {Wx::PG::ImageFileProperty#on_set_value} provides a good opportunity to convert supported values into internal type.
# - Default implementation does nothing.
# @return [void]
def on_set_value; end
# Returns size of the custom painted image in front of property.
# This method must be overridden to return non-default value if OnCustomPaint is to be called.
#
# - Default behaviour is to return {size(0,0)}, which means no image.
# - Default image width or height is indicated with dimension -1.
# - You can also return {Wx::PG::PG_DEFAULT_IMAGE_SIZE} which equals {Wx::DEFAULT_SIZE}.
# @param item [Integer] Normally -1, but can be an index to the property's list of items.
# @return [Wx::Size]
def on_measure_image(item) end
# Override to paint an image in front of the property value text or drop-down list item (but only if {Wx::PG::PGProperty#on_measure_image} is overridden as well).
# If property's {Wx::PG::ImageFileProperty#on_measure_image} returns size that has height != 0 but less than row height ( < 0 has special meanings), {Wx::PG::PropertyGrid} calls this method to draw a custom image in a limited area in front of the editor control or value text/graphics, and if control has drop-down list, then the image is drawn there as well (even in the case {Wx::PG::ImageFileProperty#on_measure_image} returned higher height than row height).
# NOTE: Following applies when {Wx::PG::ImageFileProperty#on_measure_image} returns a "flexible" height ( using wxPG_FLEXIBLE_SIZE(W,H)
macro), which implies variable height items: If (rect.x+rect.width) is < 0, then this is a measure item call, which means that dc is invalid and only thing that should be done is to set paintdata.m_drawnHeight to the height of the image of item at index paintdata.m_choiceItem. This call may be done even as often as once every drop-down popup show.
#
# - You can actually exceed rect width, but if you do so then paintdata.m_drawnWidth must be set to the full width drawn in pixels.
# - Due to technical reasons, rect's height will be default even if custom height was reported during measure call.
# - Brush is guaranteed to be default background colour. It has been already used to clear the background of area being painted. It can be modified.
# - Pen is guaranteed to be 1-wide 'black' (or whatever is the proper colour) pen for drawing framing rectangle. It can be changed as well.
# @see Wx::PG::ImageFileProperty#value_to_string
# @param dc [Wx::DC] {Wx::DC} to paint on.
# @param rect [Wx::Rect] Box reserved for custom graphics. Includes surrounding rectangle, if any. If x+width is < 0, then this is a measure item call (see above).
# @param paintdata [Wx::PG::PGPaintData] {Wx::PG::PGPaintData} structure with much useful data about painted item.
# @return [void]
def on_custom_paint(dc, rect, paintdata) end
#
# @return [Wx::Variant]
def value_; end
#
# @param val [nil,String,Integer,Float,Time,Wx::Font,Wx::Colour,Wx::Variant,Array,Array,ObjectWx::PG::ColourPropertyValue]
# @return [void]
def value_=(val); end
end # ImageFileProperty
# Property representing {Wx::Font}.
# Supported special attributes:
#
# - {Wx::PG::PG_DIALOG_TITLE}: Sets a specific title for the font dialog (since 3.1.3).
#
class FontProperty < EditorDialogProperty
# @param label [String]
# @param name [String]
# @param value [Wx::Font,Wx::FontInfo]
# @return [Wx::PG::FontProperty]
def initialize(label=Wx::PG::PG_LABEL, name=Wx::PG::PG_LABEL, value=(Wx::Font.new())) end
# This virtual function is called after m_value has been set.
# - If m_value was set to Null variant (i.e. unspecified value), {Wx::PG::FontProperty#on_set_value} will not be called.
# - m_value may be of any variant type. Typically properties internally support only one variant type, and as such {Wx::PG::FontProperty#on_set_value} provides a good opportunity to convert supported values into internal type.
# - Default implementation does nothing.
# @return [void]
def on_set_value; end
# Converts property value into a text representation.
# Default implementation calls {Wx::PG::FontProperty#generate_composed_value}.
# @param value [Wx::Variant] Value to be converted.
# @param argFlags [Integer] If 0 (default value), then displayed string is returned. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_FULL_VALUE} is set, returns complete, storable string value instead of displayable. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_EDITABLE_VALUE} is set, returns string value that must be editable in textctrl. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_COMPOSITE_FRAGMENT} is set, returns text that is appropriate to display as a part of string property's composite text representation.
# @return [String]
def value_to_string(value, argFlags=0) end
# Called after value of a child property has been altered.
# Must return new value of the whole property (after any alterations warranted by child's new value).
# Note that this function is usually called at the time that value of this property, or given child property, is still pending for change, and as such, result of {Wx::PG::FontProperty#get_value} or m_value should not be relied on.
# Sample pseudo-code implementation:
#
# ```ruby
# class WxFontDataProperty < Wx::PG::FontProperty
#
# def child_changed(thisValue, childIndex, childValue)
# fontData = thisValue.object
# fontData.initial_font = fontData.chosen_font
#
# case childIndex
# when 6
# col = childValue.colour
# fontData.colour = col
# else
# # Transfer from subset to superset.
# font = fontData.chosen_font
# variant = Wx::Variant.new(font)
# variant = super(variant, childIndex, childValue)
# font = variant.font
# fontData.chosen_font = font
# end
#
# Wx::Variant.new(fontData)
# end
#
# end
# ```
#
# Modified value of the whole property.
# @param thisValue [Wx::Variant] Value of this property. Changed value should be returned (in previous versions of {Wx::PG::PropertyGrid} it was only necessary to write value back to this argument).
# @param childIndex [Integer] Index of child changed (you can use Item(childIndex) to get child property).
# @param childValue [Wx::Variant] (Pending) value of the child property.
# @return [Wx::Variant]
def child_changed(thisValue, childIndex, childValue) end
# Refresh values of child properties.
# Automatically called after value is set.
# @return [void]
def refresh_children; end
#
# @return [Wx::Variant]
def value_; end
#
# @param val [nil,String,Integer,Float,Time,Wx::Font,Wx::Colour,Wx::Variant,Array,Array,ObjectWx::PG::ColourPropertyValue]
# @return [void]
def value_=(val); end
protected
# Shows editor dialog.
# Value to be edited should be read from value, and if dialog is not cancelled, it should be stored back and true should be returned.
#
# Returns true if editor dialog was not cancelled and value was updated.
# @param pg [Wx::PG::PropertyGrid] Property grid in which property is displayed.
# @param value [Wx::Variant] Value to be edited.
# @return [Boolean]
def display_editor_dialog(pg, value) end
end # FontProperty
# Like {Wx::PG::StringProperty}, but has a button that triggers a small text editor dialog.
# Supported special attributes:
#
# - {Wx::PG::PG_DIALOG_TITLE}: Sets a specific title for the text editor dialog (since 3.1.3).
#
class LongStringProperty < EditorDialogProperty
# @param label [String]
# @param name [String]
# @param value [String]
# @return [Wx::PG::LongStringProperty]
def initialize(label=Wx::PG::PG_LABEL, name=Wx::PG::PG_LABEL, value=('')) end
# Converts property value into a text representation.
# Default implementation calls {Wx::PG::LongStringProperty#generate_composed_value}.
# @param value [Wx::Variant] Value to be converted.
# @param argFlags [Integer] If 0 (default value), then displayed string is returned. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_FULL_VALUE} is set, returns complete, storable string value instead of displayable. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_EDITABLE_VALUE} is set, returns string value that must be editable in textctrl. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_COMPOSITE_FRAGMENT} is set, returns text that is appropriate to display as a part of string property's composite text representation.
# @return [String]
def value_to_string(value, argFlags=0) end
# Converts text into {Wx::Variant} value appropriate for this property.
# Returns true if resulting {Wx::Variant} value was different.
#
# Default implementation converts semicolon delimited tokens into child values. Only works for properties with children.
#
# You might want to take into account that m_value is Null variant if property value is unspecified (which is usually only case if you explicitly enabled that sort behaviour).
# @param variant [Wx::Variant] On function entry this is the old value (should not be {Wx::NullVariant} in normal cases). Translated value must be assigned back to it.
# @param text [String] Text to be translated into variant.
# @param argFlags [Integer] If {Wx::PG::PG_MISC_ARG_FLAGS::PG_FULL_VALUE} is set, returns complete, storable value instead of displayable one (they may be different). If {Wx::PG::PG_MISC_ARG_FLAGS::PG_COMPOSITE_FRAGMENT} is set, text is interpreted as a part of composite property string value (as generated by {Wx::PG::LongStringProperty#value_to_string} called with this same flag).
# @return [Boolean]
def string_to_value(variant, text, argFlags=0) end
#
# @return [Wx::Variant]
def value_; end
#
# @param val [nil,String,Integer,Float,Time,Wx::Font,Wx::Colour,Wx::Variant,Array,Array,ObjectWx::PG::ColourPropertyValue]
# @return [void]
def value_=(val); end
protected
# Shows editor dialog.
# Value to be edited should be read from value, and if dialog is not cancelled, it should be stored back and true should be returned.
#
# Returns true if editor dialog was not cancelled and value was updated.
# @param pg [Wx::PG::PropertyGrid] Property grid in which property is displayed.
# @param value [Wx::Variant] Value to be edited.
# @return [Boolean]
def display_editor_dialog(pg, value) end
end # LongStringProperty
# Property that manages a value resulting from {Wx::MultiChoiceDialog}.
# Value is array of strings. You can get value as array of choice values/indices by calling {Wx::PG::MultiChoiceProperty#get_value_as_array_int}.
# Supported special attributes:
#
# - {Wx::PG::PG_ATTR_MULTICHOICE_USERSTRINGMODE}: If > 0, allow user to manually enter strings that are not in the list of choices. If this value is 1, user strings are preferably placed in front of valid choices. If value is 2, then those strings will placed behind valid choices.
# - {Wx::PG::PG_DIALOG_TITLE}: Sets a specific title for the editor dialog (since 3.1.3).
#
class MultiChoiceProperty < EditorDialogProperty
# @overload initialize(label, name, strings, value)
# @param label [String]
# @param name [String]
# @param strings [Array]
# @param value [Array]
# @return [Wx::PG::MultiChoiceProperty]
# @overload initialize(label, name, choices, value=(Wx::ArrayString.new()))
# @param label [String]
# @param name [String]
# @param choices [Wx::PG::PGChoices]
# @param value [Array]
# @return [Wx::PG::MultiChoiceProperty]
# @overload initialize(label=Wx::PG::PG_LABEL, name=Wx::PG::PG_LABEL, value=(Wx::ArrayString.new()))
# @param label [String]
# @param name [String]
# @param value [Array]
# @return [Wx::PG::MultiChoiceProperty]
def initialize(*args) end
# This virtual function is called after m_value has been set.
# - If m_value was set to Null variant (i.e. unspecified value), {Wx::PG::MultiChoiceProperty#on_set_value} will not be called.
# - m_value may be of any variant type. Typically properties internally support only one variant type, and as such {Wx::PG::MultiChoiceProperty#on_set_value} provides a good opportunity to convert supported values into internal type.
# - Default implementation does nothing.
# @return [void]
def on_set_value; end
# Converts property value into a text representation.
# Default implementation calls {Wx::PG::MultiChoiceProperty#generate_composed_value}.
# @param value [Wx::Variant] Value to be converted.
# @param argFlags [Integer] If 0 (default value), then displayed string is returned. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_FULL_VALUE} is set, returns complete, storable string value instead of displayable. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_EDITABLE_VALUE} is set, returns string value that must be editable in textctrl. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_COMPOSITE_FRAGMENT} is set, returns text that is appropriate to display as a part of string property's composite text representation.
# @return [String]
def value_to_string(value, argFlags=0) end
# Converts text into {Wx::Variant} value appropriate for this property.
# Returns true if resulting {Wx::Variant} value was different.
#
# Default implementation converts semicolon delimited tokens into child values. Only works for properties with children.
#
# You might want to take into account that m_value is Null variant if property value is unspecified (which is usually only case if you explicitly enabled that sort behaviour).
# @param variant [Wx::Variant] On function entry this is the old value (should not be {Wx::NullVariant} in normal cases). Translated value must be assigned back to it.
# @param text [String] Text to be translated into variant.
# @param argFlags [Integer] If {Wx::PG::PG_MISC_ARG_FLAGS::PG_FULL_VALUE} is set, returns complete, storable value instead of displayable one (they may be different). If {Wx::PG::PG_MISC_ARG_FLAGS::PG_COMPOSITE_FRAGMENT} is set, text is interpreted as a part of composite property string value (as generated by {Wx::PG::MultiChoiceProperty#value_to_string} called with this same flag).
# @return [Boolean]
def string_to_value(variant, text, argFlags=0) end
# @return [Array]
def get_value_as_array_int; end
alias_method :value_as_array_int, :get_value_as_array_int
#
#
#
# @return [String]
def display_; end
#
#
#
# @param val [String]
# @return [void]
def display_=(val); end
#
#
#
# @return [Integer]
def user_string_mode_; end
#
#
#
# @param val [Integer]
# @return [void]
def user_string_mode_=(val); end
# @param value [nil,String,Integer,Float,Time,Wx::Font,Wx::Colour,Wx::Variant,Array,Array,ObjectWx::PG::ColourPropertyValue]
# @return [String]
def generate_value_as_string(value) end
# @return [Array]
def get_value_as_indices; end
alias_method :value_as_indices, :get_value_as_indices
#
# @return [Wx::Variant]
def value_; end
#
# @param val [nil,String,Integer,Float,Time,Wx::Font,Wx::Colour,Wx::Variant,Array,Array,ObjectWx::PG::ColourPropertyValue]
# @return [void]
def value_=(val); end
protected
# Shows editor dialog.
# Value to be edited should be read from value, and if dialog is not cancelled, it should be stored back and true should be returned.
#
# Returns true if editor dialog was not cancelled and value was updated.
# @param pg [Wx::PG::PropertyGrid] Property grid in which property is displayed.
# @param value [Wx::Variant] Value to be edited.
# @return [Boolean]
def display_editor_dialog(pg, value) end
end # MultiChoiceProperty
# This is an abstract class which serves as a base class for numeric properties, like {Wx::PG::IntProperty}, {Wx::PG::UIntProperty}, {Wx::PG::FloatProperty}.
# Supported special attributes:
#
# - {Wx::PG::PG_ATTR_MIN}, {Wx::PG::PG_ATTR_MAX}: Specify acceptable value range.
# - {Wx::PG::PG_ATTR_SPINCTRL_STEP}: How much number changes when SpinCtrl editor button is pressed (or up/down on keyboard).
# - {Wx::PG::PG_ATTR_SPINCTRL_WRAP}: Specify if value modified with SpinCtrl editor wraps at Min/Max.
# - {Wx::PG::PG_ATTR_SPINCTRL_MOTION}: Specify if value can also by changed with SpinCtrl editor by moving mouse when left mouse button is being pressed.
#
class NumericProperty < PGProperty
# Reimplement this member function to add special handling for attributes of this property.
# Return false to have the attribute automatically stored in m_attributes. Default implementation simply does that and nothing else.
#
# To actually set property attribute values from the application, use {Wx::PG::PGProperty#set_attribute} instead.
# @param name [String]
# @param value [Wx::Variant]
# @return [Boolean]
def do_set_attribute(name, value) end
# Returns what would be the new value of the property after adding SpinCtrl editor step to the current value.
# Current value range and wrapping (if enabled) are taken into account. This member has to be implemented in derived properties.
#
# Value which property would have after adding SpinCtrl editor step.
#
# Current property value is not changed.
# @param stepScale [Integer] SpinCtrl editor step is first multiplied by this factor and next added to the current value.
# @return [Wx::Variant]
def add_spin_step_value(stepScale) end
# Return true if value can be changed with SpinCtrl editor by moving the mouse.
# @return [Boolean]
def use_spin_motion; end
#
#
#
# @return [Wx::Variant]
def min_val_; end
#
#
#
# @param val [nil,String,Integer,Float,Time,Wx::Font,Wx::Colour,Wx::Variant,Array,Array,ObjectWx::PG::ColourPropertyValue]
# @return [void]
def min_val_=(val); end
#
#
#
# @return [Wx::Variant]
def max_val_; end
#
#
#
# @param val [nil,String,Integer,Float,Time,Wx::Font,Wx::Colour,Wx::Variant,Array,Array,ObjectWx::PG::ColourPropertyValue]
# @return [void]
def max_val_=(val); end
#
#
#
# @return [Boolean]
def spin_motion_; end
#
#
#
# @param val [Boolean]
# @return [void]
def spin_motion_=(val); end
#
#
#
# @return [Wx::Variant]
def spin_step_; end
#
#
#
# @param val [nil,String,Integer,Float,Time,Wx::Font,Wx::Colour,Wx::Variant,Array,Array,ObjectWx::PG::ColourPropertyValue]
# @return [void]
def spin_step_=(val); end
#
#
#
# @return [Boolean]
def spin_wrap_; end
#
#
#
# @param val [Boolean]
# @return [void]
def spin_wrap_=(val); end
#
# @return [Wx::Variant]
def value_; end
#
# @param val [nil,String,Integer,Float,Time,Wx::Font,Wx::Colour,Wx::Variant,Array,Array,ObjectWx::PG::ColourPropertyValue]
# @return [void]
def value_=(val); end
protected
# Constructor is protected because {Wx::PG::NumericProperty} is only a base class for other numeric property classes.
# @param label [String]
# @param name [String]
# @return [Wx::PG::NumericProperty]
def initialize(label, name) end
end # NumericProperty
# Basic property with integer value.
# Supported special attributes:
# - {Wx::PG::PG_ATTR_MIN}, {Wx::PG::PG_ATTR_MAX}, {Wx::PG::PG_ATTR_SPINCTRL_STEP}, {Wx::PG::PG_ATTR_SPINCTRL_WRAP}, {Wx::PG::PG_ATTR_SPINCTRL_MOTION}: like in {Wx::PG::NumericProperty}.
#
class IntProperty < NumericProperty
# @overload initialize(label=Wx::PG::PG_LABEL, name=Wx::PG::PG_LABEL, value=0)
# @param label [String]
# @param name [String]
# @param value [Integer]
# @return [Wx::PG::IntProperty]
# @overload initialize(label, name, value)
# @param label [String]
# @param name [String]
# @param value [Integer]
# @return [Wx::PG::IntProperty]
def initialize(*args) end
# Converts property value into a text representation.
# Default implementation calls {Wx::PG::IntProperty#generate_composed_value}.
# @param value [Wx::Variant] Value to be converted.
# @param argFlags [Integer] If 0 (default value), then displayed string is returned. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_FULL_VALUE} is set, returns complete, storable string value instead of displayable. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_EDITABLE_VALUE} is set, returns string value that must be editable in textctrl. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_COMPOSITE_FRAGMENT} is set, returns text that is appropriate to display as a part of string property's composite text representation.
# @return [String]
def value_to_string(value, argFlags=0) end
# Converts text into {Wx::Variant} value appropriate for this property.
# Returns true if resulting {Wx::Variant} value was different.
#
# Default implementation converts semicolon delimited tokens into child values. Only works for properties with children.
#
# You might want to take into account that m_value is Null variant if property value is unspecified (which is usually only case if you explicitly enabled that sort behaviour).
# @param variant [Wx::Variant] On function entry this is the old value (should not be {Wx::NullVariant} in normal cases). Translated value must be assigned back to it.
# @param text [String] Text to be translated into variant.
# @param argFlags [Integer] If {Wx::PG::PG_MISC_ARG_FLAGS::PG_FULL_VALUE} is set, returns complete, storable value instead of displayable one (they may be different). If {Wx::PG::PG_MISC_ARG_FLAGS::PG_COMPOSITE_FRAGMENT} is set, text is interpreted as a part of composite property string value (as generated by {Wx::PG::IntProperty#value_to_string} called with this same flag).
# @return [Boolean]
def string_to_value(variant, text, argFlags=0) end
# Implement this function in derived class to check the value.
# Return true if it is ok. Returning false prevents property change events from occurring.
#
# - Default implementation always returns true.
# @param value [Wx::Variant]
# @param validationInfo [Wx::PG::PGValidationInfo]
# @return [Boolean]
def validate_value(value, validationInfo) end
# Converts integer (possibly a choice selection) into {Wx::Variant} value appropriate for this property.
# Returns true if resulting {Wx::Variant} value was different.
#
# - If property is not supposed to use choice or spinctrl or other editor with int-based value, it is not necessary to implement this method.
# - Default implementation simply assign given int to m_value.
# - If property uses choice control, and displays a dialog on some choice items, then it is preferred to display that dialog in IntToValue instead of OnEvent.
# - You might want to take into account that m_value is Mull variant if property value is unspecified (which is usually only case if you explicitly enabled that sort behaviour).
# @param variant [Wx::Variant] On function entry this is the old value (should not be {Wx::NullVariant} in normal cases). Translated value must be assigned back to it.
# @param number [Integer] Integer to be translated into variant.
# @param argFlags [Integer] If {Wx::PG::PG_MISC_ARG_FLAGS::PG_FULL_VALUE} is set, returns complete, storable value instead of displayable one.
# @return [Boolean]
def int_to_value(variant, number, argFlags=0) end
# Returns pointer to the {Wx::Validator} that should be used with the editor of this property (NULL for no validator).
# Setting validator explicitly via #set_property_validator will override this.
# In most situations, code like this should work well:
#
# ```ruby
# class MyPropertyClass < Wx::PG::IntProperty
#
# class << self
# def validator
# @validator ||= MyValidator.new(...)
# end
# end
#
# # ...
#
# def do_get_validator
# MyPropertyClass.validator
# end
#
# # ...
#
# end
# ```
#
# You can get common filename validator by returning {Wx::PG::FileProperty.get_class_validator}. {Wx::PG::DirProperty}, for example, uses it.
# @return [Wx::Validator]
def do_get_validator; end
# Returns what would be the new value of the property after adding SpinCtrl editor step to the current value.
# Current value range and wrapping (if enabled) are taken into account. This member has to be implemented in derived properties.
#
# Value which property would have after adding SpinCtrl editor step.
#
# Current property value is not changed.
# @param stepScale [Integer] SpinCtrl editor step is first multiplied by this factor and next added to the current value.
# @return [Wx::Variant]
def add_spin_step_value(stepScale) end
# @return [Wx::Validator]
def self.get_class_validator; end
#
# @return [Wx::Variant]
def value_; end
#
# @param val [nil,String,Integer,Float,Time,Wx::Font,Wx::Colour,Wx::Variant,Array,Array,ObjectWx::PG::ColourPropertyValue]
# @return [void]
def value_=(val); end
#
# @return [Wx::Variant]
def min_val_; end
#
# @param val [nil,String,Integer,Float,Time,Wx::Font,Wx::Colour,Wx::Variant,Array,Array,ObjectWx::PG::ColourPropertyValue]
# @return [void]
def min_val_=(val); end
#
# @return [Wx::Variant]
def max_val_; end
#
# @param val [nil,String,Integer,Float,Time,Wx::Font,Wx::Colour,Wx::Variant,Array,Array,ObjectWx::PG::ColourPropertyValue]
# @return [void]
def max_val_=(val); end
#
# @return [Boolean]
def spin_motion_; end
#
# @param val [Boolean]
# @return [void]
def spin_motion_=(val); end
#
# @return [Wx::Variant]
def spin_step_; end
#
# @param val [nil,String,Integer,Float,Time,Wx::Font,Wx::Colour,Wx::Variant,Array,Array,ObjectWx::PG::ColourPropertyValue]
# @return [void]
def spin_step_=(val); end
#
# @return [Boolean]
def spin_wrap_; end
#
# @param val [Boolean]
# @return [void]
def spin_wrap_=(val); end
end # IntProperty
# Basic property with double-precision floating point value.
# Supported special attributes:
#
# - {Wx::PG::PG_FLOAT_PRECISION}: Sets the (max) precision used when floating point value is rendered as text. The default -1 means infinite precision.
# - {Wx::PG::PG_ATTR_MIN}, {Wx::PG::PG_ATTR_MAX}, {Wx::PG::PG_ATTR_SPINCTRL_STEP}, {Wx::PG::PG_ATTR_SPINCTRL_WRAP}, {Wx::PG::PG_ATTR_SPINCTRL_MOTION}: like in {Wx::PG::NumericProperty}.
#
class FloatProperty < NumericProperty
# @param label [String]
# @param name [String]
# @param value [Float]
# @return [Wx::PG::FloatProperty]
def initialize(label=Wx::PG::PG_LABEL, name=Wx::PG::PG_LABEL, value=0.0) end
# Converts property value into a text representation.
# Default implementation calls {Wx::PG::FloatProperty#generate_composed_value}.
# @param value [Wx::Variant] Value to be converted.
# @param argFlags [Integer] If 0 (default value), then displayed string is returned. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_FULL_VALUE} is set, returns complete, storable string value instead of displayable. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_EDITABLE_VALUE} is set, returns string value that must be editable in textctrl. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_COMPOSITE_FRAGMENT} is set, returns text that is appropriate to display as a part of string property's composite text representation.
# @return [String]
def value_to_string(value, argFlags=0) end
# Converts text into {Wx::Variant} value appropriate for this property.
# Returns true if resulting {Wx::Variant} value was different.
#
# Default implementation converts semicolon delimited tokens into child values. Only works for properties with children.
#
# You might want to take into account that m_value is Null variant if property value is unspecified (which is usually only case if you explicitly enabled that sort behaviour).
# @param variant [Wx::Variant] On function entry this is the old value (should not be {Wx::NullVariant} in normal cases). Translated value must be assigned back to it.
# @param text [String] Text to be translated into variant.
# @param argFlags [Integer] If {Wx::PG::PG_MISC_ARG_FLAGS::PG_FULL_VALUE} is set, returns complete, storable value instead of displayable one (they may be different). If {Wx::PG::PG_MISC_ARG_FLAGS::PG_COMPOSITE_FRAGMENT} is set, text is interpreted as a part of composite property string value (as generated by {Wx::PG::FloatProperty#value_to_string} called with this same flag).
# @return [Boolean]
def string_to_value(variant, text, argFlags=0) end
# Reimplement this member function to add special handling for attributes of this property.
# Return false to have the attribute automatically stored in m_attributes. Default implementation simply does that and nothing else.
#
# To actually set property attribute values from the application, use {Wx::PG::PGProperty#set_attribute} instead.
# @param name [String]
# @param value [Wx::Variant]
# @return [Boolean]
def do_set_attribute(name, value) end
# Implement this function in derived class to check the value.
# Return true if it is ok. Returning false prevents property change events from occurring.
#
# - Default implementation always returns true.
# @param value [Wx::Variant]
# @param validationInfo [Wx::PG::PGValidationInfo]
# @return [Boolean]
def validate_value(value, validationInfo) end
# Returns pointer to the {Wx::Validator} that should be used with the editor of this property (NULL for no validator).
# Setting validator explicitly via #set_property_validator will override this.
# In most situations, code like this should work well:
#
# ```ruby
# class MyPropertyClass < Wx::PG::FloatProperty
#
# class << self
# def validator
# @validator ||= MyValidator.new(...)
# end
# end
#
# # ...
#
# def do_get_validator
# MyPropertyClass.validator
# end
#
# # ...
#
# end
# ```
#
# You can get common filename validator by returning {Wx::PG::FileProperty.get_class_validator}. {Wx::PG::DirProperty}, for example, uses it.
# @return [Wx::Validator]
def do_get_validator; end
# Returns what would be the new value of the property after adding SpinCtrl editor step to the current value.
# Current value range and wrapping (if enabled) are taken into account. This member has to be implemented in derived properties.
#
# Value which property would have after adding SpinCtrl editor step.
#
# Current property value is not changed.
# @param stepScale [Integer] SpinCtrl editor step is first multiplied by this factor and next added to the current value.
# @return [Wx::Variant]
def add_spin_step_value(stepScale) end
# @return [Wx::Validator]
def self.get_class_validator; end
#
#
#
# @return [Integer]
def precision_; end
#
#
#
# @param val [Integer]
# @return [void]
def precision_=(val); end
#
# @return [Wx::Variant]
def value_; end
#
# @param val [nil,String,Integer,Float,Time,Wx::Font,Wx::Colour,Wx::Variant,Array,Array,ObjectWx::PG::ColourPropertyValue]
# @return [void]
def value_=(val); end
#
# @return [Wx::Variant]
def min_val_; end
#
# @param val [nil,String,Integer,Float,Time,Wx::Font,Wx::Colour,Wx::Variant,Array,Array,ObjectWx::PG::ColourPropertyValue]
# @return [void]
def min_val_=(val); end
#
# @return [Wx::Variant]
def max_val_; end
#
# @param val [nil,String,Integer,Float,Time,Wx::Font,Wx::Colour,Wx::Variant,Array,Array,ObjectWx::PG::ColourPropertyValue]
# @return [void]
def max_val_=(val); end
#
# @return [Boolean]
def spin_motion_; end
#
# @param val [Boolean]
# @return [void]
def spin_motion_=(val); end
#
# @return [Wx::Variant]
def spin_step_; end
#
# @param val [nil,String,Integer,Float,Time,Wx::Font,Wx::Colour,Wx::Variant,Array,Array,ObjectWx::PG::ColourPropertyValue]
# @return [void]
def spin_step_=(val); end
#
# @return [Boolean]
def spin_wrap_; end
#
# @param val [Boolean]
# @return [void]
def spin_wrap_=(val); end
end # FloatProperty
# Basic property with unsigned integer value.
# Seamlessly supports 64-bit integer ({Wx::ULongLong}) on overflow.
# Supported special attributes:
#
# - {Wx::PG::PG_UINT_BASE}: Define base. Valid constants are {Wx::PG::PG_BASE_OCT}, {Wx::PG::PG_BASE_DEC}, {Wx::PG::PG_BASE_HEX} and {Wx::PG::PG_BASE_HEXL} (lowercase characters). Arbitrary bases are not supported.
# - {Wx::PG::PG_UINT_PREFIX}: Possible values are {Wx::PG::PG_PREFIX_NONE}, {Wx::PG::PG_PREFIX_0x}, and {Wx::PG::PG_PREFIX_DOLLAR_SIGN}. Only {Wx::PG::PG_PREFIX_NONE} works with Decimal and Octal numbers.
# - {Wx::PG::PG_ATTR_MIN}, {Wx::PG::PG_ATTR_MAX}, {Wx::PG::PG_ATTR_SPINCTRL_STEP}, {Wx::PG::PG_ATTR_SPINCTRL_WRAP}, {Wx::PG::PG_ATTR_SPINCTRL_MOTION}: like in {Wx::PG::NumericProperty}.
#
# - For example how to use seamless 64-bit integer support, see {Wx::PG::IntProperty} documentation (just use {Wx::ULongLong} instead of {Wx::LongLong}).
#
class UIntProperty < NumericProperty
# @overload initialize(label=Wx::PG::PG_LABEL, name=Wx::PG::PG_LABEL, value=0)
# @param label [String]
# @param name [String]
# @param value [Integer]
# @return [Wx::PG::UIntProperty]
# @overload initialize(label, name, value)
# @param label [String]
# @param name [String]
# @param value [Integer]
# @return [Wx::PG::UIntProperty]
def initialize(*args) end
# Converts property value into a text representation.
# Default implementation calls {Wx::PG::UIntProperty#generate_composed_value}.
# @param value [Wx::Variant] Value to be converted.
# @param argFlags [Integer] If 0 (default value), then displayed string is returned. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_FULL_VALUE} is set, returns complete, storable string value instead of displayable. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_EDITABLE_VALUE} is set, returns string value that must be editable in textctrl. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_COMPOSITE_FRAGMENT} is set, returns text that is appropriate to display as a part of string property's composite text representation.
# @return [String]
def value_to_string(value, argFlags=0) end
# Converts text into {Wx::Variant} value appropriate for this property.
# Returns true if resulting {Wx::Variant} value was different.
#
# Default implementation converts semicolon delimited tokens into child values. Only works for properties with children.
#
# You might want to take into account that m_value is Null variant if property value is unspecified (which is usually only case if you explicitly enabled that sort behaviour).
# @param variant [Wx::Variant] On function entry this is the old value (should not be {Wx::NullVariant} in normal cases). Translated value must be assigned back to it.
# @param text [String] Text to be translated into variant.
# @param argFlags [Integer] If {Wx::PG::PG_MISC_ARG_FLAGS::PG_FULL_VALUE} is set, returns complete, storable value instead of displayable one (they may be different). If {Wx::PG::PG_MISC_ARG_FLAGS::PG_COMPOSITE_FRAGMENT} is set, text is interpreted as a part of composite property string value (as generated by {Wx::PG::UIntProperty#value_to_string} called with this same flag).
# @return [Boolean]
def string_to_value(variant, text, argFlags=0) end
# Reimplement this member function to add special handling for attributes of this property.
# Return false to have the attribute automatically stored in m_attributes. Default implementation simply does that and nothing else.
#
# To actually set property attribute values from the application, use {Wx::PG::PGProperty#set_attribute} instead.
# @param name [String]
# @param value [Wx::Variant]
# @return [Boolean]
def do_set_attribute(name, value) end
# Implement this function in derived class to check the value.
# Return true if it is ok. Returning false prevents property change events from occurring.
#
# - Default implementation always returns true.
# @param value [Wx::Variant]
# @param validationInfo [Wx::PG::PGValidationInfo]
# @return [Boolean]
def validate_value(value, validationInfo) end
# Returns pointer to the {Wx::Validator} that should be used with the editor of this property (NULL for no validator).
# Setting validator explicitly via #set_property_validator will override this.
# In most situations, code like this should work well:
#
# ```ruby
# class MyPropertyClass < Wx::PG::UIntProperty
#
# class << self
# def validator
# @validator ||= MyValidator.new(...)
# end
# end
#
# # ...
#
# def do_get_validator
# MyPropertyClass.validator
# end
#
# # ...
#
# end
# ```
#
# You can get common filename validator by returning {Wx::PG::FileProperty.get_class_validator}. {Wx::PG::DirProperty}, for example, uses it.
# @return [Wx::Validator]
def do_get_validator; end
# Converts integer (possibly a choice selection) into {Wx::Variant} value appropriate for this property.
# Returns true if resulting {Wx::Variant} value was different.
#
# - If property is not supposed to use choice or spinctrl or other editor with int-based value, it is not necessary to implement this method.
# - Default implementation simply assign given int to m_value.
# - If property uses choice control, and displays a dialog on some choice items, then it is preferred to display that dialog in IntToValue instead of OnEvent.
# - You might want to take into account that m_value is Mull variant if property value is unspecified (which is usually only case if you explicitly enabled that sort behaviour).
# @param variant [Wx::Variant] On function entry this is the old value (should not be {Wx::NullVariant} in normal cases). Translated value must be assigned back to it.
# @param number [Integer] Integer to be translated into variant.
# @param argFlags [Integer] If {Wx::PG::PG_MISC_ARG_FLAGS::PG_FULL_VALUE} is set, returns complete, storable value instead of displayable one.
# @return [Boolean]
def int_to_value(variant, number, argFlags=0) end
# Returns what would be the new value of the property after adding SpinCtrl editor step to the current value.
# Current value range and wrapping (if enabled) are taken into account. This member has to be implemented in derived properties.
#
# Value which property would have after adding SpinCtrl editor step.
#
# Current property value is not changed.
# @param stepScale [Integer] SpinCtrl editor step is first multiplied by this factor and next added to the current value.
# @return [Wx::Variant]
def add_spin_step_value(stepScale) end
#
#
#
# @return [Integer]
def base_; end
#
#
#
# @param val [Integer]
# @return [void]
def base_=(val); end
#
#
#
# @return [Integer]
def real_base_; end
#
#
#
# @param val [Integer]
# @return [void]
def real_base_=(val); end
#
#
#
# @return [Integer]
def prefix_; end
#
#
#
# @param val [Integer]
# @return [void]
def prefix_=(val); end
#
# @return [Wx::Variant]
def value_; end
#
# @param val [nil,String,Integer,Float,Time,Wx::Font,Wx::Colour,Wx::Variant,Array,Array,ObjectWx::PG::ColourPropertyValue]
# @return [void]
def value_=(val); end
#
# @return [Wx::Variant]
def min_val_; end
#
# @param val [nil,String,Integer,Float,Time,Wx::Font,Wx::Colour,Wx::Variant,Array,Array,ObjectWx::PG::ColourPropertyValue]
# @return [void]
def min_val_=(val); end
#
# @return [Wx::Variant]
def max_val_; end
#
# @param val [nil,String,Integer,Float,Time,Wx::Font,Wx::Colour,Wx::Variant,Array,Array,ObjectWx::PG::ColourPropertyValue]
# @return [void]
def max_val_=(val); end
#
# @return [Boolean]
def spin_motion_; end
#
# @param val [Boolean]
# @return [void]
def spin_motion_=(val); end
#
# @return [Wx::Variant]
def spin_step_; end
#
# @param val [nil,String,Integer,Float,Time,Wx::Font,Wx::Colour,Wx::Variant,Array,Array,ObjectWx::PG::ColourPropertyValue]
# @return [void]
def spin_step_=(val); end
#
# @return [Boolean]
def spin_wrap_; end
#
# @param val [Boolean]
# @return [void]
def spin_wrap_=(val); end
end # UIntProperty
# You can derive custom properties with choices from this class.
# See {Wx::BaseEnumProperty} for remarks.
#
# - Updating private index is important. You can do this either by calling {Wx::PG::EnumProperty#set_index} in IntToValue, and then letting Wx::BaseEnumProperty::OnSetValue be called (by not implementing it, or by calling super class function in it) -OR- you can just call SetIndex in OnSetValue.
#
class EnumProperty < PGProperty
# @overload initialize(label, name, choices, value=0)
# @param label [String]
# @param name [String]
# @param choices [Wx::PG::PGChoices]
# @param value [Integer]
# @return [Wx::PG::EnumProperty]
# @overload initialize(label, name, labels, values=(Wx::ArrayInt.new()), value=0)
# @param label [String]
# @param name [String]
# @param labels [Array]
# @param values [Array]
# @param value [Integer]
# @return [Wx::PG::EnumProperty]
def initialize(*args) end
# @return [Integer]
def get_item_count; end
alias_method :item_count, :get_item_count
# This virtual function is called after m_value has been set.
# - If m_value was set to Null variant (i.e. unspecified value), {Wx::PG::EnumProperty#on_set_value} will not be called.
# - m_value may be of any variant type. Typically properties internally support only one variant type, and as such {Wx::PG::EnumProperty#on_set_value} provides a good opportunity to convert supported values into internal type.
# - Default implementation does nothing.
# @return [void]
def on_set_value; end
# Converts property value into a text representation.
# Default implementation calls {Wx::PG::EnumProperty#generate_composed_value}.
# @param value [Wx::Variant] Value to be converted.
# @param argFlags [Integer] If 0 (default value), then displayed string is returned. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_FULL_VALUE} is set, returns complete, storable string value instead of displayable. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_EDITABLE_VALUE} is set, returns string value that must be editable in textctrl. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_COMPOSITE_FRAGMENT} is set, returns text that is appropriate to display as a part of string property's composite text representation.
# @return [String]
def value_to_string(value, argFlags=0) end
# Converts text into {Wx::Variant} value appropriate for this property.
# Returns true if resulting {Wx::Variant} value was different.
#
# Default implementation converts semicolon delimited tokens into child values. Only works for properties with children.
#
# You might want to take into account that m_value is Null variant if property value is unspecified (which is usually only case if you explicitly enabled that sort behaviour).
# @param variant [Wx::Variant] On function entry this is the old value (should not be {Wx::NullVariant} in normal cases). Translated value must be assigned back to it.
# @param text [String] Text to be translated into variant.
# @param argFlags [Integer] If {Wx::PG::PG_MISC_ARG_FLAGS::PG_FULL_VALUE} is set, returns complete, storable value instead of displayable one (they may be different). If {Wx::PG::PG_MISC_ARG_FLAGS::PG_COMPOSITE_FRAGMENT} is set, text is interpreted as a part of composite property string value (as generated by {Wx::PG::EnumProperty#value_to_string} called with this same flag).
# @return [Boolean]
def string_to_value(variant, text, argFlags=0) end
# Implement this function in derived class to check the value.
# Return true if it is ok. Returning false prevents property change events from occurring.
#
# - Default implementation always returns true.
# @param value [Wx::Variant]
# @param validationInfo [Wx::PG::PGValidationInfo]
# @return [Boolean]
def validate_value(value, validationInfo) end
# Converts integer (possibly a choice selection) into {Wx::Variant} value appropriate for this property.
# Returns true if resulting {Wx::Variant} value was different.
#
# - If property is not supposed to use choice or spinctrl or other editor with int-based value, it is not necessary to implement this method.
# - Default implementation simply assign given int to m_value.
# - If property uses choice control, and displays a dialog on some choice items, then it is preferred to display that dialog in IntToValue instead of OnEvent.
# - You might want to take into account that m_value is Mull variant if property value is unspecified (which is usually only case if you explicitly enabled that sort behaviour).
# @param variant [Wx::Variant] On function entry this is the old value (should not be {Wx::NullVariant} in normal cases). Translated value must be assigned back to it.
# @param number [Integer] Integer to be translated into variant.
# @param argFlags [Integer] If {Wx::PG::PG_MISC_ARG_FLAGS::PG_FULL_VALUE} is set, returns complete, storable value instead of displayable one.
# @return [Boolean]
def int_to_value(variant, number, argFlags=0) end
# @param value [Integer]
# @return [Integer]
def get_index_for_value(value) end
alias_method :index_for_value, :get_index_for_value
# Returns which choice is currently selected.
# Only applies to properties which have choices.
# Needs to reimplemented in derived class if property value does not map directly to a choice. Integer as index, bool, and string usually do.
# @return [Integer]
def get_choice_selection; end
alias_method :choice_selection, :get_choice_selection
# @return [Integer]
def get_index; end
alias_method :index, :get_index
# @param index [Integer]
# @return [void]
def set_index(index) end
alias_method :index=, :set_index
# @param value [Wx::Variant]
# @param text [String]
# @param argFlags [Integer]
# @return [Boolean]
def value_from_string_(value, text, argFlags) end
# @param value [Wx::Variant]
# @param intVal [Integer]
# @param argFlags [Integer]
# @return [Boolean]
def value_from_int_(value, intVal, argFlags) end
#
# @return [Wx::Variant]
def value_; end
#
# @param val [nil,String,Integer,Float,Time,Wx::Font,Wx::Colour,Wx::Variant,Array,Array,ObjectWx::PG::ColourPropertyValue]
# @return [void]
def value_=(val); end
end # EnumProperty
# Property representing {Wx::Cursor}.
#
#
class CursorProperty < EnumProperty
# @param label [String]
# @param name [String]
# @param value [Integer]
# @return [Wx::PG::CursorProperty]
def initialize(label=Wx::PG::PG_LABEL, name=Wx::PG::PG_LABEL, value=0) end
# Returns size of the custom painted image in front of property.
# This method must be overridden to return non-default value if OnCustomPaint is to be called.
#
# - Default behaviour is to return {size(0,0)}, which means no image.
# - Default image width or height is indicated with dimension -1.
# - You can also return {Wx::PG::PG_DEFAULT_IMAGE_SIZE} which equals {Wx::DEFAULT_SIZE}.
# @param item [Integer] Normally -1, but can be an index to the property's list of items.
# @return [Wx::Size]
def on_measure_image(item) end
# Override to paint an image in front of the property value text or drop-down list item (but only if {Wx::PG::PGProperty#on_measure_image} is overridden as well).
# If property's {Wx::PG::CursorProperty#on_measure_image} returns size that has height != 0 but less than row height ( < 0 has special meanings), {Wx::PG::PropertyGrid} calls this method to draw a custom image in a limited area in front of the editor control or value text/graphics, and if control has drop-down list, then the image is drawn there as well (even in the case {Wx::PG::CursorProperty#on_measure_image} returned higher height than row height).
# NOTE: Following applies when {Wx::PG::CursorProperty#on_measure_image} returns a "flexible" height ( using wxPG_FLEXIBLE_SIZE(W,H)
macro), which implies variable height items: If (rect.x+rect.width) is < 0, then this is a measure item call, which means that dc is invalid and only thing that should be done is to set paintdata.m_drawnHeight to the height of the image of item at index paintdata.m_choiceItem. This call may be done even as often as once every drop-down popup show.
#
# - You can actually exceed rect width, but if you do so then paintdata.m_drawnWidth must be set to the full width drawn in pixels.
# - Due to technical reasons, rect's height will be default even if custom height was reported during measure call.
# - Brush is guaranteed to be default background colour. It has been already used to clear the background of area being painted. It can be modified.
# - Pen is guaranteed to be 1-wide 'black' (or whatever is the proper colour) pen for drawing framing rectangle. It can be changed as well.
# @see Wx::PG::CursorProperty#value_to_string
# @param dc [Wx::DC] {Wx::DC} to paint on.
# @param rect [Wx::Rect] Box reserved for custom graphics. Includes surrounding rectangle, if any. If x+width is < 0, then this is a measure item call (see above).
# @param paintdata [Wx::PG::PGPaintData] {Wx::PG::PGPaintData} structure with much useful data about painted item.
# @return [void]
def on_custom_paint(dc, rect, paintdata) end
#
# @return [Wx::Variant]
def value_; end
#
# @param val [nil,String,Integer,Float,Time,Wx::Font,Wx::Colour,Wx::Variant,Array,Array,ObjectWx::PG::ColourPropertyValue]
# @return [void]
def value_=(val); end
end # CursorProperty
# {Wx::PG::EnumProperty} with {Wx::String} value and writable combo box editor.
# Uses int value, similar to {Wx::PG::EnumProperty}, unless text entered by user is not in choices (in which case string value is used).
#
class EditEnumProperty < EnumProperty
# @overload initialize(label=Wx::PG::PG_LABEL, name=Wx::PG::PG_LABEL, labels=(Wx::ArrayString.new()), values=(Wx::ArrayInt.new()), value=(''))
# @param label [String]
# @param name [String]
# @param labels [Array]
# @param values [Array]
# @param value [String]
# @return [Wx::PG::EditEnumProperty]
# @overload initialize(label, name, choices, value=(''))
# @param label [String]
# @param name [String]
# @param choices [Wx::PG::PGChoices]
# @param value [String]
# @return [Wx::PG::EditEnumProperty]
def initialize(*args) end
#
# @return [Wx::Variant]
def value_; end
#
# @param val [nil,String,Integer,Float,Time,Wx::Font,Wx::Colour,Wx::Variant,Array,Array,ObjectWx::PG::ColourPropertyValue]
# @return [void]
def value_=(val); end
end # EditEnumProperty
# Has dropdown list of wxWidgets system colours.
# Value used is of {Wx::PG::ColourPropertyValue} type.
# Supported special attributes: {Wx::PG::PG_COLOUR_ALLOW_CUSTOM}, {Wx::PG::PG_COLOUR_HAS_ALPHA}
#
class SystemColourProperty < EnumProperty
# @param label [String]
# @param name [String]
# @param value [Wx::PG::ColourPropertyValue]
# @return [Wx::PG::SystemColourProperty]
def initialize(label=Wx::PG::PG_LABEL, name=Wx::PG::PG_LABEL, value=(Wx::ColourPropertyValue.new())) end
# This virtual function is called after m_value has been set.
# - If m_value was set to Null variant (i.e. unspecified value), {Wx::PG::SystemColourProperty#on_set_value} will not be called.
# - m_value may be of any variant type. Typically properties internally support only one variant type, and as such {Wx::PG::SystemColourProperty#on_set_value} provides a good opportunity to convert supported values into internal type.
# - Default implementation does nothing.
# @return [void]
def on_set_value; end
# Converts integer (possibly a choice selection) into {Wx::Variant} value appropriate for this property.
# Returns true if resulting {Wx::Variant} value was different.
#
# - If property is not supposed to use choice or spinctrl or other editor with int-based value, it is not necessary to implement this method.
# - Default implementation simply assign given int to m_value.
# - If property uses choice control, and displays a dialog on some choice items, then it is preferred to display that dialog in IntToValue instead of OnEvent.
# - You might want to take into account that m_value is Mull variant if property value is unspecified (which is usually only case if you explicitly enabled that sort behaviour).
# @param variant [Wx::Variant] On function entry this is the old value (should not be {Wx::NullVariant} in normal cases). Translated value must be assigned back to it.
# @param number [Integer] Integer to be translated into variant.
# @param argFlags [Integer] If {Wx::PG::PG_MISC_ARG_FLAGS::PG_FULL_VALUE} is set, returns complete, storable value instead of displayable one.
# @return [Boolean]
def int_to_value(variant, number, argFlags=0) end
# Override in derived class to customize how colours are printed as strings.
# @param col [Wx::Colour,String,Symbol]
# @param index [Integer]
# @param argFlags [Integer]
# @return [String]
def colour_to_string(col, index, argFlags=0) end
# Returns index of entry that triggers colour picker dialog (default is last).
# @return [Integer]
def get_custom_colour_index; end
alias_method :custom_colour_index, :get_custom_colour_index
# Converts property value into a text representation.
# Default implementation calls {Wx::PG::SystemColourProperty#generate_composed_value}.
# @param value [Wx::Variant] Value to be converted.
# @param argFlags [Integer] If 0 (default value), then displayed string is returned. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_FULL_VALUE} is set, returns complete, storable string value instead of displayable. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_EDITABLE_VALUE} is set, returns string value that must be editable in textctrl. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_COMPOSITE_FRAGMENT} is set, returns text that is appropriate to display as a part of string property's composite text representation.
# @return [String]
def value_to_string(value, argFlags=0) end
# Converts text into {Wx::Variant} value appropriate for this property.
# Returns true if resulting {Wx::Variant} value was different.
#
# Default implementation converts semicolon delimited tokens into child values. Only works for properties with children.
#
# You might want to take into account that m_value is Null variant if property value is unspecified (which is usually only case if you explicitly enabled that sort behaviour).
# @param variant [Wx::Variant] On function entry this is the old value (should not be {Wx::NullVariant} in normal cases). Translated value must be assigned back to it.
# @param text [String] Text to be translated into variant.
# @param argFlags [Integer] If {Wx::PG::PG_MISC_ARG_FLAGS::PG_FULL_VALUE} is set, returns complete, storable value instead of displayable one (they may be different). If {Wx::PG::PG_MISC_ARG_FLAGS::PG_COMPOSITE_FRAGMENT} is set, text is interpreted as a part of composite property string value (as generated by {Wx::PG::SystemColourProperty#value_to_string} called with this same flag).
# @return [Boolean]
def string_to_value(variant, text, argFlags=0) end
# Events received by editor widgets are processed here.
# Note that editor class usually processes most events. Some, such as button press events of TextCtrlAndButton class, can be handled here. Also, if custom handling for regular events is desired, then that can also be done (for example, {Wx::PG::SystemColourProperty} custom handles {Wx::EVT_CHOICE} to display colour picker dialog when 'custom' selection is made).
# If the event causes value to be changed, {Wx::PG::SystemColourProperty#set_value_in_event} should be called to set the new value.
# The parameter event is the associated {Wx::Event}.
#
# Should
#
# return true if any changes in value should be reported.
#
# - If property uses choice control, and displays a dialog on some choice items, then it is preferred to display that dialog in IntToValue instead of OnEvent.
# @param propgrid [Wx::PG::PropertyGrid]
# @param wnd_primary [Wx::Window]
# @param event [Wx::Event]
# @return [Boolean]
def on_event(propgrid, wnd_primary, event) end
# Reimplement this member function to add special handling for attributes of this property.
# Return false to have the attribute automatically stored in m_attributes. Default implementation simply does that and nothing else.
#
# To actually set property attribute values from the application, use {Wx::PG::PGProperty#set_attribute} instead.
# @param name [String]
# @param value [Wx::Variant]
# @return [Boolean]
def do_set_attribute(name, value) end
# Returns size of the custom painted image in front of property.
# This method must be overridden to return non-default value if OnCustomPaint is to be called.
#
# - Default behaviour is to return {size(0,0)}, which means no image.
# - Default image width or height is indicated with dimension -1.
# - You can also return {Wx::PG::PG_DEFAULT_IMAGE_SIZE} which equals {Wx::DEFAULT_SIZE}.
# @param item [Integer] Normally -1, but can be an index to the property's list of items.
# @return [Wx::Size]
def on_measure_image(item) end
# Override to paint an image in front of the property value text or drop-down list item (but only if {Wx::PG::PGProperty#on_measure_image} is overridden as well).
# If property's {Wx::PG::SystemColourProperty#on_measure_image} returns size that has height != 0 but less than row height ( < 0 has special meanings), {Wx::PG::PropertyGrid} calls this method to draw a custom image in a limited area in front of the editor control or value text/graphics, and if control has drop-down list, then the image is drawn there as well (even in the case {Wx::PG::SystemColourProperty#on_measure_image} returned higher height than row height).
# NOTE: Following applies when {Wx::PG::SystemColourProperty#on_measure_image} returns a "flexible" height ( using wxPG_FLEXIBLE_SIZE(W,H)
macro), which implies variable height items: If (rect.x+rect.width) is < 0, then this is a measure item call, which means that dc is invalid and only thing that should be done is to set paintdata.m_drawnHeight to the height of the image of item at index paintdata.m_choiceItem. This call may be done even as often as once every drop-down popup show.
#
# - You can actually exceed rect width, but if you do so then paintdata.m_drawnWidth must be set to the full width drawn in pixels.
# - Due to technical reasons, rect's height will be default even if custom height was reported during measure call.
# - Brush is guaranteed to be default background colour. It has been already used to clear the background of area being painted. It can be modified.
# - Pen is guaranteed to be 1-wide 'black' (or whatever is the proper colour) pen for drawing framing rectangle. It can be changed as well.
# @see Wx::PG::SystemColourProperty#value_to_string
# @param dc [Wx::DC] {Wx::DC} to paint on.
# @param rect [Wx::Rect] Box reserved for custom graphics. Includes surrounding rectangle, if any. If x+width is < 0, then this is a measure item call (see above).
# @param paintdata [Wx::PG::PGPaintData] {Wx::PG::PGPaintData} structure with much useful data about painted item.
# @return [void]
def on_custom_paint(dc, rect, paintdata) end
# @param variant [Wx::Variant]
# @return [Boolean]
def query_colour_from_user(variant) end
# Default is to use {Wx::SystemSettings.get_colour(index)}.
# Override to use custom colour tables etc.
# @param index [Integer]
# @return [Wx::Colour]
def get_colour(index) end
alias_method :colour, :get_colour
# @param pVariant [Wx::Variant]
# @return [Wx::PG::ColourPropertyValue]
def get_val(pVariant=nil) end
alias_method :val, :get_val
# @param type [Integer]
# @param colour [Wx::Colour,String,Symbol]
# @return [void]
def init(type, colour) end
# @param colour [Wx::Colour,String,Symbol]
# @return [Integer]
def col_to_ind(colour) end
#
# @return [Wx::Variant]
def value_; end
#
# @param val [nil,String,Integer,Float,Time,Wx::Font,Wx::Colour,Wx::Variant,Array,Array,ObjectWx::PG::ColourPropertyValue]
# @return [void]
def value_=(val); end
protected
# @param v [Wx::PG::ColourPropertyValue]
# @return [Wx::Variant]
def do_translate_val(v) end
end # SystemColourProperty
# Allows to select a colour from the list or with colour dialog.
# Value used is of {Wx::PG::ColourPropertyValue} type.
# Supported special attributes: {Wx::PG::PG_COLOUR_ALLOW_CUSTOM}, {Wx::PG::PG_COLOUR_HAS_ALPHA}
#
class ColourProperty < SystemColourProperty
# @param label [String]
# @param name [String]
# @param value [Wx::Colour,String,Symbol]
# @return [Wx::PG::ColourProperty]
def initialize(label=Wx::PG::PG_LABEL, name=Wx::PG::PG_LABEL, value=Wx::WHITE) end
# Converts property value into a text representation.
# Default implementation calls {Wx::PG::ColourProperty#generate_composed_value}.
# @param value [Wx::Variant] Value to be converted.
# @param argFlags [Integer] If 0 (default value), then displayed string is returned. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_FULL_VALUE} is set, returns complete, storable string value instead of displayable. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_EDITABLE_VALUE} is set, returns string value that must be editable in textctrl. If {Wx::PG::PG_MISC_ARG_FLAGS::PG_COMPOSITE_FRAGMENT} is set, returns text that is appropriate to display as a part of string property's composite text representation.
# @return [String]
def value_to_string(value, argFlags=0) end
# Default is to use {Wx::SystemSettings.get_colour(index)}.
# Override to use custom colour tables etc.
# @param index [Integer]
# @return [Wx::Colour]
def get_colour(index) end
alias_method :colour, :get_colour
#
# @return [Wx::Variant]
def value_; end
#
# @param val [nil,String,Integer,Float,Time,Wx::Font,Wx::Colour,Wx::Variant,Array,Array,ObjectWx::PG::ColourPropertyValue]
# @return [void]
def value_=(val); end
protected
# @param v [Wx::PG::ColourPropertyValue]
# @return [Wx::Variant]
def do_translate_val(v) end
end # ColourProperty
# Because text, background and other colours tend to differ between platforms, {Wx::PG::SystemColourProperty} must be able to select between system colour and, when necessary, to pick a custom one.
# {Wx::PG::SystemColourProperty} value makes this possible.
#
#
# @note This class is untracked and should not be derived from nor instances extended!
class ColourPropertyValue < Object
# An integer value relating to the colour, and which exact meaning depends on the property with which it is used.
# For {Wx::PG::SystemColourProperty}:
# Any of {Wx::SYS_COLOUR_XXX}, or any web-colour ( use {Wx::PG_TO_WEB_COLOUR} macro - (currently unsupported) ), or {Wx::PG::PG_COLOUR_CUSTOM}.
# For custom colour properties without values array specified:
# index or {Wx::PG::PG_COLOUR_CUSTOM}
# For custom colour properties with values array specified:
# m_arrValues[index] or {Wx::PG::PG_COLOUR_CUSTOM}
#
# @return [Integer]
def type_; end
# An integer value relating to the colour, and which exact meaning depends on the property with which it is used.
# For {Wx::PG::SystemColourProperty}:
# Any of {Wx::SYS_COLOUR_XXX}, or any web-colour ( use {Wx::PG_TO_WEB_COLOUR} macro - (currently unsupported) ), or {Wx::PG::PG_COLOUR_CUSTOM}.
# For custom colour properties without values array specified:
# index or {Wx::PG::PG_COLOUR_CUSTOM}
# For custom colour properties with values array specified:
# m_arrValues[index] or {Wx::PG::PG_COLOUR_CUSTOM}
#
# @param val [Integer]
# @return [void]
def type_=(val); end
# Resulting colour.
# Should be correct regardless of type.
#
# @return [Wx::Colour]
def colour_; end
# Resulting colour.
# Should be correct regardless of type.
#
# @param val [Wx::Colour]
# @return [void]
def colour_=(val); end
# @overload initialize()
# @return [Wx::PG::ColourPropertyValue]
# @overload initialize(v)
# @param v [Wx::PG::ColourPropertyValue]
# @return [Wx::PG::ColourPropertyValue]
# @overload initialize(colour)
# @param colour [Wx::Colour,String,Symbol]
# @return [Wx::PG::ColourPropertyValue]
# @overload initialize(type)
# @param type [Integer]
# @return [Wx::PG::ColourPropertyValue]
# @overload initialize(type, colour)
# @param type [Integer]
# @param colour [Wx::Colour,String,Symbol]
# @return [Wx::PG::ColourPropertyValue]
def initialize(*args) end
# @param type [Integer]
# @param colour [Wx::Colour,String,Symbol]
# @return [void]
def init(type, colour) end
end # ColourPropertyValue
end