웹마스터 팁
page_full_width" class="col-xs-12" |cond="$__Context->page_full_width">
png-24 포맷 알파값 이미지 로딩하기
2003.04.20 15:15
먼저, 예제입니다.
http://ezvice.com/bbs/png/png.htm
밑에 있는 세가지 그림은 모두 png파일입니다.
위의 컬러 이름 쓰여져 있는 것을 눌러보세요.
배경이 바뀌면서 png의 알파값도 같이 적용됩니다.
이것을 만드는 법을 소개하겠습니다.
참고로, 원 출처는 http://www.theaqua.com입니다.
스틱스님 홈페이지에 사용되었던 것입니다.
저 "png.htm"파일을 소스로 열어보면 아시다시피,
이 그림을 로딩하는 방법은 모두 "png.js"에 들어가 있습니다.
그럼 png.js를 열어보겠습니다.
if (navigator.platform == "Win32" && navigator.appName == "Microsoft Internet Explorer" && window.attachEvent) {
document.writeln('<style type="text/css">img, input.image { visibility:hidden; } </style>');
window.attachEvent("onload", fnLoadPngs);
}
function fnLoadPngs() {
var rslt = navigator.appVersion.match(/MSIE (d+.d+)/, '');
var itsAllGood = (rslt != null && Number(rslt[1]) >= 5.5);
for (var i = document.images.length - 1, img = null; (img = document.images[i]); i--) {
if (itsAllGood && img.src.match(/.png$/i) != null) {
var src = img.src;
img.style.width = img.width + "px";
img.style.height = img.height + "px";
img.style.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(src='" + src + "', sizingMethod='scale')"
img.src = "spacer.gif";
}
img.style.visibility = "visible";
}
}
이렇게 되어 있습니다.
여기서 중요한 부분은 몇 되지 않습니다.
바꿔야 할 부분은 거의 없고,
유념해야 할 것은, js를 htm파일에 경로를 제대로 입력하는 것과
끝에서 다섯번째 줄의 spacer.gif,
그리고 로딩하는 png가 꼭 " img src= " 구문으로 로딩되어야 한다는 것입니다.
저 spacer.gif는 가로 사이즈 1, 세로 사이즈 1의 투명한 gif로서,
표현한 png-24의 위를 살포시 덮어주는 역할을 하는데요,
이것 img.src = "images/spacer.gif"; 구문을 없애버리면
알파값이 적용되지 않습니다.
이점 유의하시기 바랍니다.
그러므로, 저 구문의 "spacer.gif"에는
가로 1, 세로 1 사이즈의 투명한 gif파일을 로딩하면 되는 것입니다.
이것만 유념하시면 png-24의 알파값 이미지를 로딩할 수 있습니다.
업로드 #1은, 이 강좌에 사용된 png.js 파일입니다.
모르는 부분이 있으면 코멘트로 어택하시기 바랍니다. (관리자라는 위치상 쪽지로 질문 받을 수 없습니다)
* Nytoner님에 의해서 게시물 이동되었습니다 (2003-04-21 17:21)
출처 : http://www.theaqua.com
http://ezvice.com/bbs/png/png.htm
밑에 있는 세가지 그림은 모두 png파일입니다.
위의 컬러 이름 쓰여져 있는 것을 눌러보세요.
배경이 바뀌면서 png의 알파값도 같이 적용됩니다.
이것을 만드는 법을 소개하겠습니다.
참고로, 원 출처는 http://www.theaqua.com입니다.
스틱스님 홈페이지에 사용되었던 것입니다.
저 "png.htm"파일을 소스로 열어보면 아시다시피,
이 그림을 로딩하는 방법은 모두 "png.js"에 들어가 있습니다.
그럼 png.js를 열어보겠습니다.
if (navigator.platform == "Win32" && navigator.appName == "Microsoft Internet Explorer" && window.attachEvent) {
document.writeln('<style type="text/css">img, input.image { visibility:hidden; } </style>');
window.attachEvent("onload", fnLoadPngs);
}
function fnLoadPngs() {
var rslt = navigator.appVersion.match(/MSIE (d+.d+)/, '');
var itsAllGood = (rslt != null && Number(rslt[1]) >= 5.5);
for (var i = document.images.length - 1, img = null; (img = document.images[i]); i--) {
if (itsAllGood && img.src.match(/.png$/i) != null) {
var src = img.src;
img.style.width = img.width + "px";
img.style.height = img.height + "px";
img.style.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(src='" + src + "', sizingMethod='scale')"
img.src = "spacer.gif";
}
img.style.visibility = "visible";
}
}
이렇게 되어 있습니다.
여기서 중요한 부분은 몇 되지 않습니다.
바꿔야 할 부분은 거의 없고,
유념해야 할 것은, js를 htm파일에 경로를 제대로 입력하는 것과
끝에서 다섯번째 줄의 spacer.gif,
그리고 로딩하는 png가 꼭 " img src= " 구문으로 로딩되어야 한다는 것입니다.
저 spacer.gif는 가로 사이즈 1, 세로 사이즈 1의 투명한 gif로서,
표현한 png-24의 위를 살포시 덮어주는 역할을 하는데요,
이것 img.src = "images/spacer.gif"; 구문을 없애버리면
알파값이 적용되지 않습니다.
이점 유의하시기 바랍니다.
그러므로, 저 구문의 "spacer.gif"에는
가로 1, 세로 1 사이즈의 투명한 gif파일을 로딩하면 되는 것입니다.
이것만 유념하시면 png-24의 알파값 이미지를 로딩할 수 있습니다.
업로드 #1은, 이 강좌에 사용된 png.js 파일입니다.
모르는 부분이 있으면 코멘트로 어택하시기 바랍니다. (관리자라는 위치상 쪽지로 질문 받을 수 없습니다)
* Nytoner님에 의해서 게시물 이동되었습니다 (2003-04-21 17:21)
출처 : http://www.theaqua.com
댓글 9
-
TheMics
2003.04.20 16:29
;ㅁ;결국 올렸군; -
TheMics
2003.04.20 16:29
그런데말야;자바스크립트 자료 아닐까; -
DearMai
2003.04.20 21:54
자바스크립트와 CSS 속성을 둘다 가진듯 ;ㅁ; -
Nytoner
2003.04.21 07:34
저도 어디로 옮겨야 할지 몰랐는데; 그냥 놔둬도 되겠네요;; CSS 속성을 가졌다면.. -
K i o r i a
2003.04.21 11:41
100% 자바 스크립트 입니다. 코딩 안에 들어가있는 CSS는 그냥 익스플로러면은 정해져있는 CSS를 쓰라는뜻. -
nxtyle
2003.04.21 12:55
그럼 PNG의 호환성[알파값이나..]을 높이는 자바라고 보면되나요?;;; -
nxtyle
2003.04.21 12:59
재밌는건...마우스 오른쪽 클릭해서 등록정보를 보면...크기는 png파일의 크긴데 파일 자체는 spacer.gif내요;;;음...자바스크립트는 이래서 무한하다는건가;;; -
styx
2003.04.21 17:06
소스를 보다가... 어째 내 소스같다라고 생각하고 다시 훑어보니;; ㅡㅡ;; -
가울이
2003.04.23 16:21
앗; 유명인사 납시오~
제목 | 글쓴이 | 날짜 |
---|---|---|
크롬리스(Chromless) 웹어플리케이션 -2 [5] | sundew | 2003.05.18 |
크롬리스(Chromless) 웹어플리케이션 -1 [1] | sundew | 2003.05.17 |
XXX는 객체가 아닙니다. [1] | RedEye | 2003.05.12 |
자바스크립트의 활용함에 대해.... [5] | RedEye | 2003.05.12 |
자바스크립트의 활용함에 대해 2 .... [1] | RedEye | 2003.05.18 |
[벅스 전용] 랜덤 음악 재생 Javascript. [1] | sundew | 2003.05.11 |
구문 오류 및 런타임 오류 모음 [1] | 아이쿠 | 2003.05.10 |
이벤트 핸들러 (Event Handler) 모음 [2] | 아이쿠 | 2003.05.10 |
랜덤 배경화면 구현하기 초간단 스크립트 공개(중복아님) [5] | 호호짱 | 2003.05.07 |
[re] [소스] [배경음악] 첫곡은 랜덤, 그 이후로는 순차재생 --> 문제해결! [1] | 장진석 | 2003.06.02 |
상태바에 링크 주소 99.9% 가리기 - 다른것 [8] | 세죠위그이 | 2003.05.05 |
상태바에 링크 주소 쉽게 99.9999% 가리기 [8] | 최상락 | 2003.05.03 |
또다른 TOP으로 가기 [6] | RedEye | 2003.05.05 |
시디롬 뱉어 내는 스크립.. [2] | 피너츠 | 2003.04.29 |
[! 수정판 !] 일반 자바 스크릅트와 차원이 다른 VB 스크립트 만들기! [10] | 제로보드 | 2003.04.29 |
숫자인지 아닌지 알아보는함수 [1] | 김승태 | 2003.04.27 |
좌표관련메소드모음 [1] | 김승태 | 2003.04.27 |
유용한건 아니지만 마우스 클릭으로 블루스크린띠우기 [3] | 루룿 | 2003.04.25 |
png-24 포맷 알파값 이미지 로딩하기 [9] | D3 | 2003.04.20 |
메뉴이동입니다. [5] | 데빌스텔스 | 2003.04.20 |