/*
|
* Copyright (c) 2019 Rockchip Corporation
|
*
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
* you may not use this file except in compliance with the License.
|
* You may obtain a copy of the License at
|
*
|
* http://www.apache.org/licenses/LICENSE-2.0
|
*
|
* Unless required by applicable law or agreed to in writing, software
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
* See the License for the specific language governing permissions and
|
* limitations under the License.
|
*
|
*/
|
|
#include "sample_comm.h"
|
|
#define LIMIT_VALUE(value,max_value,min_value) (value > max_value? max_value : value < min_value ? min_value : value)
|
|
|
static void sample_agamma_usage()
|
{
|
printf("Usage : \n");
|
printf("\t 0) AGAMMA: test rk_aiq_user_api2_agamma_SetAttrib stManual Sync.\n");
|
printf("\t 1) AGAMMA: test rk_aiq_user_api2_agamma_SetAttrib stManual Async.\n");
|
printf("\t 2) AGAMMA: test rk_aiq_user_api2_agamma_SetAttrib stFast Sync.\n");
|
printf("\t 3) AGAMMA: test rk_aiq_user_api2_agamma_SetAttrib stFast Async.\n");
|
printf("\t 4) AGAMMA: test rk_aiq_user_api2_agamma_GetAttrib.\n");
|
printf("\t 5) AGAMMA: test rk_aiq_uapi2_setGammaCoef.\n");
|
printf("\t q) AGAMMA: return to main sample screen.\n");
|
|
printf("\n");
|
printf("\t please press the key: ");
|
|
return;
|
}
|
|
void sample_print_agamma_info(const void *arg)
|
{
|
printf ("enter AGAMMA modult test!\n");
|
}
|
|
XCamReturn sample_agamma_module(const void *arg)
|
{
|
int key = -1;
|
CLEAR();
|
|
rk_aiq_gamma_attr_t attr;
|
const demo_context_t *demo_ctx = (demo_context_t *)arg;
|
const rk_aiq_sys_ctx_t* ctx ;
|
if (demo_ctx->camGroup) {
|
ctx = (rk_aiq_sys_ctx_t*)(demo_ctx->camgroup_ctx);
|
} else {
|
ctx = (rk_aiq_sys_ctx_t*)(demo_ctx->aiq_ctx);
|
}
|
|
do {
|
sample_agamma_usage ();
|
|
key = getchar ();
|
while (key == '\n' || key == '\r')
|
key = getchar();
|
printf ("\n");
|
|
|
switch (key)
|
{
|
case '0': {
|
printf("\t AGAMMA test rk_aiq_user_api2_agamma_SetAttrib stManual Sync\n\n");
|
attr.sync.sync_mode = RK_AIQ_UAPI_MODE_DEFAULT;
|
attr.sync.done = false;
|
attr.atrrV30.mode = RK_AIQ_GAMMA_MODE_MANUAL;
|
attr.atrrV30.stManual.Gamma_en = true;
|
attr.atrrV30.stManual.Gamma_out_offset = 0;
|
float X_isp30[CALIBDB_AGAMMA_KNOTS_NUM_V30] = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 10, 12, 14, 16, 20, 24, 28, 32, 40, 48, 56,
|
64, 80, 96, 112, 128, 160, 192, 224, 256, 320, 384, 448, 512, 640, 768, 896, 1024,
|
1280, 1536, 1792, 2048, 2304, 2560, 2816, 3072, 3328, 3584, 3840, 4095
|
};
|
float Y_isp30[CALIBDB_AGAMMA_KNOTS_NUM_V30];
|
for(int i = 0; i < CALIBDB_AGAMMA_KNOTS_NUM_V30; i++) {
|
Y_isp30[i] = 4095 * pow(X_isp30[i] / 4095, 1 / 1 + 0.0);
|
Y_isp30[i] = LIMIT_VALUE(Y_isp30[i], 4095, 0);
|
attr.atrrV30.stManual.Gamma_curve[i] = (int)(Y_isp30[i] + 0.5);
|
}
|
rk_aiq_user_api2_agamma_SetAttrib(ctx, attr);
|
break;
|
}
|
case '1': {
|
printf("\t AGAMMA test rk_aiq_user_api2_agamma_SetAttrib stManual Async\n\n");
|
attr.sync.sync_mode = RK_AIQ_UAPI_MODE_ASYNC;
|
attr.sync.done = false;
|
attr.atrrV30.mode = RK_AIQ_GAMMA_MODE_MANUAL;
|
attr.atrrV30.stManual.Gamma_en = true;
|
attr.atrrV30.stManual.Gamma_out_offset = 1024;
|
float X_isp30[CALIBDB_AGAMMA_KNOTS_NUM_V30] = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 10, 12, 14, 16, 20, 24, 28, 32, 40, 48, 56,
|
64, 80, 96, 112, 128, 160, 192, 224, 256, 320, 384, 448, 512, 640, 768, 896, 1024,
|
1280, 1536, 1792, 2048, 2304, 2560, 2816, 3072, 3328, 3584, 3840, 4095
|
};
|
float Y_isp30[CALIBDB_AGAMMA_KNOTS_NUM_V30];
|
for(int i = 0; i < CALIBDB_AGAMMA_KNOTS_NUM_V30; i++) {
|
Y_isp30[i] = 4095 * pow(X_isp30[i] / 4095, 1 / 2.2 + 0.0);
|
Y_isp30[i] = LIMIT_VALUE(Y_isp30[i], 4095, 0);
|
attr.atrrV30.stManual.Gamma_curve[i] = (int)(Y_isp30[i] + 0.5);
|
}
|
rk_aiq_user_api2_agamma_SetAttrib(ctx, attr);
|
break;
|
}
|
case '2': {
|
printf("\t AGAMMA test rk_aiq_user_api2_agamma_SetAttrib stFast Sync\n\n");
|
attr.sync.sync_mode = RK_AIQ_UAPI_MODE_DEFAULT;
|
attr.sync.done = false;
|
attr.atrrV30.mode = RK_AIQ_GAMMA_MODE_FAST;
|
attr.atrrV30.stFast.en = true;
|
attr.atrrV30.stFast.GammaCoef = 3;
|
attr.atrrV30.stFast.SlopeAtZero = 0.0;
|
rk_aiq_user_api2_agamma_SetAttrib(ctx, attr);
|
break;
|
}
|
case '3': {
|
printf("\t AGAMMA test rk_aiq_user_api2_agamma_SetAttrib stFast Async\n\n");
|
attr.sync.sync_mode = RK_AIQ_UAPI_MODE_ASYNC;
|
attr.sync.done = false;
|
attr.atrrV30.mode = RK_AIQ_GAMMA_MODE_FAST;
|
attr.atrrV30.stFast.en = true;
|
attr.atrrV30.stFast.GammaCoef = 4;
|
attr.atrrV30.stFast.SlopeAtZero = 0.0;
|
rk_aiq_user_api2_agamma_SetAttrib(ctx, attr);
|
break;
|
}
|
case '4': {
|
printf("\t AGAMMA test rk_aiq_user_api2_agamma_GetAttrib\n\n");
|
rk_aiq_user_api2_agamma_GetAttrib(ctx, &attr);
|
printf("\t sync = %d, done = %d\n", attr.sync.sync_mode, attr.sync.done);
|
printf("\t attr.mode:%d stManual.Gamma_en:%d stManual.Gamma_out_offset:%d\n\n", attr.atrrV30.mode, attr.atrrV30.stManual.Gamma_en, attr.atrrV30.stManual.Gamma_out_offset);
|
printf("\t stManual.Gamma_curve:%d %d %d %d %d %d\n\n", attr.atrrV30.stManual.Gamma_curve[0], attr.atrrV30.stManual.Gamma_curve[1],
|
attr.atrrV30.stManual.Gamma_curve[2], attr.atrrV30.stManual.Gamma_curve[3], attr.atrrV30.stManual.Gamma_curve[4], attr.atrrV30.stManual.Gamma_curve[5]);
|
printf("\t stFast.en:%d stFast.GammaCoef:%f stFast.SlopeAtZero:%f\n\n", attr.atrrV30.stFast.en, attr.atrrV30.stFast.GammaCoef, attr.atrrV30.stFast.SlopeAtZero);
|
break;
|
}
|
case '5': {
|
printf("\t AGAMMA test rk_aiq_uapi2_setGammaCoef\n\n");
|
rk_aiq_uapi2_setGammaCoef(ctx, 5, 0);
|
break;
|
}
|
default:
|
break;
|
}
|
} while (key != 'q' && key != 'Q');
|
|
return XCAM_RETURN_NO_ERROR;
|
}
|