Parmanoir

A 2D Bevel Technique

How do you generate a 2D bevel out of a shape ? Maybe start by computing a heightfield, then light it just like Photoshop does … but then, how do you try that out ? Go push individual pixels in C ? Bwwwwarg.

Luckily after browsing the Core Image Reference, we can see that everything we need to do a bevel is there : CIHeightFieldFromMask and CIShadedMaterial.

Image:A 2D Bevel Technique.png

Once there, varying the radius on CIHeightFieldFromMask will vary the bevel depth.

Image:Varying Gaussian Blur Radius.png

Sample QTZ

Bevel 4.qtz

Patrick Geiller
2008 05 29

Browsing the logs I've seen someone from netblock-68-/-/-/.dslextreme.com trying to leave a comment here. I was doing some work on the admin side and your comment didn't make it through. Sorry ! Please repost if you come back.


Follow me on Twitter
Planet Cocoa
Cocoa.fr

2011 02 22Distance field
2010 07 202Binding through NSApp
2010 05 122Forwarding invocations
2010 02 272Core Image black fringes
2010 02 21Quickest Way to Shell
2010 02 08Who's calling ?
2009 09 2138 ways to use Blocks in Snow Leopard
2009 08 182Bracket Mess
2009 08 124Taming JavascriptCore within and without WebView
2009 04 15Debugging with Activity Monitor
2009 03 25How Core Image Color Tracking works
2009 03 1510Custom NSThemeFrame
2009 03 10Which framework is running ?
2009 03 074CoreUI can paint pretty big
2009 02 18Localization with functions
2009 01 30Did you forget to nest alloc and init?
2009 01 16JSCocoa on the iPhone
2009 01 11Mixing WebView and JavascriptCore
2009 01 09Badge overflow
2009 01 09Find your Garbage Collection leaks with Instruments

Powered by MediaWiki