반응형 이미지 (responsive image)는 반응형 웹 디자인의 큰 부분을 차지하는 개념 및 기법이라 생각됩니다.
반응형 웹 디자인과 마찬가지로, 모바일과 데스크탑의 스크린 크기에 어떻게 대응하는가 하는 것과
실제 전송되는 화일의 크기와 내용을 어떻게 달리 할까라는 보다 실용적인 문제 등이 있는것 같습니다.
아마 첫번째는 클라이언트쪽에서 처리를 하고, 두번째는 서버쪽에서 처리를 해야 하지 않을까 합니다.
이번에 제가 관심을 가졌던 분야는, 이미지 화일을 선택적으로 사용하도록 하는 기법들입니다.
즉, 데탑에서 사용하는 이미지화일과 모바일에서 사용하는 이미지화일들을 선택적으로 사용하는 방법이죠.
참고로 아직 테스트 해보지는 못했습니다. ^^;
1. 쿠키를 이용한 선택적 이미지 화일 제공 기법: http://blog.keithclark.co.uk/responsive-images-using-cookies/
= 아이디어: 이미지 폴더 (/image)에 쿠기값을 이용하여 이미지 화일을 선택하는 index.php 저장
= 사용방법
document.cookie = "device_dimensions=" + screen.width + "x" + screen.height;
<img src="images/?test.png">
= index.php 에서는 쿠키값 ($_COOKIE['device_dimensions'])를 이용해서, 화면크기에 맞는 화일 전송
+ 장점: 다른 방법에 비해서, 한 이미지만 전송
- 단점: 쿠키가 허용된 도메인에, 화면크기에 따른 모든 이미지를 미리 생성해놔야.
2. 모바일 퍼스트 접근방법 1: http://filamentgroup.com/lab/responsive_images_experimenting_with_context_aware_image_sizing/
= 아이디어: 기본적으로 모바일용 이미지를 다운받고, 데탑에서는 큰 이미지를 별도로 받도록 유도
= 사용방법
<img src="images/test.png?full=images/test-full.png">
= 적절한 .htaccess와 responsiveimgs.js 이용, 위 이미지 소스를 데탑에서는 큰 이미지로 바꿔짐
+ 장점: 대체 (큰) 이미지를 자유롭게 설정가능
- 단점: 작은 이미지화일은 항상 받음. IE8이하는 작동안함 (즉, 작은 그림만 보여줌), mod_rewrite 허용되어야 함
= 아이디어: js 없이, css3의 media-query와 data/attr 기능을 이용, 선택적 큰 이미지 선택
= 사용방법
<img src="image.png" data-src-600px="image-600px.png">
@media (min-device-width:600px) {
img[data-src-600px] {
content: attr(data-src-600px, url);
}
} + 장점: js 불필요
- 단점: 역시 작은 이미지는 항상 받음. css3 지원하지 않는 브라우져 지원 안함.
이밖에 Sench.io를 사용하는 방법도 있겠죠. 그리고 video인 경우 max-width:100%로 완전히 처리되지 않는 경우의 팁도 있네요. (링크)
그밖에 다른 방법을 알고 계시는 분들도 같이 나눠보아요. :)
* 위 내용은, 스매싱매거진 글에서 가져왔습니다. http://www.smashingmagazine.com/2011/07/22/responsive-web-design-techniques-tools-and-design-strategies/
반응형 이미지 이외에, 반응형 웹 디자인 관련 기법들도 많이 있네요..
댓글 8개
display:none 으로 이미지를 선택적으로 다운로딩 할 수 있는지 실험해본 결과가 꽤 유용해 보입니다.
원글: http://timkadlec.com/2012/04/media-query-asset-downloading-results/
제 블로그: http://blog.gnuboard.org/2012/04/media-query-image-downloads/
결론적으로, background-image 의 부모 태그에 display:none 을 적용하면, 거의 모든 (모바일) 웹 브라우져에서 해당 백그라운드 이미지를 다운로드 하지 않는다고 합니다. :)
원글: http://timkadlec.com/2012/04/media-query-asset-downloading-results/
제 블로그: http://blog.gnuboard.org/2012/04/media-query-image-downloads/
결론적으로, background-image 의 부모 태그에 display:none 을 적용하면, 거의 모든 (모바일) 웹 브라우져에서 해당 백그라운드 이미지를 다운로드 하지 않는다고 합니다. :)
게시글 목록
| 번호 | 제목 |
|---|---|
| 32341 | |
| 32339 | |
| 32326 | |
| 32325 | |
| 32322 | |
| 32319 | |
| 32318 | |
| 32316 | |
| 32315 | |
| 32313 | |
| 32312 | |
| 32311 | |
| 32310 | |
| 32304 | |
| 32303 | |
| 32300 | |
| 32293 | |
| 32292 | |
| 32291 | |
| 32285 | |
| 32284 | |
| 32275 | |
| 32271 | |
| 32268 | |
| 32265 | |
| 32261 | |
| 32258 | |
| 32257 | |
| 32255 | |
| 32254 | |
| 32253 | |
| 32251 | |
| 32250 | |
| 32249 | |
| 32247 | |
| 32246 | |
| 32245 | |
| 32244 | |
| 32243 | |
| 32242 | |
| 32241 | |
| 32240 | |
| 32239 | |
| 32238 | |
| 32237 | |
| 32236 | |
| 32232 | |
| 32229 | |
| 32228 | |
| 32227 | |
| 32217 | |
| 32215 | |
| 32214 | |
| 32213 | |
| 32211 | |
| 32207 | |
| 32196 | |
| 32193 | |
| 32192 | |
| 32190 | |
| 32188 | |
| 32186 | |
| 32184 | |
| 32173 | |
| 32172 | |
| 32171 | |
| 32167 | |
| 32165 | |
| 32163 | |
| 32162 | |
| 32158 | |
| 32157 | |
| 32155 | |
| 32151 | |
| 32149 | |
| 32135 | |
| 32132 | |
| 32127 | |
| 32125 | |
| 32122 | |
| 32120 | |
| 32119 | |
| 32117 | |
| 32116 | |
| 32115 | |
| 32114 | |
| 32112 | |
| 32111 | |
| 32109 | |
| 32107 | |
| 32104 | |
| 32103 | |
| 32102 | |
| 32101 | |
| 32094 | |
| 32089 | |
| 20404 | |
| 31036 | |
| 8279 | |
| 8268 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기