File: Zoom.hpp

package info (click to toggle)
vite 1.4-5
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 19,112 kB
  • sloc: cpp: 30,167; makefile: 467; sh: 233; python: 140; ansic: 67
file content (82 lines) | stat: -rw-r--r-- 2,054 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
/**
 *
 * @file plugins/MatrixVisualizer/Common/Zoom.hpp
 *
 * @copyright 2008-2024 Bordeaux INP, CNRS (LaBRI UMR 5800), Inria,
 *                      Univ. Bordeaux. All rights reserved.
 *
 * @author Hamza Benmendil
 * @author Johnny Jazeix
 * @author Camille Ordronneau
 *
 * @date 2024-07-17
 */
#ifndef ZOOM_HPP
#define ZOOM_HPP

#include <QOpenGLFunctions>

#include "../Formats/SymbolMatrix.hpp"

/**
 * \class Zoom
 * \brief This is an abstract class, it contains the attributes and functions that all the sub-classes need
 *
 */
class Zoom
{
public:
    /**
     * \brief The size of the color matrix
     *
     */
    static const int DEFAULT_LEVEL = 1024;

public:
    /**
     * \fn Zoom(symbol_matrix_t* matrix)
     * \brief Construct a zoom object
     * \param matrix The matrix where the zoom is applied
     */
    Zoom(symbol_matrix_t *matrix);

    /**
     * \fn virtual ~Zoom()
     * \brief Destroy the Zoom object
     */
    virtual ~Zoom();

    /**
     * \fn GLfloat getColor(int x, int y) const
     * \brief Get the Color in x an y coordinates
     * \param x first coordinate
     * \param y second coordinate
     * \return A color of type GLfloat
     */
    GLfloat getColor(int x, int y) const;

    /**
     * \fn virtual void move(double x_start, double x_end, double y_start, double y_end) = 0
     * \brief A virtual function, it is the function that is called when the zoom is applied
     * \param x_start The start of x coordinate of the selected zone
     * \param x_end The end of x coordinate of the selected zone
     * \param y_start The start of y coordinate of the selected zone
     * \param y_end The end of y coordinate of the selected zone
     */
    virtual void move(double x_start, double x_end, double y_start, double y_end) = 0;

protected:
    /**
     * \brief A pointer to the matrix to display
     *
     */
    symbol_matrix_t *m_matrix;

    /**
     * \brief The color matrix that is painted on the display
     *
     */
    GLfloat m_colors[DEFAULT_LEVEL][DEFAULT_LEVEL];
};

#endif