/* * scaler_service.cpp * * Copyright (c) 2021 Rockchip Electronics Co., Ltd. * * 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: Cody Xie */ #include "scaler_service.h" #include "image_processor.h" #include "dma_video_buffer.h" using namespace XCam; namespace RkCam { template To convert(From&); template <> img_buffer_t convert(std::shared_ptr& dma) { auto info = dma->get_video_info(); img_buffer_t buf = { .width = (int)info.width, .height = (int)info.height, .wstride = (int)info.aligned_width, .hstride = (int)info.aligned_height, }; buf.fd = dma->get_fd(); buf.format = static_cast(info.format); return buf; } ScalerTask::ScalerTask(std::unique_ptr proc) : proc_(std::move(proc)) {} TaskResult ScalerTask::operator()(ServiceParam& p) { auto full = p.payload->input_image; auto scales = p.payload->scaled_images; auto last = full; for (auto it = scales.begin(); it != scales.end(); it++) { img_buffer_t src = convert(last); img_buffer_t dst = convert(*it); proc_->resize(src, dst, 0, 0); last = *it; } return TaskResult::kSuccess; } }; // namespace RkCam