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的数量。

  1. attendees的数量作为存储的计算字段添加
  2. 然后添加相关视图
openacademy/models.py
    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:
openacademy/views/openacademy.xml
            </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"
posted @ 2018-06-23 09:06  LeeeetMe  阅读(1608)  评论(0编辑  收藏  举报