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