현재의 앱디자인은 과거 웹디자인을 테이블로 짜던 시절과 거의 비슷하다. 모든 이미지의 shadow 를 포토샵에서 잘라내서 나인패치 형태의 테이블에 한 귀퉁이씩 짜넣던 그 시절. 이 답답함때문에 모바일웹 디자인이 차라리 편한 것 같다. 적어도 레이아웃에서 shadow를 고민하지 않아도 되니까.
언제쯤이면 앱디자인에서도 CSS가 구현하는 수준의 언어기반 렌더링이 가능해질지....
현재의 앱디자인은 과거 웹디자인을 테이블로 짜던 시절과 거의 비슷하다. 모든 이미지의 shadow 를 포토샵에서 잘라내서 나인패치 형태의 테이블에 한 귀퉁이씩 짜넣던 그 시절. 이 답답함때문에 모바일웹 디자인이 차라리 편한 것 같다. 적어도 레이아웃에서 shadow를 고민하지 않아도 되니까.
언제쯤이면 앱디자인에서도 CSS가 구현하는 수준의 언어기반 렌더링이 가능해질지....
웹을 떠난 지 한참 있다가 근 10년 만에 돌아왔더니, CSS가 눈부시게 발전해버렸다.
어제는 미로니에 들어갈 버튼 하나를 디자인하면서, 포토샵에서 만든 이미지를 끼워 맞춰보다가, CSS3를 심층적으로 탐구하게 되었는데, 오… 이 것이 물건이로세.
아무튼, 그 결과는 아래와 같다.
위 이미지는 온전히 <div>에 CSS3로 스타일만 먹여서 만든 버튼이다. 이미지 파일은 1px 도 들어가지 않았으며, 그라데이션부터 외곽선, drop shadow 와 inner shadow, inner glow 모두를 CSS로만 완성한 것이다. 굳이 캡쳐를 한 것은 이 코드가 일부 브라우저(아마도 IE)에서는 위와 같이 렌더링 되지 않을 수도 있기 때문. 실제 코드로 만든 <div>는 아래와 같다.
1. 같은 스타일의 (대량의) 버튼들을 코드 한 두줄로 색이나 shadow 등을 바꿀 수 있어 효율적
2. vector 이미지와 같이 사용자 브라우저의 확대 축소에 전혀 문제가 되지 않는다.
3. 비트맵 이미지보다 훨씬 적은 용량으로 버튼 이미지 구현 가능
그럼 각 단계별로 포토샵 effect 와 CSS 가 어떻게 같은 역할을 하는지 살펴보자.
1. Rounded Box
포토샵에서는 아예 처음부터 박스의 round 값을 정하고 들어가야 해서, 나중에 고치기가 애매한 부분인데, CSS에서는 이마저도 얼마든지 조정 가능하다. <div> 의 외곽을 얼마나 round 처리하는지를 정한다.
border-radius:10px;
2. Gradient Overay
각 브라우저마다 그라데이션은 명령어가 다르다. 해서, 세 줄 다 써놓아야 한다.
<!-- chrome, safari -->
background:-webkit-gradient( linear, left top, left bottom, color-stop(0, #a6cd2f), color-stop(1, #6e9102) );
<!-- mozilla -->
background:-moz-linear-gradient(top, #a6cd2f, #6e9102);
<!-- IE -->
filter: progid:DXImageTransform.Microsoft.Gradient(StartColorStr='#a6cd2f', EndColorStr='#6e9102', GradientType=0);
3. Stroke
포토샵의 stroke는 <div> 의 border 에 해당한다. 해서, 이 border 에 아래와 같은 효과들을 주면 됨.
border-style: solid;
border-width: 1px;
border-color: #555;
(이거 다 합쳐서 한 줄로도 쓸 수 있다. border: 1px solid #555; )
4. Inner Shadow
여기서 포토샵보다 CSS가 더 좋은 한 가지는 multiple shadow 가 적용 가능하다는 점. 포토샵에서는 외곽 번짐효과라고 볼 수 있는 네 가지 - drop shadow, outer glow, inner glow, inner shadow 외에는 추가로 쓸 수 있는 shadow 가 없지만, CSS에서는 무한정 추가 가능하다.
사실상 outer glow 나 inner glow 도 distance 0 인 shadow와 마찬가지이기 때문에, shadow 라는 개념 하나만으로도 이 모든 효과를 표현할 수 있다.
box-shadow:inset 0px 2px 0px rgba(255, 255, 255, .75)
box-shadow:inset 0px 2px 0px rgba(255, 255, 255, .75), inset 0px 0px 2px rgba(255, 255, 255, .75);
box-shadow: inset 0px 2px 0px rgba(255, 255, 255, .75), inset 0px 0px 2px rgba(255, 255, 255, .7), 0px 3px 3px rgba(0,0,0, .3);