1a3e0fd82Sopenharmony_ci/* 2a3e0fd82Sopenharmony_ci * Copyright (c) 2022 Huawei Device Co., Ltd. 3a3e0fd82Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License"); 4a3e0fd82Sopenharmony_ci * you may not use this file except in compliance with the License. 5a3e0fd82Sopenharmony_ci * You may obtain a copy of the License at 6a3e0fd82Sopenharmony_ci * 7a3e0fd82Sopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0 8a3e0fd82Sopenharmony_ci * 9a3e0fd82Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software 10a3e0fd82Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS, 11a3e0fd82Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12a3e0fd82Sopenharmony_ci * See the License for the specific language governing permissions and 13a3e0fd82Sopenharmony_ci * limitations under the License. 14a3e0fd82Sopenharmony_ci */ 15a3e0fd82Sopenharmony_ci 16a3e0fd82Sopenharmony_ci/** 17a3e0fd82Sopenharmony_ci* @file render_buffer.h 18a3e0fd82Sopenharmony_ci* @brief Defines Renderer buffer 19a3e0fd82Sopenharmony_ci* @since 1.0 20a3e0fd82Sopenharmony_ci* @version 1.0. 21a3e0fd82Sopenharmony_ci*/ 22a3e0fd82Sopenharmony_ci 23a3e0fd82Sopenharmony_ci#ifndef GRAPHIC_LITE_RENDER_BUFFER_H 24a3e0fd82Sopenharmony_ci#define GRAPHIC_LITE_RENDER_BUFFER_H 25a3e0fd82Sopenharmony_ci 26a3e0fd82Sopenharmony_ci#include <cstring> 27a3e0fd82Sopenharmony_ci 28a3e0fd82Sopenharmony_ci#include "gfx_utils/diagram/vertexprimitive/geometry_plaindata_array.h" 29a3e0fd82Sopenharmony_ci 30a3e0fd82Sopenharmony_cinamespace OHOS { 31a3e0fd82Sopenharmony_ci/** 32a3e0fd82Sopenharmony_ci * Row accessor. 33a3e0fd82Sopenharmony_ci */ 34a3e0fd82Sopenharmony_ciclass RenderBuffer { 35a3e0fd82Sopenharmony_cipublic: 36a3e0fd82Sopenharmony_ci RenderBuffer() : renBuf_(0), start_(0), width_(0), height_(0), bufStride_(0) {} 37a3e0fd82Sopenharmony_ci 38a3e0fd82Sopenharmony_ci /** 39a3e0fd82Sopenharmony_ci * @brief RowAccessor Row accessor. 40a3e0fd82Sopenharmony_ci * @param renBuf buffer. 41a3e0fd82Sopenharmony_ci * @param areaWidth The width of the pixel area in the buffer. 42a3e0fd82Sopenharmony_ci * @param areaHeight The height of the pixel area in the buffer. 43a3e0fd82Sopenharmony_ci * @param stride Buffer stride. 44a3e0fd82Sopenharmony_ci */ 45a3e0fd82Sopenharmony_ci RenderBuffer(uint8_t* renBuf, uint32_t areaWidth, uint32_t areaHeight, int32_t stride) 46a3e0fd82Sopenharmony_ci : renBuf_(0), 47a3e0fd82Sopenharmony_ci start_(0), 48a3e0fd82Sopenharmony_ci width_(0), 49a3e0fd82Sopenharmony_ci height_(0), 50a3e0fd82Sopenharmony_ci bufStride_(0) 51a3e0fd82Sopenharmony_ci { 52a3e0fd82Sopenharmony_ci Attach(renBuf, areaWidth, areaHeight, stride); 53a3e0fd82Sopenharmony_ci } 54a3e0fd82Sopenharmony_ci 55a3e0fd82Sopenharmony_ci /** 56a3e0fd82Sopenharmony_ci * @brief attach Incoming parameters. 57a3e0fd82Sopenharmony_ci * @param renBuf buffer 58a3e0fd82Sopenharmony_ci * @param areaWidth The width of the pixel area in the buffer. 59a3e0fd82Sopenharmony_ci * @param areaHeightThe height of the pixel area in the buffer. 60a3e0fd82Sopenharmony_ci * @param stride Buffer stride. 61a3e0fd82Sopenharmony_ci */ 62a3e0fd82Sopenharmony_ci void Attach(uint8_t* renBuf, uint32_t areaWidth, uint32_t areaHeight, int32_t stride) 63a3e0fd82Sopenharmony_ci { 64a3e0fd82Sopenharmony_ci renBuf_ = renBuf; 65a3e0fd82Sopenharmony_ci start_ = renBuf; 66a3e0fd82Sopenharmony_ci width_ = areaWidth; 67a3e0fd82Sopenharmony_ci height_ = areaHeight; 68a3e0fd82Sopenharmony_ci bufStride_ = stride; 69a3e0fd82Sopenharmony_ci if (stride < 0) { 70a3e0fd82Sopenharmony_ci start_ = renBuf - static_cast<int32_t>(areaHeight - 1) * stride; 71a3e0fd82Sopenharmony_ci } 72a3e0fd82Sopenharmony_ci } 73a3e0fd82Sopenharmony_ci 74a3e0fd82Sopenharmony_ci /** 75a3e0fd82Sopenharmony_ci * @brief GetBuf Gets a pointer to the render buffer. 76a3e0fd82Sopenharmony_ci */ 77a3e0fd82Sopenharmony_ci const uint8_t* GetBuf() const 78a3e0fd82Sopenharmony_ci { 79a3e0fd82Sopenharmony_ci return renBuf_; 80a3e0fd82Sopenharmony_ci } 81a3e0fd82Sopenharmony_ci 82a3e0fd82Sopenharmony_ci /** 83a3e0fd82Sopenharmony_ci * @brief GetBuf Get area width. 84a3e0fd82Sopenharmony_ci */ 85a3e0fd82Sopenharmony_ci uint32_t GetWidth() const 86a3e0fd82Sopenharmony_ci { 87a3e0fd82Sopenharmony_ci return width_; 88a3e0fd82Sopenharmony_ci } 89a3e0fd82Sopenharmony_ci 90a3e0fd82Sopenharmony_ci /** 91a3e0fd82Sopenharmony_ci * @brief GetBuf GetBuf Get area height. 92a3e0fd82Sopenharmony_ci */ 93a3e0fd82Sopenharmony_ci uint32_t GetHeight() const 94a3e0fd82Sopenharmony_ci { 95a3e0fd82Sopenharmony_ci return height_; 96a3e0fd82Sopenharmony_ci } 97a3e0fd82Sopenharmony_ci 98a3e0fd82Sopenharmony_ci int32_t GetStride() const 99a3e0fd82Sopenharmony_ci { 100a3e0fd82Sopenharmony_ci return bufStride_; 101a3e0fd82Sopenharmony_ci } 102a3e0fd82Sopenharmony_ci 103a3e0fd82Sopenharmony_ci /** 104a3e0fd82Sopenharmony_ci * @brief GetRowPtr Returns a pointer to the beginning of line y. 105a3e0fd82Sopenharmony_ci */ 106a3e0fd82Sopenharmony_ci uint8_t* GetRowPtr(int32_t y) 107a3e0fd82Sopenharmony_ci { 108a3e0fd82Sopenharmony_ci return start_ + y * bufStride_; 109a3e0fd82Sopenharmony_ci } 110a3e0fd82Sopenharmony_ci 111a3e0fd82Sopenharmony_ci /** 112a3e0fd82Sopenharmony_ci * @brief GetRowPtr Returns a pointer to the beginning of line y。 113a3e0fd82Sopenharmony_ci */ 114a3e0fd82Sopenharmony_ci const uint8_t* GetRowPtr(int32_t y) const 115a3e0fd82Sopenharmony_ci { 116a3e0fd82Sopenharmony_ci return start_ + y * bufStride_; 117a3e0fd82Sopenharmony_ci } 118a3e0fd82Sopenharmony_ci 119a3e0fd82Sopenharmony_ci /** 120a3e0fd82Sopenharmony_ci * @brief GetRow Get row data 121a3e0fd82Sopenharmony_ci */ 122a3e0fd82Sopenharmony_ci RowData GetRow(int32_t y) const 123a3e0fd82Sopenharmony_ci { 124a3e0fd82Sopenharmony_ci return RowData(0, width_ - 1, GetRowPtr(y)); 125a3e0fd82Sopenharmony_ci } 126a3e0fd82Sopenharmony_ci 127a3e0fd82Sopenharmony_ciprivate: 128a3e0fd82Sopenharmony_ci uint8_t* renBuf_; // Pointer to render buffer. 129a3e0fd82Sopenharmony_ci uint8_t* start_; // Point to the first pixel according to the stride. 130a3e0fd82Sopenharmony_ci uint32_t width_; // Area width. 131a3e0fd82Sopenharmony_ci uint32_t height_; // Area height. 132a3e0fd82Sopenharmony_ci int32_t bufStride_; // Number of bytes per line. 133a3e0fd82Sopenharmony_ci}; 134a3e0fd82Sopenharmony_ci} // namespace OHOS 135a3e0fd82Sopenharmony_ci#endif 136