-
Data Grid
- Overview
-
Data Binding
-
Paging and Scrolling
-
Editing
-
Grouping
-
Filtering and Sorting
- Focused Row
-
Row Drag & Drop
-
Selection
-
Columns
- State Persistence
-
Appearance
-
Templates
-
Data Summaries
-
Master-Detail
-
Export to PDF
-
Export to Excel
-
Adaptability
- Keyboard Navigation
-
Pivot Grid
- Overview
-
Data Binding
-
Field Chooser
-
Features
-
Export to Excel
-
Tree List
- Overview
-
Data Binding
- Sorting
- Paging
-
Editing
- Node Drag & Drop
- Focused Row
-
Selection
-
Filtering
-
Column Customization
- State Persistence
- Adaptability
- Keyboard Navigation
-
Scheduler
- Overview
-
Data Binding
-
Views
-
Features
- Virtual Scrolling
-
Grouping
-
Customization
- Adaptability
-
Html Editor
-
Chat
-
Diagram
- Overview
-
Data Binding
-
Featured Shapes
-
Custom Shapes
-
Document Capabilities
-
User Interaction
- UI Customization
- Adaptability
-
Charts
- Overview
-
Data Binding
-
Area Charts
-
Bar Charts
- Bullet Charts
-
Doughnut Charts
-
Financial Charts
-
Line Charts
-
Pie Charts
-
Point Charts
-
Polar and Radar Charts
-
Range Charts
-
Sparkline Charts
-
Tree Map
-
Funnel and Pyramid Charts
- Sankey Chart
-
Combinations
-
More Features
-
Export
-
Selection
-
Tooltips
-
Zooming
-
-
Gantt
- Overview
-
Data
-
UI Customization
- Strip Lines
- Export to PDF
- Sorting
-
Filtering
-
Gauges
- Overview
-
Data Binding
-
Bar Gauge
-
Circular Gauge
-
Linear Gauge
-
Navigation
- Overview
- Accordion
-
Menu
- Multi View
-
Drawer
-
Tab Panel
-
Tabs
-
Toolbar
- Pagination
-
Tree View
- Right-to-Left Support
-
Layout
-
Editors
- Overview
- Autocomplete
-
Calendar
- Check Box
- Color Box
-
Date Box
-
Date Range Box
-
Drop Down Box
-
Number Box
-
Select Box
- Switch
-
Tag Box
- Text Area
- Text Box
- Validation
- Custom Text Editor Buttons
- Right-to-Left Support
- Editor Appearance Variants
-
Forms and Multi-Purpose
- Overview
- Button Group
- Field Set
-
Filter Builder
-
Form
- Radio Group
-
Range Selector
- Numeric Scale (Lightweight)
- Numeric Scale
- Date-Time Scale (Lightweight)
- Date-Time Scale
- Logarithmic Scale
- Discrete scale
- Custom Formatting
- Use Range Selection for Calculation
- Use Range Selection for Filtering
- Image on Background
- Chart on Background
- Customized Chart on Background
- Chart on Background with Series Template
- Range Slider
- Slider
-
Sortable
-
File Management
-
File Manager
- Overview
-
File System Types
-
Customization
-
File Uploader
-
-
Actions and Lists
- Overview
-
Action Sheet
-
Button
- Floating Action Button
- Drop Down Button
-
Context Menu
-
List
-
Lookup
-
Maps
- Overview
-
Map
-
Vector Map
-
Dialogs and Notifications
-
Localization
JavaScript/jQuery Charts - Colorization
This demo shows options that you can use to colorize TreeMap tiles. To see each option, use the drop-down editor below the component.
If you have technical questions, please create a support ticket in the DevExpress Support Center.
$(() => {
const colorizationOptions = [{
name: 'Discrete',
options: {
type: 'discrete',
palette: 'harmony light',
colorizeGroups: false,
},
}, {
name: 'Grouped',
options: {
type: 'discrete',
palette: 'harmony light',
colorizeGroups: true,
},
}, {
name: 'Range',
options: {
type: 'range',
palette: ['#fbd600', '#78299a'],
range: [0, 50000, 100000, 150000, 200000, 250000],
colorCodeField: 'salesAmount',
colorizeGroups: false,
},
}, {
name: 'Gradient',
options: {
type: 'gradient',
palette: ['#fbd600', '#78299a'],
range: [10000, 250000],
colorCodeField: 'salesAmount',
colorizeGroups: false,
},
}];
const startColorization = colorizationOptions[2];
const treeMap = $('#treemap').dxTreeMap({
dataSource: salesAmount,
title: 'Sales Amount by Product',
valueField: 'salesAmount',
tooltip: {
enabled: true,
format: 'currency',
customizeTooltip(arg) {
const { data } = arg.node;
return {
text: arg.node.isLeaf() ? (`<span class='product'>${data.name
}</span><br/>Sales Amount: ${arg.valueText}`) : null,
};
},
},
colorizer: startColorization.options,
}).dxTreeMap('instance');
$('#colorization').dxSelectBox({
items: colorizationOptions,
width: 200,
inputAttr: { 'aria-label': 'Colorization Option' },
value: startColorization,
displayExpr: 'name',
onValueChanged(data) {
treeMap.option('colorizer', data.value.options);
},
});
});
xxxxxxxxxx
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml" lang="en">
<head>↔</head>
<body class="dx-viewport">
<div class="demo-container">
<div id="treemap"></div>
<div class="options">
<div class="caption">Options</div>
<div class="option">
<span>Colorization Type</span>
<div id="colorization" class="selectbox"></div>
</div>
</div>
</div>
</body>
</html>
xxxxxxxxxx
.product {
font-weight: 500;
}
.options {
padding: 20px;
background-color: rgba(191, 191, 191, 0.15);
margin-top: 20px;
}
.option {
margin-top: 10px;
}
.caption {
font-size: 18px;
font-weight: 500;
}
.option > span {
margin-right: 10px;
}
.option > .dx-widget {
display: inline-block;
vertical-align: middle;
}
xxxxxxxxxx
const salesAmount = [{
name: 'Monitors',
items: [{
name: 'DesktopLCD 19',
salesAmount: 23420,
}, {
name: 'DesktopLCD 21',
salesAmount: 113900,
}, {
name: 'DesktopLED 19',
salesAmount: 49170,
}, {
name: 'DesktopLED 21',
salesAmount: 81200,
}],
}, {
name: 'Projectors',
items: [{
name: 'Projector Plus',
salesAmount: 99000,
}, {
name: 'Projector PlusHD',
salesAmount: 152250,
}],
}, {
name: 'Televisions',
items: [{
name: 'SuperLCD 55',
salesAmount: 147150,
}, {
name: 'SuperLCD 42',
salesAmount: 103200,
}, {
name: 'SuperLCD 70',
salesAmount: 56000,
}, {
name: 'SuperLED 42',
salesAmount: 159500,
}, {
name: 'SuperLED 50',
salesAmount: 233600,
}, {
name: 'SuperPlasma 50',
salesAmount: 184800,
}, {
name: 'SuperPlasma 65',
salesAmount: 178500,
}],
}, {
name: 'Video Players',
items: [{
name: 'HD Video Player',
salesAmount: 63690,
}, {
name: 'SuperHD Video Player',
salesAmount: 74000,
}],
}];
To colorize the TreeMap tiles, you can use the colorizer object. This object allows you to specify the colorization type:
-
"discrete" (default)
This colorization algorithm paints each tile within a group in a color from the palette. When there are multiple groups, the way in which groups are colorized depends on the colorizeGroups property setting:-
If colorizeGroups is set to
false
(Discrete mode in the demo):
Each group is painted independently - regardless of the colors used in other groups. -
If colorizeGroups is set to
true
(Grouped mode in the demo):
Each group is painted with a different color from the palette.
-
-
"gradient"
If you choose this algorithm, the palette should contain only two colors that the component uses to colorize the smallest and the largest tile, respectively. The other tiles will have a tint of either the first or the second color depending on their size. In order to use the "gradient" algorithm, you need to set the range property to an array of only two values. -
"range"
This algorithm is similar to "gradient", but the array assigned to the range property should contain more than two values. This array specifies the ranges between each value. The palette of two colors will generate multiple tints - one for each range.
If you use the "gradient" or "range" colorization algorithm, the color of the tile depends on the value. Normally, the value field supplies this value to the component. However, you can use the colorCodeField property to assign another field to supply the value.