• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1# 拍照开发指导<a name="ZH-CN_TOPIC_0000001054915940"></a>
2
3-   [使用场景](#zh-cn_topic_0000001052170554_section1963312376119)
4-   [接口说明](#zh-cn_topic_0000001052170554_section56549532016)
5-   [约束与限制](#zh-cn_topic_0000001052170554_section1165911177314)
6-   [开发步骤](#zh-cn_topic_0000001052170554_section138543918214)
7
8## 使用场景<a name="zh-cn_topic_0000001052170554_section1963312376119"></a>
9
10使用Camera产生图片帧(拍照)。
11
12## 接口说明<a name="zh-cn_topic_0000001052170554_section56549532016"></a>
13
14**表 1**  API列表
15
16| 类名  | 接口名| 描述 |
17| --------- | ------------| -------- |
18| CameraKit | int32_t GetCameraIds(std::list\<string\> cameraList)  | 获取cameraId列表。 |
19| CameraKit | CameraAbility& GetCameraAbility(string cameraId)  | 获取指定camera的能力。 |
20| CameraKit | void RegisterCameraDeviceCallback(CameraDeviceCallback* callback, EventHandler* handler)  | 注册camera设备状态回调。 |
21| CameraKit | void UnregisterCameraDeviceCallback(CameraDeviceCallback* callback)  | 去注册camera设备状态回调。 |
22| CameraKit | void CreateCamera(string cameraId, CameraStateCallback* callback, EventHandler* handler)  | 创建camera实例。 |
23| Camera | string GetCameraId()  | 获取cameraID。 |
24| Camera | CameraConfig& GetCameraConfig()  | 获取camera配置信息。 |
25| Camera | FrameConfig& GetFrameConfig(int32_t type)  | 获取捕获帧类型。 |
26| Camera | void Configure(CameraConfig& config)  | 配置camera。 |
27| Camera | void Release()  | 释放camera。 |
28| Camera | int TriggerLoopingCapture(FrameConfig& frameConfig)  | 开始循环帧捕获。 |
29| Camera | void StopLoopingCapture()  | 停止循环帧捕获。 |
30| Camera | int32_t TriggerSingleCapture(FrameConfig& frameConfig)  | 抓图。 |
31| CameraConfig | void SetFrameStateCallback(FrameStateCallback* callback, EventHandler* handler)  | 设置帧状态回调。 |
32| CameraConfig | static CameraConfig* CreateCameraConfig()  | 创建camera配置信息实例。 |
33| CameraAbility | std::list\<Size\> GetSupportedSizes(int format)  | 根据类型获取支持输出图像尺寸大小。 |
34| CameraAbility | std::list\<T\> GetParameterRange(uint32_t key)  | 获取支持的参数范围。 |
35| CameraDevice | CameraDeviceCallback()  | camera设备回调类构造函数。 |
36| CameraDevice | void OnCameraStatus​(std::string cameraId, int32_t status)  | camera设备状态变化时的回调。 |
37| CameraStateCallback | CameraStateCallback​()  | camera状态回调类构造函数。 |
38| CameraStateCallback | void OnConfigured​(Camera& camera)  | camera配置成功回调。 |
39| CameraStateCallback | void OnConfigureFailed​(Camera& camera,int32_t errorCode)  | camera配置失败回调。 |
40| CameraStateCallback | void OnCreated​(Camera& camera)  | camera创建成功回调。 |
41| CameraStateCallback | void OnCreateFailed​(std::string cameraId,int32_t errorCode)  | camera创建失败回调。 |
42| CameraStateCallback | void OnReleased​(Camera& camera)  | camera释放回调。 |
43| FrameStateCallback | FrameStateCallback​()  | 帧状态回调类构造函数。 |
44| FrameStateCallback | void OnFrameFinished(Camera& camera, FrameConfig& frameConfig, FrameResult& frameResult)  | 拍照帧完成回调。 |
45| FrameStateCallback | void OnFrameError​(Camera& camera, FrameConfig& frameConfig, int32_t errorCode, FrameResult& frameResult)  | 拍照帧异常回调。 |
46| FrameConfig | int32_t GetFrameConfigType()  | 获取帧配置类型。 |
47| FrameConfig | std::list<OHOS::Surface> GetSurfaces()  | 获取帧配置的surface。 |
48| FrameConfig | void AddSurface(OHOS::AGP::UISurface& surface)  | 添加surface。 |
49| FrameConfig | void RemoveSurface(OHOS::AGP::UISurface& surface)  | 删除surface。 |
50
51## 约束与限制<a name="zh-cn_topic_0000001052170554_section1165911177314"></a>
52
53无。
54
55## 开发步骤<a name="zh-cn_topic_0000001052170554_section138543918214"></a>
56
571.  <a name="zh-cn_topic_0000001052170554_li378084192111"></a>实现设备状态回调的派生类,用户在设备状态发生变更(如新插入相机设备/相机掉线)时,自定义操作。
58
59    ```
60    class SampleCameraDeviceCallback : public CameraDeviceCallback {
61        void OnCameraStatus(std::string cameraId, int32_t status) override
62        {
63            //do something when camera is available/unavailable.
64        }
65    };
66    ```
67
682.  <a name="zh-cn_topic_0000001052170554_li8716104682913"></a>实现帧事件回调的派生类,这里在拿到帧数据以后将其转存为文件。
69
70    ```
71    static void SampleSaveCapture(const char *p, uint32_t size)
72    {
73        cout << "Start saving picture" << endl;
74        struct timeval tv;
75        gettimeofday(&tv, NULL);
76        struct tm *ltm = localtime(&tv.tv_sec);
77        if (ltm != nullptr) {
78            ostringstream ss("Capture_");
79            ss << "Capture" << ltm->tm_hour << "-" << ltm->tm_min << "-" << ltm->tm_sec << ".jpg";
80
81            ofstream pic("/sdcard/" + ss.str(), ofstream::out | ofstream::trunc);
82            cout << "write " << size << " bytes" << endl;
83            pic.write(p, size);
84            cout << "Saving picture end" << endl;
85        }
86    }
87
88    class TestFrameStateCallback : public FrameStateCallback {
89        void OnFrameFinished(Camera &camera, FrameConfig &fc, FrameResult &result) override
90        {
91            cout << "Receive frame complete inform." << endl;
92            if (fc.GetFrameConfigType() == FRAME_CONFIG_CAPTURE) {
93                cout << "Capture frame received." << endl;
94                list<Surface *> surfaceList = fc.GetSurfaces();
95                for (Surface *surface : surfaceList) {
96                    SurfaceBuffer *buffer = surface->AcquireBuffer();
97                    if (buffer != nullptr) {
98                        char *virtAddr = static_cast<char *>(buffer->GetVirAddr());
99                        if (virtAddr != nullptr) {
100                            SampleSaveCapture(virtAddr, buffer->GetSize());
101                        }
102                        surface->ReleaseBuffer(buffer);
103                    }
104                    delete surface;
105                }
106                delete &fc;
107            }
108        }
109    };
110    ```
111
1123.  <a name="zh-cn_topic_0000001052170554_li6671035102514"></a>实现相机状态回调的派生类,自定义相机状态发生变化(配置成功/失败,创建成功/失败\)时的操作。
113
114    ```
115    class SampleCameraStateMng : public CameraStateCallback {
116    public:
117        SampleCameraStateMng() = delete;
118        SampleCameraStateMng(EventHandler &eventHdlr) : eventHdlr_(eventHdlr) {}
119        ~SampleCameraStateMng()
120        {
121            if (recordFd_ != -1) {
122                close(recordFd_);
123            }
124        }
125        void OnCreated(Camera &c) override
126        {
127            cout << "Sample recv OnCreate camera." << endl;
128            auto config = CameraConfig::CreateCameraConfig();
129            config->SetFrameStateCallback(&fsCb_, &eventHdlr_);
130            c.Configure(*config);
131            cam_ = &c;
132        }
133        void OnCreateFailed(const std::string cameraId, int32_t errorCode) override {}
134        void OnReleased(Camera &c) override {}
135    };
136    ```
137
1384.  创建CameraKit,用于创建和获取camera信息。
139
140    ```
141    CameraKit *camKit = CameraKit::GetInstance();
142    list<string> camList = camKit->GetCameraIds();
143    string camId;
144    for (auto &cam : camList) {
145        cout << "camera name:" << cam << endl;
146        const CameraAbility *ability = camKit->GetCameraAbility(cam);
147        /* find camera which fits user's ability */
148        list<CameraPicSize> sizeList = ability->GetSupportedSizes(0);
149        if (find(sizeList.begin(), sizeList.end(), CAM_PIC_1080P) != sizeList.end()) {
150            camId = cam;
151            break;
152        }
153    }
154    ```
155
1565.  创建Camera实例。
157
158    ```
159    EventHandler eventHdlr; // Create a thread to handle callback events.
160    SampleCameraStateMng CamStateMng(eventHdlr);
161
162    camKit->CreateCamera(camId, CamStateMng, eventHdlr);
163    ```
164
1656.  根据[步骤1](#zh-cn_topic_0000001052170554_li378084192111)、[步骤2](#zh-cn_topic_0000001052170554_li8716104682913)、[步骤3](#zh-cn_topic_0000001052170554_li6671035102514)中的回调设计,同步等待 OnCreated 回调拿到 cam\_ 之后,进行相关操作。
166
167    ```
168    void OnCreated(Camera &c) override
169    {
170        cout << "Sample recv OnCreate camera." << endl;
171        auto config = CameraConfig::CreateCameraConfig();
172        config->SetFrameStateCallback(&fsCb_, &eventHdlr_);
173        c.Configure(*config);
174        cam_ = &c;
175    }
176
177    void Capture()
178    {
179        if (cam_ == nullptr) {
180            cout << "Camera is not ready." << endl;
181            return;
182        }
183        FrameConfig *fc = new FrameConfig(FRAME_CONFIG_CAPTURE);
184        Surface *surface = Surface::CreateSurface();
185        if (surface == nullptr) {
186            delete fc;
187            return;
188        }
189        surface->SetWidthAndHeight(1920, 1080); /* 1920:width,1080:height */
190        fc->AddSurface(*surface);
191        cam_->TriggerSingleCapture(*fc);
192    }
193    ```
194
195
196