Search code examples
opengl-esrounded-corners

OpenGL—ES 1.0 2d rounded rectangle


How to make rounded rectangle in OpenGL, or any polygon with rounded corners?


Solution

  • Using polygons

    If using polygons is absolutely required, for example if objects with rounding need to be scaled or zoomed a lot or if amount of rounding needs to be controlled, it is possible to break rectangle into several sub-objects.

    Rounded corners

    There are at least three rectangular parts and four corners. Calculating corner coordinates is easy. Just find a point from circle and build triangles like in picture above.

     float anglerad = PI * angle / 180.0f;
     float x = sinf(anglerad) * radius; 
     float y = cosf(anglerad) * radius;
    

    It will still have sharp edges, but more points make corners more round. Small objects need less points than big objects.

    Easy route is to use GL_TRIANGLE_FAN for corners. However with OpenGL ES it might be wise to minimize amount of OpenGL calls and just use more vertices as it is possible to build whole object as GL_TRIANGLE_STRIP.

    This approached can be used with any shape. With a rectangle, angle of corner is always 90 degrees, but with other shapes angle needs to be calculated from the edges.

    Using textures

    Another approach is called 9-slice scaling. Rectangle and texture are broken into 9 slices. Actual rounding is in corner of a texture. Idea is that corners are not scaled, but maintain their original size. This approach is widely used pattern in UI-design allowing variable size UI-elements like buttons. Its advantage is that one rectangle needs only these 9 quads to render. But it will look bad if also corners need to be scaled and especially if texture is low resolution.