odoo-图表透视图
图形视图
图形视图允许聚合的概述和模型的分析,它们的根元素是 <graph>
。
注
数据透视图(元素<pivot>)是一个多维表,它允许选择文件和维度来获得正确的聚合数据集,然后移动到更为图形化的概观。数据透视图共享与图视图相同的内容定义。
图形视图有4种显示模式,默认模式是使用@typ属性来选择的。
- 柱状图(默认的)
-
柱状图,第一维用于定义水平轴上的组,其他维度定义每个组内的聚合条。
默认情况下,柱状图是并排的,它们可以通过使用@stacked="True"在<graph>上进行堆叠
- 曲线图
- 二维线图
- 饼图
- 二维的饼图
图形视图包含具有强制@type属性的<field>值:
row
(默认的)- 默认情况下应聚合字段
measure
- 字段应该聚合而不是分组
<graph string="Total idea score by Inventor">
<field name="inventor_id"/>
<field name="score" type="measure"/>
</graph>
警告
图形视图对数据库值执行聚合,它们不与非存储的计算字段一起使用
练习
图形视图
在Session对象中添加一个图形视图,它显示每个course中在柱形图表单下attendees的数量。
- 将attendees的数量作为存储的计算字段添加
- 然后添加相关视图
openacademy/models.py
openacademy/views/openacademy.xml
hours = fields.Float(string="Duration in hours",
compute='_get_hours', inverse='_set_hours')
attendees_count = fields.Integer(
string="Attendees count", compute='_get_attendees_count', store=True)
@api.depends('seats', 'attendee_ids')
def _taken_seats(self):
for r in self:
for r in self:
r.duration = r.hours / 24
@api.depends('attendee_ids')
def _get_attendees_count(self):
for r in self:
r.attendees_count = len(r.attendee_ids)
@api.constrains('instructor_id', 'attendee_ids')
def _check_instructor_not_in_attendees(self):
for r in self:
</field>
</record>
<record model="ir.ui.view" id="openacademy_session_graph_view">
<field name="name">openacademy.session.graph</field>
<field name="model">openacademy.session</field>
<field name="arch" type="xml">
<graph string="Participations by Courses">
<field name="course_id"/>
<field name="attendees_count" type="measure"/>
</graph>
</field>
</record>
<record model="ir.actions.act_window" id="session_list_action">
<field name="name">Sessions</field>
<field name="res_model">openacademy.session</field>
<field name="view_type">form</field>
<field name="view_mode">tree,form,calendar,gantt,graph</field>
</record>
<menuitem id="session_menu" name="Sessions"