Difference between revisions of "Documentation/DevGuide/Forms/Form Controls accepting Value Bindings"
m |
|||
(3 intermediate revisions by one other user not shown) | |||
Line 6: | Line 6: | ||
|NextPage=Documentation/DevGuide/Forms/External List Sources | |NextPage=Documentation/DevGuide/Forms/External List Sources | ||
}} | }} | ||
− | {{DISPLAYTITLE:Form Controls accepting Value Bindings}} | + | {{Documentation/DevGuideLanguages|Documentation/DevGuide/Forms/{{SUBPAGENAME}}}} |
+ | {{DISPLAYTITLE:Form Controls accepting Value Bindings}} | ||
How do form controls and value bindings relate to each other? When looking at all the form control functionality that has so far been discussed, the following questions come need to be answered: | How do form controls and value bindings relate to each other? When looking at all the form control functionality that has so far been discussed, the following questions come need to be answered: | ||
Line 32: | Line 33: | ||
The following covers the last question from the above list: What is this good for? | The following covers the last question from the above list: What is this good for? | ||
− | {{ | + | {{AOo}} already contains two practical applications: |
''Spreadsheet cell bindings'' | ''Spreadsheet cell bindings'' | ||
− | :In a {{ | + | :In a {{AOo}} spreadsheet document, you always could insert form controls. Since version OpenOffice.org 2.0.0, you can, in their properties, bind form controls to arbitrary cells within the document. That is, every change made in this cell is propagated to the control, and vice versa. This is implemented using the value binding mechanism described in this chapter. See <idl>com.sun.star.table.CellValueBinding</idl> for more details. |
:The following piece of code creates a cell value binding in a spreadsheet document, for cell A1 on the first sheet, and knits it to a numeric control model: | :The following piece of code creates a cell value binding in a spreadsheet document, for cell A1 on the first sheet, and knits it to a numeric control model: | ||
− | + | <syntaxhighlight lang="java"> | |
// insert our sample control | // insert our sample control | ||
XPropertySet numericControl = m_formLayer.insertControlLine( "DatabaseFormattedField", | XPropertySet numericControl = m_formLayer.insertControlLine( "DatabaseFormattedField", | ||
Line 56: | Line 57: | ||
); | ); | ||
bindable.setValueBinding( cellBinding ); | bindable.setValueBinding( cellBinding ); | ||
− | + | </syntaxhighlight> | |
+ | |||
''XML form bindings'' | ''XML form bindings'' | ||
− | :{{ | + | :{{AOo}} features XML forms. These are form documents whose data model is a DOM tree. They are realized with the usual form controls and logical forms, and this time the controls are bound to DOM nodes using the value binding mechanism. |
{{PDL1}} | {{PDL1}} | ||
− | [[Category: Forms]] | + | |
+ | [[Category:Documentation/Developer's Guide/Forms]] |
Latest revision as of 15:49, 21 December 2020
How do form controls and value bindings relate to each other? When looking at all the form control functionality that has so far been discussed, the following questions come need to be answered:
- Which control types do support value bindings?
- For a given control type, which aspect actually is its value, which is exchanged with an external binding?
- How do external value bindings interact with data awareness, for example, controls that exchange their value with a database column?
- What can you do with all this?
The first two questions are easy: Every control that allows user input also supports value bindings. The data that the user entered (this may be, for instance, plain text, or an image, or a check state) is considered the value of the control, and thus exchanged with the external binding.
The basic service is the com.sun.star.form.binding.BindableControlModel, which specifies a control model supporting external value bindings. For a concrete control type, for instance, a check box, a service such as BindableCheckBox
would be expected, which specifies how a check box control model exchanges its value with an external binding.
However, all controls that potentially could support a binding also are data aware (see Data Aware Controls). Thus, the first step is to answer the third question from above. The service com.sun.star.form.binding.BindableDataAwareControlModel is about data aware control models with value binding capabilities. You are referred to the documentation of the BindableDataAwareControlModel service for all the details, but the two most interesting details are as follows:
Priority External value bindings overrule any active SQL-column binding. If an external component is bound to a control model that currently has an active SQL binding, this SQL binding is suspended until the external binding is revoked.
Immediacy When a BindableDataAwareControlModel is bound to an external value, then every change in the control model's value is immediately reflected in the external binding. This is a difference to SQL bindings of most DataAwareControlModels, where changes in the model's value are only propagated to the bound column upon explicit request via commit.
The illustration below shows the service hierarchy for control models that are also value components. It also shows how concrete control types fit in, for example by using check boxes.
The following covers the last question from the above list: What is this good for?
Apache OpenOffice already contains two practical applications:
Spreadsheet cell bindings
- In a Apache OpenOffice spreadsheet document, you always could insert form controls. Since version OpenOffice.org 2.0.0, you can, in their properties, bind form controls to arbitrary cells within the document. That is, every change made in this cell is propagated to the control, and vice versa. This is implemented using the value binding mechanism described in this chapter. See com.sun.star.table.CellValueBinding for more details.
- The following piece of code creates a cell value binding in a spreadsheet document, for cell A1 on the first sheet, and knits it to a numeric control model:
// insert our sample control
XPropertySet numericControl = m_formLayer.insertControlLine( "DatabaseFormattedField",
"enter a value", "", 10 );
// a value binding for cell A1 on the first
CellAddress address = new CellAddress( (short)0, (short)0, (short)0 );
Object[] initParam = new Object[] { new NamedValue( "BoundCell", address ) };
XValueBinding cellBinding = (XValueBinding)UnoRuntime.queryInterface(
XValueBinding.class,
m_document.createInstanceWithArguments(
"com.sun.star.table.CellValueBinding", initParam ) );
// bind it to the control model
XBindableValue bindable = (XBindableValue)UnoRuntime.queryInterface(
XBindableValue.class, numericControl
);
bindable.setValueBinding( cellBinding );
XML form bindings
- Apache OpenOffice features XML forms. These are form documents whose data model is a DOM tree. They are realized with the usual form controls and logical forms, and this time the controls are bound to DOM nodes using the value binding mechanism.
Content on this page is licensed under the Public Documentation License (PDL). |