uint8_t atk_mc7725f_get_frame(volatile uint16_t *dts, atk_mc7725f_get_frame_type_t type) { uint16_t width_index; uint16_t height_index; // uint16_t dat; // volatile uint16_t *dts_array[1000]; // //atk_mc7725f_get_frame(*dts_array ,ATK_MC7725F_GET_FRAME_TYPE_AUTO_INC); // if (g_atk_mc7725f_sta.frame.handle_flag == FRAME_HANDLE_DONE) { return ATK_MC7725F_EEMPTY; } ATK_MC7725F_RRST(0); ATK_MC7725F_RCLK(0); ATK_MC7725F_RCLK(1); ATK_MC7725F_RCLK(0); ATK_MC7725F_RRST(1); ATK_MC7725F_RCLK(1); for (height_index=0; height_index<g_atk_mc7725f_sta.output.height; height_index++) { for (width_index=0; width_index<g_atk_mc7725f_sta.output.width; width_index++) { ATK_MC7725F_RCLK(0); dat = (atk_mc7725f_get_byte_data() << 8); ATK_MC7725F_RCLK(1); ATK_MC7725F_RCLK(0); dat |= atk_mc7725f_get_byte_data(); hcc_dat=dat; // hcc[height_index][height_index]=dat; // hcc[height_index][width_index]=dat; ATK_MC7725F_RCLK(1); *dts = dat; switch (type) { case ATK_MC7725F_GET_FRAME_TYPE_NOINC: { break; } case ATK_MC7725F_GET_FRAME_TYPE_AUTO_INC: { dts++; break; } default: { return ATK_MC7725F_EINVAL; } } } } g_atk_mc7725f_sta.frame.handle_flag = FRAME_HANDLE_DONE; g_atk_mc7725f_sta.frame.count++; return ATK_MC7725F_EOK; } 如何将此函数的数据以二维数组输出
时间: 2023-09-11 17:06:09 浏览: 116
C实现与 uint64_t 相同功能的类
你可以将函数的数据以二维数组输出,具体的方法如下:
1. 首先定义一个二维数组,用于存储函数的数据,数组的大小根据实际情况进行定义。例如:`uint16_t hcc[height][width];`
2. 在函数内部,将获取到的数据赋值给二维数组对应的元素。修改代码如下:
```c
hcc[height_index][width_index] = dat;
```
3. 在函数结束后,将二维数组作为函数的输出参数返回。修改函数的声明如下:
```c
uint8_t atk_mc7725f_get_frame(volatile uint16_t *dts, atk_mc7725f_get_frame_type_t type, uint16_t hcc[][width]);
```
4. 在函数中,将二维数组作为参数传入,并在需要返回数据时将数据赋值给该数组。修改代码如下:
```c
uint8_t atk_mc7725f_get_frame(volatile uint16_t *dts, atk_mc7725f_get_frame_type_t type, uint16_t hcc[][width])
```
5. 调用函数时,创建一个二维数组作为输出参数传入,并接收函数返回的结果。例如:
```c
uint16_t hcc_array[height][width];
uint8_t result = atk_mc7725f_get_frame(dts, type, hcc_array);
```
这样,你就可以通过 `hcc_array` 数组获取函数的数据了。记得根据实际情况修改代码中的 `height` 和 `width` 的值。
阅读全文