Fixed OOK clk setting

This commit is contained in:
furrtek 2016-08-06 12:55:39 +02:00
parent 38e506a108
commit e686c7437e
3 changed files with 58 additions and 44 deletions

View File

@ -50,15 +50,15 @@ void EncodersView::generate_frame() {
debug_text.clear();
i = 0;
for (auto c : encoder_def->word_def) {
if (c < 'S')
debug_text += encoder_def->bit_format.at(bitfield.value(i));
else if (c == 'S')
for (auto c : encoder_def->word_format) {
if (c == 'S')
debug_text += encoder_def->sync;
else
debug_text += encoder_def->bit_format.at(bitfield.value(i));
i++;
}
//if (visible()) parent()->set_dirty(); // Might be called before on_show ?
draw_waveform();
}
void EncodersView::draw_waveform() {
@ -77,7 +77,9 @@ void EncodersView::draw_waveform() {
else
y = 0;
// Edge
if (prev_y != y) painter_->draw_rectangle( { (Coord)x, 160, 1, 24 }, Color::yellow() );
// Level
painter_->draw_rectangle( { (Coord)x, 160 + y, ceil(x_inc), 1 }, Color::yellow() );
prev_y = y;
@ -87,6 +89,7 @@ void EncodersView::draw_waveform() {
void EncodersView::paint(Painter& painter) {
painter_ = &painter;
draw_waveform();
}
void EncodersView::update_progress() {
@ -215,7 +218,7 @@ void EncodersView::start_tx(const bool scan) {
// 2280000/2 = 1140000Hz = 0,877192982us
// numberfield_clk.value() / encoder_def->clk_per_symbol
// 455000 / 12 = 37917Hz = 26,37339452us
1140000 / ((numberfield_clk.value() * 1000) / encoder_def->clk_per_symbol),
228000 / ((numberfield_clk.value() * 1000) / encoder_def->clk_per_symbol),
encoder_def->repeat_min,
encoder_def->pause_symbols
);

View File

@ -28,7 +28,7 @@
namespace ui {
#define ENC_TYPES_COUNT 13
#define ENC_TYPES_COUNT 14
class EncodersView : public View {
public:
@ -50,7 +50,6 @@ private:
uint16_t clk_per_symbol; // Oscillator periods per bit fragment
std::vector<std::string> bit_format;
uint8_t word_length; // Total # of bits
std::string word_def;
std::string word_format;
std::string sync; // Like bit_format
uint32_t default_frequency; // Default encoder clk frequency
@ -59,15 +58,27 @@ private:
};
// S = Sync
// 0~9 A~R = Address/data bits
// A/D = Address/data bits
const encoder_def_t encoder_defs[ENC_TYPES_COUNT] = {
// PT2260
// PT2260-R2
{
"xx2260",
"2260-R2",
3, 2,
1024, 128,
{ "10001000", "11101110", "10001110" },
12, "0123456789ABS", "AAAAAAAAAADD",
12, "AAAAAAAAAADDS",
"10000000000000000000000000000000",
200000, 1,
10 // ?
},
// PT2260-R4
{
"2260-R4",
3, 2,
1024, 128,
{ "10001000", "11101110", "10001110" },
12, "AAAAAAAADDDDS",
"10000000000000000000000000000000",
200000, 1,
10 // ?
@ -75,35 +86,35 @@ private:
// PT2262
{
"xx2262",
"2262 ",
3, 2,
32, 4,
1024, 128,
{ "10001000", "11101110", "10001110" },
12, "0123456789ABS", "AAAAAADDDDDD",
12, "AAAAAAAAAAAAS",
"10000000000000000000000000000000",
30000, 4,
200000, 1,
10 // ?
},
// 16bit?
// 16-bit ?
{
"16bit?",
"16-bit ",
2, 2,
32, 8,
{ "1110", "1000" }, // Opposite ?
16, "0123456789ABCDEFS", "AAAAAAAAAAAAAAAA",
"10000000000000000000000000000000",
114000, 50,
10 // ?
16, "AAAAAAAAAAAAAAAAS",
"100000000000000000000",
25000, 50,
0 // ?
},
// RT1527
{
"xx1527",
"1527 ",
2, 2,
128, 32,
{ "1000", "1110" },
12, "0123456789ABS", "AAAAAAAADD",
24, "SAAAAAAAAAAAAAAAAAAAADDDD",
"10000000000000000000000000000000",
100000, 4,
10 // ?
@ -111,11 +122,11 @@ private:
// HK526E
{
"xx526 ",
"526 ",
2, 2,
24, 8,
{ "110", "100" },
12, "0123456789AB", "AAAAAAAADDDD",
12, "AAAAAAAAAAAA",
"",
20000, 4,
10 // ?
@ -123,11 +134,11 @@ private:
// HT12E
{
"xx12E ",
"12E ",
2, 2,
3, 1,
{ "011", "001" },
12, "S0123456789AB", "AAAAAAAADDDD",
12, "SAAAAAAAADDDD",
"0000000000000000000000000000000000001",
3000, 4,
10 // ?
@ -135,11 +146,11 @@ private:
// VD5026 13 bits ?
{
"xx5026",
"5026 ",
4, 4,
128, 8,
{ "1000000010000000", "1111111011111110", "1111111010000000", "1000000011111110" },
12, "S0123456789AB", "AAAAAAAADDDD",
12, "SAAAAAAAAAAAA",
"000000000000000000000000000000000000000000000001", // ?
100000, 4,
10 // ?
@ -151,7 +162,7 @@ private:
2, 2,
96, 32,
{ "011", "001" },
12, "S0123456789AB", "AAAAAAAAAAAA",
12, "SAAAAAAAAAAAA",
"1",
100000, 4,
10 // ?
@ -163,7 +174,7 @@ private:
3, 2,
96, 16,
{ "011011", "001001", "011001" },
18, "S0123456789ABCDEFGH", "AAAAAAAAAADDDDDDDD",
18, "SAAAAAAAAAADDDDDDDD",
"1",
160000, 4,
10 // ?
@ -175,7 +186,7 @@ private:
2, 2,
3072, 768,
{ "1000", "1110" },
9, "S012345678", "DDAAAAAAA",
9, "SDDAAAAAAA",
"",
455000, 4,
10 // ?
@ -187,19 +198,19 @@ private:
3, 2,
16, 1,
{ "0111111101111111", "0100000001000000", "0111111101000000" },
9, "S012345678", "AAAAADDDD",
9, "SAAAAADDDD",
"000000000000000000",
455000, 2,
10 // ?
},
// HT6xxx
// HT6*** TODO: Add individual variations
{
"HT6xxx",
"HT6*** ",
3, 2,
198, 33,
{ "011011", "001001", "001011" },
18, "S0123456789ABCDEFGH", "AAAAAAAAAAAADDDDDD",
18, "SAAAAAAAAAAAADDDDDD",
"0000000000000000000000000000000000001011001011001",
100000, 3,
10 // ?
@ -211,7 +222,7 @@ private:
2, 2,
48, 12,
{ "1000", "1110", },
12, "0123456789AB", "DDDDDDDDDDDD",
12, "AAAAAAAAAAAA",
"",
455000, 3,
10 // ?
@ -278,7 +289,7 @@ private:
};
OptionsField options_enctype {
{ 2 * 8, 5 * 8 },
6,
7,
{
}
};

Binary file not shown.