1a3e0fd82Sopenharmony_ci/* 2a3e0fd82Sopenharmony_ci * Copyright (c) 2020-2021 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 * @addtogroup UI_Components 18a3e0fd82Sopenharmony_ci * @{ 19a3e0fd82Sopenharmony_ci * 20a3e0fd82Sopenharmony_ci * @brief Defines UI components such as buttons, texts, images, lists, and progress bars. 21a3e0fd82Sopenharmony_ci * 22a3e0fd82Sopenharmony_ci * @since 1.0 23a3e0fd82Sopenharmony_ci * @version 1.0 24a3e0fd82Sopenharmony_ci */ 25a3e0fd82Sopenharmony_ci 26a3e0fd82Sopenharmony_ci/** 27a3e0fd82Sopenharmony_ci * @file ui_qrcode.h 28a3e0fd82Sopenharmony_ci * 29a3e0fd82Sopenharmony_ci * @brief Declares the attributes and functions of the <b>UIQrcode</b> class. 30a3e0fd82Sopenharmony_ci * 31a3e0fd82Sopenharmony_ci * @since 3.0 32a3e0fd82Sopenharmony_ci * @version 5.0 33a3e0fd82Sopenharmony_ci */ 34a3e0fd82Sopenharmony_ci 35a3e0fd82Sopenharmony_ci#ifndef GRAPHIC_LITE_UI_QRCODE_H 36a3e0fd82Sopenharmony_ci#define GRAPHIC_LITE_UI_QRCODE_H 37a3e0fd82Sopenharmony_ci 38a3e0fd82Sopenharmony_ci#include "components/ui_image_view.h" 39a3e0fd82Sopenharmony_ci 40a3e0fd82Sopenharmony_cinamespace qrcodegen { 41a3e0fd82Sopenharmony_ciclass QrCode; 42a3e0fd82Sopenharmony_ci} 43a3e0fd82Sopenharmony_ci 44a3e0fd82Sopenharmony_cinamespace OHOS { 45a3e0fd82Sopenharmony_ci/** 46a3e0fd82Sopenharmony_ci * @brief Provides functions related to quick response (QR) codes. 47a3e0fd82Sopenharmony_ci * 48a3e0fd82Sopenharmony_ci * @since 3.0 49a3e0fd82Sopenharmony_ci * @version 5.0 50a3e0fd82Sopenharmony_ci */ 51a3e0fd82Sopenharmony_ciclass UIQrcode : public UIImageView { 52a3e0fd82Sopenharmony_cipublic: 53a3e0fd82Sopenharmony_ci /** 54a3e0fd82Sopenharmony_ci * @brief A default constructor used to create a <b>UIQrcode</b> instance. 55a3e0fd82Sopenharmony_ci * 56a3e0fd82Sopenharmony_ci * @since 3.0 57a3e0fd82Sopenharmony_ci * @version 5.0 58a3e0fd82Sopenharmony_ci */ 59a3e0fd82Sopenharmony_ci UIQrcode(); 60a3e0fd82Sopenharmony_ci 61a3e0fd82Sopenharmony_ci /** 62a3e0fd82Sopenharmony_ci * @brief A destructor used to delete the <b>UIQrcode</b> instance. 63a3e0fd82Sopenharmony_ci * 64a3e0fd82Sopenharmony_ci * @since 3.0 65a3e0fd82Sopenharmony_ci * @version 5.0 66a3e0fd82Sopenharmony_ci */ 67a3e0fd82Sopenharmony_ci virtual ~UIQrcode(); 68a3e0fd82Sopenharmony_ci 69a3e0fd82Sopenharmony_ci /** 70a3e0fd82Sopenharmony_ci * @brief Sets the QR code information. 71a3e0fd82Sopenharmony_ci * 72a3e0fd82Sopenharmony_ci * @param val Indicates the pointer to the content used to generate the QR code. 73a3e0fd82Sopenharmony_ci * @param backgroundColor Indicates the background color of the QR code. It is white by default. 74a3e0fd82Sopenharmony_ci * @param qrColor Indicates the QR code color. It is black by default. 75a3e0fd82Sopenharmony_ci * @since 3.0 76a3e0fd82Sopenharmony_ci * @version 5.0 77a3e0fd82Sopenharmony_ci */ 78a3e0fd82Sopenharmony_ci void SetQrcodeInfo(const char* val, ColorType backgroundColor = Color::White(), ColorType qrColor = Color::Black()); 79a3e0fd82Sopenharmony_ci 80a3e0fd82Sopenharmony_ci /** 81a3e0fd82Sopenharmony_ci * @brief Obtains the view type. 82a3e0fd82Sopenharmony_ci * 83a3e0fd82Sopenharmony_ci * @return Returns the view type. For details, see {@link UIViewType}. 84a3e0fd82Sopenharmony_ci * @since 1.0 85a3e0fd82Sopenharmony_ci * @version 1.0 86a3e0fd82Sopenharmony_ci */ 87a3e0fd82Sopenharmony_ci UIViewType GetViewType() const override 88a3e0fd82Sopenharmony_ci { 89a3e0fd82Sopenharmony_ci return UI_QRCODE; 90a3e0fd82Sopenharmony_ci } 91a3e0fd82Sopenharmony_ci 92a3e0fd82Sopenharmony_ci /** 93a3e0fd82Sopenharmony_ci * @brief Sets the QR code width. 94a3e0fd82Sopenharmony_ci * 95a3e0fd82Sopenharmony_ci * @param width Indicates the width to set. 96a3e0fd82Sopenharmony_ci * @since 1.0 97a3e0fd82Sopenharmony_ci * @version 1.0 98a3e0fd82Sopenharmony_ci */ 99a3e0fd82Sopenharmony_ci void SetWidth(int16_t width) override; 100a3e0fd82Sopenharmony_ci 101a3e0fd82Sopenharmony_ci /** 102a3e0fd82Sopenharmony_ci * @brief Sets the QR code height. 103a3e0fd82Sopenharmony_ci * 104a3e0fd82Sopenharmony_ci * @param height Indicates the height to set. 105a3e0fd82Sopenharmony_ci * @since 1.0 106a3e0fd82Sopenharmony_ci * @version 1.0 107a3e0fd82Sopenharmony_ci */ 108a3e0fd82Sopenharmony_ci void SetHeight(int16_t height) override; 109a3e0fd82Sopenharmony_ci 110a3e0fd82Sopenharmony_ciprivate: 111a3e0fd82Sopenharmony_ci void ReMeasure() override; 112a3e0fd82Sopenharmony_ci void RefreshQrcode(); 113a3e0fd82Sopenharmony_ci void SetImageInfo(qrcodegen::QrCode& qrcode); 114a3e0fd82Sopenharmony_ci void GenerateQrCode(qrcodegen::QrCode& qrcode); 115a3e0fd82Sopenharmony_ci void FillQrCodeColor(qrcodegen::QrCode& qrcode); 116a3e0fd82Sopenharmony_ci void FillQrCodeBackgroundColor(); 117a3e0fd82Sopenharmony_ci void SetQrcodeVal(const char* val, uint32_t length); 118a3e0fd82Sopenharmony_ci void GetDestData(uint8_t* destData, int32_t outFilePixelPrescaler); 119a3e0fd82Sopenharmony_ci 120a3e0fd82Sopenharmony_ci static constexpr uint8_t QRCODE_FACTOR_NUM = 4; 121a3e0fd82Sopenharmony_ci ImageInfo imageInfo_; 122a3e0fd82Sopenharmony_ci int16_t width_; 123a3e0fd82Sopenharmony_ci bool needDraw_; 124a3e0fd82Sopenharmony_ci ColorType backgroundColor_; 125a3e0fd82Sopenharmony_ci ColorType qrColor_; 126a3e0fd82Sopenharmony_ci char* qrcodeVal_; 127a3e0fd82Sopenharmony_ci}; 128a3e0fd82Sopenharmony_ci} // namespace OHOS 129a3e0fd82Sopenharmony_ci#endif // GRAPHIC_LITE_UI_QRCODE_H 130