2017-06-06 17:53:23 -04:00
|
|
|
//
|
|
|
|
// Video.hpp
|
|
|
|
// Clock Signal
|
|
|
|
//
|
|
|
|
// Created by Thomas Harte on 06/06/2017.
|
2018-05-13 15:19:52 -04:00
|
|
|
// Copyright 2017 Thomas Harte. All rights reserved.
|
2017-06-06 17:53:23 -04:00
|
|
|
//
|
|
|
|
|
|
|
|
#ifndef Machines_ZX8081_Video_hpp
|
|
|
|
#define Machines_ZX8081_Video_hpp
|
|
|
|
|
|
|
|
#include "../../Outputs/CRT/CRT.hpp"
|
2017-07-25 20:20:55 -04:00
|
|
|
#include "../../ClockReceiver/ClockReceiver.hpp"
|
2017-06-06 17:53:23 -04:00
|
|
|
|
|
|
|
namespace ZX8081 {
|
|
|
|
|
2017-06-06 18:01:33 -04:00
|
|
|
/*!
|
|
|
|
Packages a ZX80/81-style video feed into a CRT-compatible waveform.
|
|
|
|
|
|
|
|
While sync is active, this feed will output the sync level.
|
|
|
|
|
|
|
|
While sync is inactive, this feed will output the white level unless it is supplied
|
|
|
|
with a byte to output. When a byte is supplied for output, it will be interpreted as
|
|
|
|
a 1-bit graphic and output over the next 4 cycles, picking between the white level
|
|
|
|
and the black level.
|
|
|
|
*/
|
2017-07-27 07:40:02 -04:00
|
|
|
class Video {
|
2017-06-06 17:53:23 -04:00
|
|
|
public:
|
2018-11-14 21:52:57 -05:00
|
|
|
/// Constructs an instance of the video feed.
|
|
|
|
Video();
|
2017-06-06 18:01:33 -04:00
|
|
|
|
2018-04-15 18:00:51 -04:00
|
|
|
/// Advances time by @c half-cycles.
|
2017-07-27 22:05:29 -04:00
|
|
|
void run_for(const HalfCycles);
|
2017-06-06 18:01:33 -04:00
|
|
|
/// Forces output to catch up to the current output position.
|
2017-06-06 17:53:23 -04:00
|
|
|
void flush();
|
|
|
|
|
2017-06-06 18:01:33 -04:00
|
|
|
/// Sets the current sync output.
|
2017-06-06 17:53:23 -04:00
|
|
|
void set_sync(bool sync);
|
2020-01-20 21:45:10 -05:00
|
|
|
|
2017-06-06 18:01:33 -04:00
|
|
|
/// Causes @c byte to be serialised into pixels and output over the next four cycles.
|
2017-06-06 17:53:23 -04:00
|
|
|
void output_byte(uint8_t byte);
|
|
|
|
|
2018-11-14 21:52:57 -05:00
|
|
|
/// Sets the scan target.
|
|
|
|
void set_scan_target(Outputs::Display::ScanTarget *scan_target);
|
|
|
|
|
2020-01-20 21:45:10 -05:00
|
|
|
/// Gets the current scan status.
|
2020-01-21 22:28:25 -05:00
|
|
|
Outputs::Display::ScanStatus get_scaled_scan_status() const;
|
2020-01-20 21:45:10 -05:00
|
|
|
|
2017-06-06 17:53:23 -04:00
|
|
|
private:
|
2017-11-09 22:14:22 -05:00
|
|
|
bool sync_ = false;
|
|
|
|
uint8_t *line_data_ = nullptr;
|
|
|
|
uint8_t *line_data_pointer_ = nullptr;
|
2018-06-02 18:25:00 -04:00
|
|
|
HalfCycles time_since_update_ = 0;
|
2018-11-14 21:52:57 -05:00
|
|
|
Outputs::CRT::CRT crt_;
|
2017-06-06 18:01:33 -04:00
|
|
|
|
|
|
|
void flush(bool next_sync);
|
2017-06-06 17:53:23 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* Video_hpp */
|