PICSimLab - Programmable IC Simulator Laboratory 0.9.2
PICSimLab - API
Loading...
Searching...
No Matches
virtual_VCD_Play.h
1/* ########################################################################
2
3 PICSimLab - Programmable IC Simulator Laboratory
4
5 ########################################################################
6
7 Copyright (c) : 2019-2024 Luis Claudio GambĂ´a Lopes <lcgamboa@yahoo.com>
8
9 This program is free software; you can redistribute it and/or modify
10 it under the terms of the GNU General Public License as published by
11 the Free Software Foundation; either version 2, or (at your option)
12 any later version.
13
14 This program is distributed in the hope that it will be useful,
15 but WITHOUT ANY WARRANTY; without even the implied warranty of
16 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 GNU General Public License for more details.
18
19 You should have received a copy of the GNU General Public License
20 along with this program; if not, write to the Free Software
21 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
22
23 For e-mail suggestions : lcgamboa@yahoo.com
24 ######################################################################## */
25
26#ifndef PART_VCD_Play_H
27#define PART_VCD_Play_H
28
29#include "../lib/part.h"
30
31#define PART_VCD_Play_Name "VCD Play"
32
33typedef struct {
34 unsigned long count;
35 unsigned char data;
36} vcd_reg_t;
37
38class cpart_VCD_Play : public part {
39public:
40 std::string GetAboutInfo(void) override { return "L.C. Gamboa \n <lcgamboa@yahoo.com>"; };
41 cpart_VCD_Play(const unsigned x, const unsigned y, const char* name, const char* type, board* pboard_,
42 const int id_);
43 ~cpart_VCD_Play(void);
44 void DrawOutput(const unsigned int index) override;
45 void PreProcess(void) override;
46 void Process(void) override;
47 void PostProcess(void) override;
48 void OnMouseButtonPress(unsigned int inputId, unsigned int button, unsigned int x, unsigned int y,
49 unsigned int state) override;
50 void ConfigurePropertiesWindow(void) override;
51 void filedialog_EvOnClose(int retId) override;
52 void ReadPropertiesWindow(void) override;
53 std::string WritePreferences(void) override;
54 void ReadPreferences(std::string value) override;
55 unsigned short GetInputId(char* name) override;
56 unsigned short GetOutputId(char* name) override;
57 int LoadVCD(std::string fname);
58
59private:
60 void RegisterRemoteControl(void) override;
61 unsigned char output_pins[8];
62 char f_vcd_name[200];
63 unsigned char play;
64 float timescale;
65 unsigned long vcd_count;
66 float vcd_inc;
67 float vcd_step;
68 vcd_reg_t* vcd_data;
69 int vcd_data_count;
70 int vcd_ptr;
71};
72
73#endif /* PART_VCD_Play_H */
Board class.
Definition board.h:111
Definition virtual_VCD_Play.h:38
void OnMouseButtonPress(unsigned int inputId, unsigned int button, unsigned int x, unsigned int y, unsigned int state) override
Event handler on the part.
Definition virtual_VCD_Play.cc:331
unsigned short GetOutputId(char *name) override
return the output ids numbers of names used in output map
Definition virtual_VCD_Play.cc:174
void PreProcess(void) override
Called every start of CPU process.
Definition virtual_VCD_Play.cc:275
void filedialog_EvOnClose(int retId) override
Used by properties window filedialogs.
Definition virtual_VCD_Play.cc:384
std::string WritePreferences(void) override
Called to save part preferences in configuration file.
Definition virtual_VCD_Play.cc:218
void ReadPreferences(std::string value) override
Called whe configuration file load preferences.
Definition virtual_VCD_Play.cc:226
void Process(void) override
Called every CPU step.
Definition virtual_VCD_Play.cc:279
void PostProcess(void) override
Called every end of CPU process.
Definition virtual_VCD_Play.cc:320
void RegisterRemoteControl(void) override
Register remote control variables.
Definition virtual_VCD_Play.cc:77
void ConfigurePropertiesWindow(void) override
Called to configure the properties window.
Definition virtual_VCD_Play.cc:253
void ReadPropertiesWindow(void) override
Called when properties window close.
Definition virtual_VCD_Play.cc:264
unsigned short GetInputId(char *name) override
return the input ids numbers of names used in input map
Definition virtual_VCD_Play.cc:162
std::string GetAboutInfo(void) override
Return the about information of part.
Definition virtual_VCD_Play.h:40
void DrawOutput(const unsigned int index) override
Called to draw every output.
Definition virtual_VCD_Play.cc:92
PART class.
Definition part.h:49
Definition virtual_VCD_Play.h:33