/* * image_file_handle.cpp - Image file handle * * Copyright (c) 2016 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 * Author: Yinhang Liu */ #include "image_file_handle.h" namespace XCam { ImageFileHandle::ImageFileHandle () { } ImageFileHandle::ImageFileHandle (const char *name, const char *option) : FileHandle (name, option) { } ImageFileHandle::~ImageFileHandle () { close (); } XCamReturn ImageFileHandle::read_buf (const SmartPtr &buf) { const VideoBufferInfo info = buf->get_video_info (); VideoBufferPlanarInfo planar; uint8_t *memory = NULL; XCamReturn ret = XCAM_RETURN_NO_ERROR; XCAM_ASSERT (is_valid ()); memory = buf->map (); for (uint32_t index = 0; index < info.components; index++) { info.get_planar_info (planar, index); uint32_t line_bytes = planar.width * planar.pixel_bytes; for (uint32_t i = 0; i < planar.height; i++) { if (fread (memory + info.offsets [index] + i * info.strides [index], 1, line_bytes, _fp) != line_bytes) { if (end_of_file ()) ret = XCAM_RETURN_BYPASS; else { XCAM_LOG_ERROR ("read file failed, size doesn't match"); ret = XCAM_RETURN_ERROR_FILE; } } } } buf->unmap (); return ret; } XCamReturn ImageFileHandle::write_buf (const SmartPtr &buf) { const VideoBufferInfo info = buf->get_video_info (); VideoBufferPlanarInfo planar; uint8_t *memory = NULL; XCamReturn ret = XCAM_RETURN_NO_ERROR; XCAM_ASSERT (is_valid ()); memory = buf->map (); for (uint32_t index = 0; index < info.components; index++) { info.get_planar_info (planar, index); uint32_t line_bytes = planar.width * planar.pixel_bytes; for (uint32_t i = 0; i < planar.height; i++) { if (fwrite (memory + info.offsets [index] + i * info.strides [index], 1, line_bytes, _fp) != line_bytes) { XCAM_LOG_ERROR ("write file failed, size doesn't match"); ret = XCAM_RETURN_ERROR_FILE; } } } buf->unmap (); return ret; } }