Metal 开发 | 使用 C++ 进行接口调用

2021-11-28
2 min read
iOS

前两天在群里面看到大佬转发一篇文章:Getting started with Metal-cpp

链接在此:

https://developer.apple.com/metal/cpp/

文章大意就是:一顿操作安排上,苹果现在支持用 C++ 开发 Metal 了。

众所周知,在做渲染后端开发时,OpenGL 和 Vulkan 都是支持 C++ 开发的,可以直接定义 C++ 相关接口并根据平台特性去实现。

而 Metal 则需要支持 Objective-C 才行了,编写的文件也是 .m 文件格式,但是现在就可以直接写 C++ 的渲染实现了。

前置准备

根据官方文章中的内容,首先要确保 Xcode 版本在 9.3 以上,并且要使用 C++17 的语法。

同时要下载好 Metal 对应的 C++ 头文件(metal-cpp),链接地址如下:

https://developer.apple.com/metal/cpp/files/metal-cpp_macOS12_iOS15.zip

创建工程

创建一个 macOS 上的工程,可以是 App 工程也可以是命令行工程,主要是验证一下环境配置是否正确。

接下来要把下载好的 Metal 头文件(metal-cpp)放在工程搜索路径中的,如下图所示:

然后把 C++ 版本改成 std=c++17 。

接下来要把 framework 依赖包含进来:

主要是:

  • Foundation.framework
  • QuartzCore.framework
  • Metal.framework

把以上的环境依赖都搞定之后,就可以进行代码开发了。

代码开发

首先需要把 Metal 相关头文件包含进来,由于它只是一个头文件的库,要生成对应的实现,还要把一些宏配置加上。

核心就是如下一段代码,

#define NS_PRIVATE_IMPLEMENTATION
#define CA_PRIVATE_IMPLEMENTATION
#define MTL_PRIVATE_IMPLEMENTATION
#include <Foundation/Foundation.hpp>
#include <Metal/Metal.hpp>
#include <QuartzCore/QuartzCore.hpp>

在其他需要用到 Metal 相关对象的地方,就只用包含三个头文件就好了。

三个头文件都是配套一起出现的,当然也可以只包含一个头文件就行。

在下载 metal-cpp 的 SingleHeader 文件夹下,有一个 MakeSingleHeader.py 脚本, 运行它来生成:

./SingleHeader/MakeSingleHeader.py Foundation/Foundation.hpp QuartzCore/QuartzCore.hpp Metal/Metal.hpp

这样一来,在 SingleHeader 文件夹下会生成 Metal.hpp 文件,它包含了所有会用到的对象,只包含它一个就好了。

#define NS_PRIVATE_IMPLEMENTATION
#define CA_PRIVATE_IMPLEMENTATION
#define MTL_PRIVATE_IMPLEMENTATION
#include <Metal/Metal.hpp>

成功引入了 Metal 头文件就可以进行开发了,官方也给出了一个 Demo 工程,可以运行下这个工程:

https://developer.apple.com/documentation/metal/rendering_a_scene_with_deferred_lighting_in_c

另外,用 Metal 做渲染引擎的开发,比用 OpenGL 写要快多了,因为它本身就提供了很多封装工具类,比 OpenGL 从零开始写要省不少事,而且说不定性能还强不少。

原创文章,转载请注明来源:    Metal 开发 | 使用 C++ 进行接口调用


欢迎关注微信公众号:音视频开发进阶