summaryrefslogtreecommitdiffstats
path: root/src/hid_core/irsensor/processor_base.cpp
blob: 91a513a701eb9c429bb11a4264867e4aceda8ef0 (plain) (blame)
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
// SPDX-FileCopyrightText: Copyright 2022 yuzu Emulator Project
// SPDX-License-Identifier: GPL-3.0-or-later

#include "hid_core/irsensor/processor_base.h"

namespace Service::IRS {

ProcessorBase::ProcessorBase() {}
ProcessorBase::~ProcessorBase() = default;

bool ProcessorBase::IsProcessorActive() const {
    return is_active;
}

std::size_t ProcessorBase::GetDataSize(Core::IrSensor::ImageTransferProcessorFormat format) const {
    switch (format) {
    case Core::IrSensor::ImageTransferProcessorFormat::Size320x240:
        return 320 * 240;
    case Core::IrSensor::ImageTransferProcessorFormat::Size160x120:
        return 160 * 120;
    case Core::IrSensor::ImageTransferProcessorFormat::Size80x60:
        return 80 * 60;
    case Core::IrSensor::ImageTransferProcessorFormat::Size40x30:
        return 40 * 30;
    case Core::IrSensor::ImageTransferProcessorFormat::Size20x15:
        return 20 * 15;
    default:
        return 0;
    }
}

std::size_t ProcessorBase::GetDataWidth(Core::IrSensor::ImageTransferProcessorFormat format) const {
    switch (format) {
    case Core::IrSensor::ImageTransferProcessorFormat::Size320x240:
        return 320;
    case Core::IrSensor::ImageTransferProcessorFormat::Size160x120:
        return 160;
    case Core::IrSensor::ImageTransferProcessorFormat::Size80x60:
        return 80;
    case Core::IrSensor::ImageTransferProcessorFormat::Size40x30:
        return 40;
    case Core::IrSensor::ImageTransferProcessorFormat::Size20x15:
        return 20;
    default:
        return 0;
    }
}

std::size_t ProcessorBase::GetDataHeight(
    Core::IrSensor::ImageTransferProcessorFormat format) const {
    switch (format) {
    case Core::IrSensor::ImageTransferProcessorFormat::Size320x240:
        return 240;
    case Core::IrSensor::ImageTransferProcessorFormat::Size160x120:
        return 120;
    case Core::IrSensor::ImageTransferProcessorFormat::Size80x60:
        return 60;
    case Core::IrSensor::ImageTransferProcessorFormat::Size40x30:
        return 30;
    case Core::IrSensor::ImageTransferProcessorFormat::Size20x15:
        return 15;
    default:
        return 0;
    }
}

} // namespace Service::IRS