blob: def19ccb42a2fb42f599e57327145334b8d9b3fe (
plain)
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
|
/* SPDX-License-Identifier: BSD-2-Clause */
/*
* Copyright (C) 2019, Raspberry Pi Ltd
*
* black_level.cpp - black level control algorithm
*/
#include <math.h>
#include <stdint.h>
#include <libcamera/base/log.h>
#include "../black_level_status.h"
#include "black_level.h"
using namespace RPiController;
using namespace libcamera;
LOG_DEFINE_CATEGORY(RPiBlackLevel)
#define NAME "rpi.black_level"
BlackLevel::BlackLevel(Controller *controller)
: Algorithm(controller)
{
}
char const *BlackLevel::name() const
{
return NAME;
}
void BlackLevel::read(boost::property_tree::ptree const ¶ms)
{
uint16_t blackLevel = params.get<uint16_t>(
"black_level", 4096); /* 64 in 10 bits scaled to 16 bits */
blackLevelR_ = params.get<uint16_t>("black_level_r", blackLevel);
blackLevelG_ = params.get<uint16_t>("black_level_g", blackLevel);
blackLevelB_ = params.get<uint16_t>("black_level_b", blackLevel);
LOG(RPiBlackLevel, Debug)
<< " Read black levels red " << blackLevelR_
<< " green " << blackLevelG_
<< " blue " << blackLevelB_;
}
void BlackLevel::prepare(Metadata *imageMetadata)
{
/*
* Possibly we should think about doing this in a switchMode or
* something?
*/
struct BlackLevelStatus status;
status.blackLevelR = blackLevelR_;
status.blackLevelG = blackLevelG_;
status.blackLevelB = blackLevelB_;
imageMetadata->set("black_level.status", status);
}
/* Register algorithm with the system. */
static Algorithm *create(Controller *controller)
{
return new BlackLevel(controller);
}
static RegisterAlgorithm reg(NAME, &create);
|