/*
* blender.h - blender interface
*
* Copyright (c) 2017 Intel 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.
*
* Author: Wind Yuan <feng.yuan@intel.com>
*/
#include "blender.h"
namespace XCam {
Blender::Blender (uint32_t alignment_x, uint32_t alignment_y)
: _alignment_x (alignment_x)
, _alignment_y (alignment_y)
, _out_width (0)
, _out_height (0)
{
}
Blender::~Blender ()
{
}
void
Blender::set_output_size (uint32_t width, uint32_t height) {
_out_width = XCAM_ALIGN_UP (width, get_alignment_x ());
_out_height = XCAM_ALIGN_UP (height, get_alignment_y ());
}
bool
Blender::set_merge_window (const Rect &window) {
uint32_t alignmend_x = get_alignment_x ();
_merge_window = window;
_merge_window.pos_x = XCAM_ALIGN_AROUND (_merge_window.pos_x, alignmend_x);
_merge_window.width = XCAM_ALIGN_AROUND (_merge_window.width, alignmend_x);
XCAM_ASSERT (_merge_window.width >= (int32_t)alignmend_x);
XCAM_LOG_DEBUG(
"Blender merge window:(x:%d, width:%d), blend_width:%d",
_merge_window.pos_x, _merge_window.width, _out_width);
return true;
}
bool
Blender::set_input_valid_area (const Rect &area, uint32_t index)
{
XCAM_ASSERT (index < XCAM_BLENDER_IMAGE_NUM);
_input_valid_area[index] = area;
uint32_t alignmend_x = get_alignment_x ();
_input_valid_area[index].pos_x = XCAM_ALIGN_DOWN (_input_valid_area[index].pos_x, alignmend_x);
_input_valid_area[index].width = XCAM_ALIGN_UP (_input_valid_area[index].width, alignmend_x);
XCAM_LOG_DEBUG(
"Blender buf(%d) valid area:(x:%d, width:%d)",
index, _input_valid_area[index].pos_x, _input_valid_area[index].width);
return true;
}
bool
Blender::set_input_merge_area (const Rect &area, uint32_t index)
{
XCAM_ASSERT (index < XCAM_BLENDER_IMAGE_NUM);
if (!is_merge_window_set ()) {
XCAM_LOG_ERROR ("set_input_merge_area(idx:%d) failed, need set merge window first", index);
return false;
}
_input_merge_area[index] = area;
_input_merge_area[index].pos_x = XCAM_ALIGN_AROUND (_input_merge_area[index].pos_x, get_alignment_x ());
_input_merge_area[index].pos_y = XCAM_ALIGN_AROUND (_input_merge_area[index].pos_y, get_alignment_y ());
XCAM_LOG_DEBUG(
"Blender buf(%d) merge area:(x:%d, width:%d)",
index, _input_merge_area[index].pos_x, _input_merge_area[index].width);
return true;
}
bool
Blender::auto_calc_merge_window (
uint32_t width0, uint32_t width1, uint32_t blend_width,
Rect &out_window)
{
out_window.pos_x = blend_width - width1;
out_window.width = (width0 + width1 - blend_width) / 2;
out_window.pos_x = XCAM_ALIGN_AROUND (out_window.pos_x, get_alignment_x ());
out_window.width = XCAM_ALIGN_AROUND (out_window.width, get_alignment_x ());
if ((int)blend_width < out_window.pos_x + out_window.width)
out_window.width = blend_width - out_window.pos_x;
XCAM_ASSERT (out_window.width > 0 && out_window.width <= (int)blend_width);
XCAM_ASSERT (out_window.pos_x >= 0 && out_window.pos_x <= (int)blend_width);
return true;
}
XCamReturn
Blender::blend (
const SmartPtr<VideoBuffer> &,
const SmartPtr<VideoBuffer> &,
SmartPtr<VideoBuffer> &)
{
XCAM_LOG_ERROR ("Blender interface blend must be derived.");
return XCAM_RETURN_ERROR_UNKNOWN;
}
}