2.6.3.2. Screen XML Descriptor
Now we will create a new screen to display a chart.
-  Select Generic UI in the project tree and click New → Screen in the context menu. After that, the template browser page will appear. 
-  Select Blank screen in the list of available templates and click Next. 
-  Enter the value column3d-chartin the Descriptor name field and click Next.
-  Open the Text tab and replace its content with the following code: 
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<window xmlns="http://schemas.haulmont.com/cuba/screen/window.xsd"
        caption="msg://caption"
        messagesPack="com.company.sampler.web"
        xmlns:chart="http://schemas.haulmont.com/charts/charts.xsd">
    <data>
        <collection id="countryGrowthDc"
                    class="com.company.sampler.entity.CountryGrowth"
                    view="_local"/>
    </data>
    <layout>
        <chart:serialChart id="chart"
                           angle="30"
                           categoryField="country"
                           dataContainer="countryGrowthDc"
                           depth3D="60"
                           height="100%"
                           plotAreaFillAlphas="0.1"
                           startDuration="1"
                           width="100%">
            <chart:categoryAxis gridPosition="START"/>
            <chart:valueAxes>
                <chart:axis position="LEFT"
                            stackType="BOX_3D"
                            title="GDP growth rate"
                            unit="%"/>
            </chart:valueAxes>
            <chart:graphs>
                <chart:graph id="graph2014"
                             balloonText="GDP grow in [[category]] (2014): <b>[[value]]</b>"
                             fillAlphas="0.9"
                             lineAlpha="0.2"
                             title="2014"
                             type="COLUMN"
                             valueField="year2014"/>
                <chart:graph id="graph2015"
                             balloonText="GDP grow in [[category]] (2015): <b>[[value]]</b>"
                             fillAlphas="09."
                             lineAlpha="0.2"
                             title="2015"
                             type="COLUMN"
                             valueField="year2015"/>
            </chart:graphs>
            <chart:export/>
        </chart:serialChart>
    </layout>
</window>The root element of the screen descriptor contains a new xmlns:chart attribute:
<window xmlns:chart="http://schemas.haulmont.com/charts/charts.xsd"
    ...
>The chart retrieves data from the countryGrowthDc data container defined in the dataContainer attribute. Names and values are displayed using the country, year2014 and year2015 attributes of the CountryGrowth entity; the list of instances for this entity is stored in the data container.
The chart:serialChart component contains the following attributes:
-  angle– defines the chart angle. May has a value from0to90.
-  balloonText– defines text for the tooltip that appears when hovering over a column. You can use the following tags:[[value]],[[title]],[[persents]],[[description]], as well as keys from theDataItemlisted in aDataProviderinstance, or names of the entity attributes from the data container. To usehtmltags you must escape them.
-  depth3D– chart thickness. When used in combination with theangleattribute, helps to create a 3D effect.
-  plotAreaFillAlphas– opacity of the plot area.
-  startDuration– duration of the animation, in seconds.
-  categoryField– a key from the set of pairs contained in theDataItemobjects listed in aDataProviderinstance; this key is used to determine the labels for the category axis.
The chart:serialChart component contains the following elements:
-  chart:categoryAxis– an element that describes the category axis.-  The gridPositionattribute specifies if a grid line is placed on the center of a cell or on the beginning of a cell.
 
-  
-  chart:valueAxes– an element that defines vertical value axes. In our case, only one vertical axis is used; the axis is described by thechart:axiselement.-  The positionattribute defines position of the value axis relative to the chart.
-  Setting stackTypetoBOX_3Dmakes the chart display columns one behind the other.
 
-  
-  chart:graphs– an element that contains the collection ofchart:graphelements; the graph is described by thechart:graphelement.-  The typeattribute defines the type of the graph and can be: line, column, step line, smoothed line, ohlc and candlestick.
-  The valueFieldattribute defines a key from the list of pairs contained in theDataItemobjects listed in aDataProviderinstance; this key is used to determine the value.
-  The fillAlphasattribute defines opacity of fill.
-  The lineAlphaattribute defines opacity of the line (or column border). Value range is 0 – 1.
 
-  
-  chart:export– an optional element that enables chart export.