• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1# NativeWindow
2
3
4## 概述
5
6提供NativeWindow功能,作为数据生产者,可用来和egl对接
7
8\@syscap SystemCapability.Graphic.Graphic2D.NativeWindow
9
10**起始版本:**
11
128
13
14
15## 汇总
16
17
18### 文件
19
20| 名称 | 描述 |
21| -------- | -------- |
22| [external_window.h](external__window_8h.md) | 定义获取和使用NativeWindow的相关函数<br/>引用文件:&lt;native_window/external_window.h&gt; <br/>库:libnative_window.so|
23
24
25### 结构体
26
27| 名称 | 描述 |
28| -------- | -------- |
29| [Region](_region.md) | 表示本地窗口OHNativeWindow需要更新内容的矩形区域(脏区) |
30| [OHHDRMetaData](_o_h_h_d_r_meta_data.md) | HDR元数据结构体定义 |
31| [OHExtDataHandle](_o_h_ext_data_handle.md) | 扩展数据句柄结构体定义 |
32
33
34### 类型定义
35
36| 名称 | 描述 |
37| -------- | -------- |
38| [OHNativeWindow](#ohnativewindow) | 提供对OHNativeWindow的访问功能 |
39| [OHNativeWindowBuffer](#ohnativewindowbuffer) | 提供对OHNativeWindowBuffer的访问功能 |
40| [Region](#region) | 表示本地窗口OHNativeWindow需要更新内容的矩形区域(脏区) |
41
42
43### 枚举
44
45| 名称 | 描述 |
46| -------- | -------- |
47| [NativeWindowOperation](#nativewindowoperation) {<br/>SET_BUFFER_GEOMETRY, GET_BUFFER_GEOMETRY, GET_FORMAT, SET_FORMAT,<br/>GET_USAGE, SET_USAGE, SET_STRIDE, GET_STRIDE,<br/>SET_SWAP_INTERVAL, GET_SWAP_INTERVAL, SET_TIMEOUT, GET_TIMEOUT,<br/>SET_COLOR_GAMUT, GET_COLOR_GAMUT, SET_TRANSFORM, GET_TRANSFORM,<br/>SET_UI_TIMESTAMP<br/>} | OH_NativeWindow_NativeWindowHandleOpt函数中的操作码 |
48| [OHScalingMode](#ohscalingmode) { OH_SCALING_MODE_FREEZE = 0, OH_SCALING_MODE_SCALE_TO_WINDOW, OH_SCALING_MODE_SCALE_CROP, OH_SCALING_MODE_NO_SCALE_CROP } | 缩放模式 Scaling Mode |
49| [OHHDRMetadataKey](#ohhdrmetadatakey) {<br/>OH_METAKEY_RED_PRIMARY_X = 0, OH_METAKEY_RED_PRIMARY_Y = 1, OH_METAKEY_GREEN_PRIMARY_X = 2, OH_METAKEY_GREEN_PRIMARY_Y = 3,<br/>OH_METAKEY_BLUE_PRIMARY_X = 4, OH_METAKEY_BLUE_PRIMARY_Y = 5, OH_METAKEY_WHITE_PRIMARY_X = 6, OH_METAKEY_WHITE_PRIMARY_Y = 7,<br/>OH_METAKEY_MAX_LUMINANCE = 8, OH_METAKEY_MIN_LUMINANCE = 9, OH_METAKEY_MAX_CONTENT_LIGHT_LEVEL = 10, OH_METAKEY_MAX_FRAME_AVERAGE_LIGHT_LEVEL = 11,<br/>OH_METAKEY_HDR10_PLUS = 12, OH_METAKEY_HDR_VIVID = 13<br/>} | 枚举HDR元数据关键字 |
50
51
52### 函数
53
54| 名称 | 描述 |
55| -------- | -------- |
56| [OH_NativeWindow_CreateNativeWindow](#oh_nativewindow_createnativewindow) (void \*pSurface) | 创建OHNativeWindow实例,每次调用都会产生一个新的OHNativeWindow实例 |
57| [OH_NativeWindow_DestroyNativeWindow](#oh_nativewindow_destroynativewindow) (OHNativeWindow \*window) | 将OHNativeWindow对象的引用计数减1,当引用计数为0的时候,该OHNativeWindow对象会被析构掉 |
58| [OH_NativeWindow_CreateNativeWindowBufferFromSurfaceBuffer](#oh_nativewindow_createnativewindowbufferfromsurfacebuffer) (void \*pSurfaceBuffer) | 创建OHNativeWindowBuffer实例,每次调用都会产生一个新的OHNativeWindowBuffer实例 |
59| [OH_NativeWindow_DestroyNativeWindowBuffer](#oh_nativewindow_destroynativewindowbuffer) (OHNativeWindowBuffer \*buffer) | 将OHNativeWindowBuffer对象的引用计数减1,当引用计数为0的时候,该OHNativeWindowBuffer对象会被析构掉 |
60| [OH_NativeWindow_NativeWindowRequestBuffer](#oh_nativewindow_nativewindowrequestbuffer) (OHNativeWindow \*window, OHNativeWindowBuffer \*\*buffer, int \*fenceFd) | 通过OHNativeWindow对象申请一块OHNativeWindowBuffer,用以内容生产 |
61| [OH_NativeWindow_NativeWindowFlushBuffer](#oh_nativewindow_nativewindowflushbuffer) (OHNativeWindow \*window, OHNativeWindowBuffer \*buffer, int fenceFd, Region region) | 通过OHNativeWindow将生产好内容的OHNativeWindowBuffer放回到Buffer队列中,用以内容消费 |
62| [OH_NativeWindow_NativeWindowAbortBuffer](#oh_nativewindow_nativewindowabortbuffer) (OHNativeWindow \*window, OHNativeWindowBuffer \*buffer) | 通过OHNativeWindow将之前申请出来的OHNativeWindowBuffer返还到Buffer队列中,供下次再申请 |
63| [OH_NativeWindow_NativeWindowHandleOpt](#oh_nativewindow_nativewindowhandleopt) (OHNativeWindow \*window, int code,...) | 设置/获取OHNativeWindow的属性,包括设置/获取宽高、内容格式等 |
64| [OH_NativeWindow_GetBufferHandleFromNative](#oh_nativewindow_getbufferhandlefromnative) (OHNativeWindowBuffer \*buffer) | 通过OHNativeWindowBuffer获取该buffer的BufferHandle指针 |
65| [OH_NativeWindow_NativeObjectReference](#oh_nativewindow_nativeobjectreference) (void \*obj) | 增加一个NativeObject的引用计数 |
66| [OH_NativeWindow_NativeObjectUnreference](#oh_nativewindow_nativeobjectunreference) (void \*obj) | 减少一个NativeObject的引用计数,当引用计数减少为0时,该NativeObject将被析构掉 |
67| [OH_NativeWindow_GetNativeObjectMagic](#oh_nativewindow_getnativeobjectmagic) (void \*obj) | 获取NativeObject的MagicId |
68| [OH_NativeWindow_NativeWindowSetScalingMode](#oh_nativewindow_nativewindowsetscalingmode) (OHNativeWindow \*window, uint32_t sequence, OHScalingMode scalingMode) | 设置OHNativeWindow的ScalingMode |
69| [OH_NativeWindow_NativeWindowSetMetaData](#oh_nativewindow_nativewindowsetmetadata) (OHNativeWindow \*window, uint32_t sequence, int32_t size, const OHHDRMetaData \*metaData) | 设置OHNativeWindow的元数据 |
70| [OH_NativeWindow_NativeWindowSetMetaDataSet](#oh_nativewindow_nativewindowsetmetadataset) (OHNativeWindow*window, uint32_t sequence, OHHDRMetadataKey key, int32_t size, const uint8_t \*metaData) | 设置OHNativeWindow的元数据集。 |
71| [OH_NativeWindow_NativeWindowSetTunnelHandle](#oh_nativewindow_nativewindowsettunnelhandle) (OHNativeWindow \*window, const OHExtDataHandle \*handle) | 设置OHNativeWindow的TunnelHandle。 |
72
73
74## 类型定义说明
75
76
77### OHNativeWindow
78
79
80```
81typedef struct NativeWindow OHNativeWindow
82```
83
84**描述:**
85
86提供对OHNativeWindow的访问功能
87
88
89### OHNativeWindowBuffer
90
91
92```
93typedef struct NativeWindowBuffer OHNativeWindowBuffer
94```
95
96**描述:**
97
98提供对OHNativeWindowBuffer的访问功能
99
100
101### Region
102
103
104```
105typedef struct Region Region
106```
107
108**描述:**
109
110表示本地窗口OHNativeWindow需要更新内容的矩形区域(脏区)
111
112
113## 枚举类型说明
114
115
116### NativeWindowOperation
117
118
119```
120enum NativeWindowOperation
121```
122
123**描述:**
124
125OH_NativeWindow_NativeWindowHandleOpt函数中的操作码
126
127| 枚举值 | 描述 |
128| -------- | -------- |
129| SET_BUFFER_GEOMETRY | 设置本地窗口缓冲区几何图形, 函数中的可变参数是 [输入]int32_t width ,[输入] int32_t height。 |
130| GET_BUFFER_GEOMETRY | 获取本地窗口缓冲区几何图形, 函数中的可变参数是 [输出] int32_t \*height, [输出] int32_t \*width。 |
131| GET_FORMAT | 获取本地窗口缓冲区格式, 函数中的可变参数是 [输出] int32_t \*format。 |
132| SET_FORMAT | 设置本地窗口缓冲区格式, 函数中的可变参数是 [输入] int32_t format。 |
133| GET_USAGE | 获取本地窗口读写方式, 函数中的可变参数是 [输出] int32_t \*usage。 |
134| SET_USAGE | 设置本地窗口缓冲区读写方式, 函数中的可变参数是 [输入] int32_t usage。 |
135| SET_STRIDE | 设置本地窗口缓冲区步幅, 函数中的可变参数是 [输入] int32_t stride。 |
136| GET_STRIDE | 获取本地窗口缓冲区步幅, 函数中的可变参数是 [输出] int32_t \*stride。 |
137| SET_SWAP_INTERVAL | 设置本地窗口缓冲区交换间隔, 函数中的可变参数是 [输入] int32_t interval。 |
138| GET_SWAP_INTERVAL | 获取本地窗口缓冲区交换间隔, 函数中的可变参数是 [输出] int32_t \*interval。 |
139| SET_TIMEOUT | 设置请求本地窗口缓冲区的超时等待时间, 函数中的可变参数是 [输入] int32_t timeout。 |
140| GET_TIMEOUT | 获取请求本地窗口缓冲区的超时等待时间, 函数中的可变参数是 [输出] int32_t \*timeout。 |
141| SET_COLOR_GAMUT | 设置本地窗口缓冲区色彩空间, 函数中的可变参数是 [输入] int32_t colorGamut。 |
142| GET_COLOR_GAMUT | 获取本地窗口缓冲区色彩空间, 函数中的可变参数是 [out int32_t \*colorGamut]。 |
143| SET_TRANSFORM | 设置本地窗口缓冲区变换, 函数中的可变参数是 [输入] int32_t transform。 |
144| GET_TRANSFORM | 获取本地窗口缓冲区变换, 函数中的可变参数是 [输出] int32_t \*transform。 |
145| SET_UI_TIMESTAMP | 设置本地窗口缓冲区UI时间戳, 函数中的可变参数是 [输入] uint64_t uiTimestamp。 |
146
147
148### OHHDRMetadataKey
149
150
151```
152enum OHHDRMetadataKey
153```
154
155**描述:**
156
157枚举HDR元数据关键字
158
159**起始版本:**
160
1619
162
163**弃用:**
164
165从API version 10开始废弃,不再提供替代接口
166
167| 枚举值 | 描述 |
168| -------- | -------- |
169| OH_METAKEY_RED_PRIMARY_X | 红基色X坐标 |
170| OH_METAKEY_RED_PRIMARY_Y | 红基色Y坐标 |
171| OH_METAKEY_GREEN_PRIMARY_X | 绿基色X坐标 |
172| OH_METAKEY_GREEN_PRIMARY_Y | 绿基色Y坐标 |
173| OH_METAKEY_BLUE_PRIMARY_X | 蓝基色X坐标 |
174| OH_METAKEY_BLUE_PRIMARY_Y | 蓝基色Y坐标 |
175| OH_METAKEY_WHITE_PRIMARY_X | 白点X坐标 |
176| OH_METAKEY_WHITE_PRIMARY_Y | 白点Y坐标 |
177| OH_METAKEY_MAX_LUMINANCE | 最大的光亮度 |
178| OH_METAKEY_MIN_LUMINANCE | 最小的光亮度 |
179| OH_METAKEY_MAX_CONTENT_LIGHT_LEVEL | 最大的内容亮度水平 |
180| OH_METAKEY_MAX_FRAME_AVERAGE_LIGHT_LEVEL | 最大的帧平均亮度水平 |
181| OH_METAKEY_HDR10_PLUS | HDR10 Plus |
182| OH_METAKEY_HDR_VIVID | Vivid |
183
184
185### OHScalingMode
186
187
188```
189enum OHScalingMode
190```
191
192**描述:**
193
194缩放模式 Scaling Mode
195
196**起始版本:**
197
1989
199
200**弃用:**
201
202从API version 10开始废弃,不再提供替代接口
203
204| 枚举值 | 描述 |
205| -------- | -------- |
206| OH_SCALING_MODE_FREEZE | 在接收到窗口大小的缓冲区之前,不可以更新窗口内容 |
207| OH_SCALING_MODE_SCALE_TO_WINDOW | 缓冲区在二维中缩放以匹配窗口大小 |
208| OH_SCALING_MODE_SCALE_CROP | 缓冲区被统一缩放,使得缓冲区的较小尺寸与窗口大小匹配 |
209| OH_SCALING_MODE_NO_SCALE_CROP | 窗口被裁剪为缓冲区裁剪矩形的大小,裁剪矩形之外的像素被视为完全透明 |
210
211
212## 函数说明
213
214
215### OH_NativeWindow_CreateNativeWindow()
216
217
218```
219OHNativeWindow* OH_NativeWindow_CreateNativeWindow (void * pSurface)
220```
221
222**描述:**
223
224创建OHNativeWindow实例,每次调用都会产生一个新的OHNativeWindow实例
225
226\@syscap SystemCapability.Graphic.Graphic2D.NativeWindow
227
228**参数:**
229
230| 名称 | 描述 |
231| -------- | -------- |
232| pSurface | 一个指向生产者ProduceSurface的指针,类型为sptr&lt;OHOS::Surface&gt; |
233
234**返回:**
235
236返回一个指针,指向OHNativeWindow的结构体实例
237
238> **说明:**
239>
240> 此接口不支持使用,可通过[OH_NativeImage_AcquireNativeWindow](_o_h___native_image.md#oh_nativeimage_acquirenativewindow)获取,或通过XComponent创建。
241
242
243### OH_NativeWindow_CreateNativeWindowBufferFromSurfaceBuffer()
244
245
246```
247OHNativeWindowBuffer* OH_NativeWindow_CreateNativeWindowBufferFromSurfaceBuffer (void * pSurfaceBuffer)
248```
249
250**描述:**
251
252创建OHNativeWindowBuffer实例,每次调用都会产生一个新的OHNativeWindowBuffer实例
253
254\@syscap SystemCapability.Graphic.Graphic2D.NativeWindow
255
256**参数:**
257
258| 名称 | 描述 |
259| -------- | -------- |
260| pSurfaceBuffer | 一个指向生产者buffer的指针,类型为sptr&lt;OHOS::SurfaceBuffer&gt; |
261
262**返回:**
263
264返回一个指针,指向OHNativeWindowBuffer的结构体实例
265
266> **说明:**
267>
268> 此接口不支持使用。
269
270### OH_NativeWindow_DestroyNativeWindow()
271
272
273```
274void OH_NativeWindow_DestroyNativeWindow (OHNativeWindow *  window)
275```
276
277**描述:**
278
279将OHNativeWindow对象的引用计数减1,当引用计数为0的时候,该OHNativeWindow对象会被析构掉
280
281\@syscap SystemCapability.Graphic.Graphic2D.NativeWindow
282
283**参数:**
284
285| 名称 | 描述 |
286| -------- | -------- |
287| window | 一个OHNativeWindow的结构体实例的指针 |
288
289
290### OH_NativeWindow_DestroyNativeWindowBuffer()
291
292
293```
294void OH_NativeWindow_DestroyNativeWindowBuffer (OHNativeWindowBuffer *  buffer)
295```
296
297**描述:**
298
299将OHNativeWindowBuffer对象的引用计数减1,当引用计数为0的时候,该OHNativeWindowBuffer对象会被析构掉
300
301\@syscap SystemCapability.Graphic.Graphic2D.NativeWindow
302
303**参数:**
304
305| 名称 | 描述 |
306| -------- | -------- |
307| buffer | 一个OHNativeWindowBuffer的结构体实例的指针 |
308
309
310### OH_NativeWindow_GetBufferHandleFromNative()
311
312
313```
314BufferHandle* OH_NativeWindow_GetBufferHandleFromNative (OHNativeWindowBuffer *  buffer)
315```
316
317**描述:**
318
319通过OHNativeWindowBuffer获取该buffer的BufferHandle指针
320
321\@syscap SystemCapability.Graphic.Graphic2D.NativeWindow
322
323**参数:**
324
325| 名称 | 描述 |
326| -------- | -------- |
327| buffer | 一个OHNativeWindowBuffer的结构体实例的指针 |
328
329**返回:**
330
331BufferHandle 返回一个指针,指向BufferHandle的结构体实例
332
333
334### OH_NativeWindow_GetNativeObjectMagic()
335
336
337```
338int32_t OH_NativeWindow_GetNativeObjectMagic (void * obj)
339```
340
341**描述:**
342
343获取NativeObject的MagicId
344
345\@syscap SystemCapability.Graphic.Graphic2D.NativeWindow
346
347**参数:**
348
349| 名称 | 描述 |
350| -------- | -------- |
351| obj | 一个OHNativeWindow或者OHNativeWindowBuffer的结构体实例的指针 |
352
353**返回:**
354
355MagicId 返回值为魔鬼数字,每个NativeObject唯一
356
357
358### OH_NativeWindow_NativeObjectReference()
359
360
361```
362int32_t OH_NativeWindow_NativeObjectReference (void * obj)
363```
364
365**描述:**
366
367增加一个NativeObject的引用计数
368
369\@syscap SystemCapability.Graphic.Graphic2D.NativeWindow
370
371**参数:**
372
373| 名称 | 描述 |
374| -------- | -------- |
375| obj | 一个OHNativeWindow或者OHNativeWindowBuffer的结构体实例的指针 |
376
377**返回:**
378
379返回值为0表示执行成功
380
381
382### OH_NativeWindow_NativeObjectUnreference()
383
384
385```
386int32_t OH_NativeWindow_NativeObjectUnreference (void * obj)
387```
388
389**描述:**
390
391减少一个NativeObject的引用计数,当引用计数减少为0时,该NativeObject将被析构掉
392
393\@syscap SystemCapability.Graphic.Graphic2D.NativeWindow
394
395**参数:**
396
397| 名称 | 描述 |
398| -------- | -------- |
399| obj | 一个OHNativeWindow或者OHNativeWindowBuffer的结构体实例的指针 |
400
401**返回:**
402
403返回值为0表示执行成功
404
405
406### OH_NativeWindow_NativeWindowAbortBuffer()
407
408
409```
410int32_t OH_NativeWindow_NativeWindowAbortBuffer (OHNativeWindow *  window, OHNativeWindowBuffer *  buffer )
411```
412
413**描述:**
414
415通过OHNativeWindow将之前申请出来的OHNativeWindowBuffer返还到Buffer队列中,供下次再申请
416
417\@syscap SystemCapability.Graphic.Graphic2D.NativeWindow
418
419**参数:**
420
421| 名称 | 描述 |
422| -------- | -------- |
423| window | 一个OHNativeWindow的结构体实例的指针 |
424| buffer | 一个OHNativeWindowBuffer的结构体实例的指针 |
425
426**返回:**
427
428返回值为0表示执行成功
429
430
431### OH_NativeWindow_NativeWindowFlushBuffer()
432
433
434```
435int32_t OH_NativeWindow_NativeWindowFlushBuffer (OHNativeWindow *  window, OHNativeWindowBuffer *  buffer, int fenceFd, Region region )
436```
437
438**描述:**
439
440通过OHNativeWindow将生产好内容的OHNativeWindowBuffer放回到Buffer队列中,用以内容消费
441
442\@syscap SystemCapability.Graphic.Graphic2D.NativeWindow
443
444**参数:**
445
446| 名称 | 描述 |
447| -------- | -------- |
448| window | 一个OHNativeWindow的结构体实例的指针 |
449| buffer | 一个OHNativeWindowBuffer的结构体实例的指针 |
450| fenceFd | 一个文件描述符句柄,用以同步时序 |
451| region | 表示一块脏区域,该区域有内容更新 |
452
453**返回:**
454
455返回值为0表示执行成功
456
457
458### OH_NativeWindow_NativeWindowHandleOpt()
459
460
461```
462int32_t OH_NativeWindow_NativeWindowHandleOpt (OHNativeWindow *  window, int code,  ... )
463```
464
465**描述:**
466
467设置/获取OHNativeWindow的属性,包括设置/获取宽高、内容格式等
468
469\@syscap SystemCapability.Graphic.Graphic2D.NativeWindow
470
471**参数:**
472
473| 名称 | 描述 |
474| -------- | -------- |
475| window | 一个OHNativeWindow的结构体实例的指针 |
476| code | 表示操作码,详见[NativeWindowOperation](#nativewindowoperation) |
477| ... | 可变参数,必须与操作码一一对应 |
478
479**返回:**
480
481返回值为0表示执行成功
482
483
484### OH_NativeWindow_NativeWindowRequestBuffer()
485
486
487```
488int32_t OH_NativeWindow_NativeWindowRequestBuffer (OHNativeWindow *  window, OHNativeWindowBuffer **  buffer, int * fenceFd )
489```
490
491**描述:**
492
493通过OHNativeWindow对象申请一块OHNativeWindowBuffer,用以内容生产
494
495\@syscap SystemCapability.Graphic.Graphic2D.NativeWindow
496
497**参数:**
498
499| 名称 | 描述 |
500| -------- | -------- |
501| window | 一个OHNativeWindow的结构体实例的指针 |
502| buffer | 一个OHNativeWindowBuffer的结构体实例的二级指针 |
503| fenceFd | 一个文件描述符句柄 |
504
505**返回:**
506
507返回值为0表示执行成功
508
509
510### OH_NativeWindow_NativeWindowSetMetaData()
511
512
513```
514int32_t OH_NativeWindow_NativeWindowSetMetaData (OHNativeWindow *  window, uint32_t sequence, int32_t size, const OHHDRMetaData *  metaData )
515```
516
517**描述:**
518
519设置OHNativeWindow的元数据
520
521\@syscap SystemCapability.Graphic.Graphic2D.NativeWindow
522
523**参数:**
524
525| 名称 | 描述 |
526| -------- | -------- |
527| window | 一个OHNativeWindow的结构体实例的指针 |
528| sequence | 生产缓冲区的序列 |
529| size | OHHDRMetaData数组的大小 |
530| metaDate | 指向OHHDRMetaData数组的指针 |
531
532**返回:**
533
534返回值为0表示执行成功
535
536**起始版本:**
537
5389
539
540**弃用:**
541
542从API version 10开始废弃,不再提供替代接口
543
544
545### OH_NativeWindow_NativeWindowSetMetaDataSet()
546
547
548```
549int32_t OH_NativeWindow_NativeWindowSetMetaDataSet (OHNativeWindow *  window, uint32_t sequence, OHHDRMetadataKey key, int32_t size, const uint8_t * metaData )
550```
551
552**描述:**
553
554设置OHNativeWindow的元数据集。
555
556\@syscap SystemCapability.Graphic.Graphic2D.NativeWindow
557
558**参数:**
559
560| 名称 | 描述 |
561| -------- | -------- |
562| window | 一个OHNativeWindow的结构体实例的指针。 |
563| sequence | 生产缓冲区的序列。 |
564| key | 枚举值OHHDRMetadataKey |
565| size | uint8_t向量的大小 |
566| metaDate | 指向uint8_t向量的指针 |
567
568**返回:**
569
570返回值为0表示执行成功
571
572**起始版本:**
573
5749
575
576**弃用:**
577
578从API version 10开始废弃,不再提供替代接口
579
580
581### OH_NativeWindow_NativeWindowSetScalingMode()
582
583
584```
585int32_t OH_NativeWindow_NativeWindowSetScalingMode (OHNativeWindow *  window, uint32_t sequence, OHScalingMode scalingMode )
586```
587
588**描述:**
589
590设置OHNativeWindow的ScalingMode
591
592\@syscap SystemCapability.Graphic.Graphic2D.NativeWindow
593
594**参数:**
595
596| 名称 | 描述 |
597| -------- | -------- |
598| window | 一个OHNativeWindow的结构体实例的指针 |
599| sequence | 生产缓冲区的序列 |
600| scalingMode | 枚举值OHScalingMode |
601
602**返回:**
603
604返回值为0表示执行成功
605
606**起始版本:**
607
6089
609
610**弃用:**
611
612从API version 10开始废弃,不再提供替代接口
613
614
615### OH_NativeWindow_NativeWindowSetTunnelHandle()
616
617
618```
619int32_t OH_NativeWindow_NativeWindowSetTunnelHandle (OHNativeWindow *  window, const OHExtDataHandle *  handle )
620```
621
622**描述:**
623
624设置OHNativeWindow的TunnelHandle。
625
626\@syscap SystemCapability.Graphic.Graphic2D.NativeWindow
627
628**参数:**
629
630| 名称 | 描述 |
631| -------- | -------- |
632| window | 一个OHNativeWindow的结构体实例的指针 |
633| handle | 指向OHExtDataHandle的指针 |
634
635**返回:**
636
637返回值为0表示执行成功
638
639**起始版本:**
640
6419
642
643**弃用:**
644
645从API version 10开始废弃,不再提供替代接口
646