How to draw an outlined shape with a line width in Metal
data:image/s3,"s3://crabby-images/b6283/b6283d6dab3a9d5fd6ceacdf08c7e1602be03f81" alt="Oscar de la Hera Gomez"
data:image/s3,"s3://crabby-images/8dcd7/8dcd78f40cee26b92e9263df21b87abda2e6ebad" alt="Three flowers that represent Swift, Metal and Xcode with the text "Line Width in Metal" beneath it."
Setting the thickness of a stroke or the line width is not available in Metal, instead you must draw triangles to produce an outline of your shape.
We recommend that you clone our Open Source Swift Starter Project, checking out the main branch and carrying out the steps below. The changes can be found on the tutorial/metal/line-thickness branch.
git clone git@github.com:delasign/swift-starter-project.git
Step One: Setup the Project
data:image/s3,"s3://crabby-images/261e6/261e63b542047e78ab02207075fd832c78842486" alt="A screenshot of an iPhone that shows a pentagon and a circle each with different colors. This demonstrates that different shaders are being used."
Follow the tutorial below to setup a MTKView within a UIView that draws multiple shapes, with multiple shaders.
Step Two: Create the OutlinedPolygonUniforms struct
data:image/s3,"s3://crabby-images/36389/36389d7bc366eec8376076f744cb5a36f2185519" alt="A screenshot of Xcode showing the struct of the data that we will pass onto the metal shader. Code available below."
Create a new file called OutlinedPolygonUniforms.swift and paste in the code below.
This file is responsible for defining the struct for the data that is passed in from Swift to the Metal shader.
Step Three: Create the Shader
data:image/s3,"s3://crabby-images/c899e/c899ef459a831cadfaeb9ed826d7e6e06c3cee0d" alt="A screenshot of Xcode showing the shader that we developed to produce an outlined shape with a variable line thickness. Code available below."
Create a new Metal file called LineThicknessColorWheelPolygonMetalShader.metal and paste in the code below.
This shader is responsible for drawing the shape with a variable line width.
The line width is calculated from the center.
Please note that this shader makes use of data from the Swift file and passes data from vertex shader to the fragment function. To learn more about this, consult the articles below.
Step Four: Update the Delegate
data:image/s3,"s3://crabby-images/79730/79730b98326b8a3c7d008b56052116a759313834" alt="A screenshot of Xcode showing the updated MetalUIView+MetalDelegate.swift file. The code is available below."
Update the MetalUIView+MetalDelegate.swift to the code below.
Key changes include:
- The addition of the drawOutlinedPolygon function.
- Calling the drawOutlinedPolygon function from the draw function.
Please note that this functionality draws multiple shapes, each of which uses a different vertex and fragment shader function. To learn more consult the article below.
This function also passes data from this file to the metal shader, to learn how to do this consult the article below.
Step Five: Test
data:image/s3,"s3://crabby-images/80ff8/80ff86d43a38abbfb88f805f17634ee75abf109f" alt="A screenshot of an iPhone showing two shapes drawn in metal. One is filled and the other is outlined with a stroke that we set in code. This proves the functionality works."
Run the code on a device and confirm that multiple shapes appear.
One must be outlined and the other, filled.
Looking to learn more about things you can do with Swift, Metal and XCode ?
Search our blog to find educational content on learning how to use Swift, Metal and XCode.