Contents

Develop
2013.04.23 13:55

[js] IE에서 인쇄 설정 팁

조회 수 10900 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
자바스크립트 프린트 호출시 옵션주기

인터넷 익스플러 5.5 버젼에서 WebBrowser Control을 이용하여 자바스크립트로 프린트 설정을 할수 있는 방법이 있었는데 5.5 이후버젼 부터는 MS사에서 많은 문제점 때문에 스크립트로 프린트를 제어할수 없게 했더군요.

MSDN에 사이트 참고한 내용 입니다.
Printing with the Internet Explorer WebBrowser Control
This sample is provided in conjunction with the MSDN Library article, 
"Printing with the Internet Explorer WebBrowser Control." 
Many developers who host the WebBrowser control want to print the control's contents programmatically.
This article discusses the options available in Microsoft Internet Explorer and reviews the most common problems.

그렇다고 웹에서 프린트를 할수가 없냐? 할수 있습니다. ActiveX를 이용해서 프린트 하는 방법이 있습니다.http://bbogi.net 이곳 주인장님이 ActiveX를 제작하셔서 예제와 VC++ 소스까지 올려놓았습니다.http://bbogi.net 참고하시구요. 여기서는 여백만 설정하는게 있는데 거기 소스보시면 가로로 출력할수 있는 해법을 찾을수 있습니다.


하지만 인증받지 않은 ActiveX로 만들고 나면 노란색 경고메세지가 뜨면서 컨포넌트를 설치하라는 메세지가 나와서 보기 않좋습니다.

이제 두번째 방법입니다. MeadCo ScriptX를 이용하는 방법입니다. MSDN사이트에서도 웹으로 프린트를 할려면 MeadCo ScriptX로 가면 해결책을 찾을수 있을거라고 하네요^^

아래는 소스 입니다. 우선 OBJECT를 선언합니다. 그리고 버튼을 클릭할때 printWindow() 함수를 호출하여 사용합니다. 소스에 주석을 달아 났으니 보면 이해될꺼에요.

# HTML 코드
<object id=factory style="display:none" 
    classid="clsid:1663ed61-23eb-11d2-b92f-008048fdd814" 
    codebase="https://www.hooni.net/ScriptX.cab#Version=6,1,429,14"> 
</object>

# Javascript 코드
<script language="javascript"> 
function printWindow() 
{
    // 머리말을 설정.
    factory.printing.header          = "This is MeadCo";
    
    // 꼬리말을 설정.
    factory.printing.footer          = "Printing by ScriptX 5.x";
    
    // 세로로 출력할것인지 가로로 출력할것인지 설정.
    // true:세로 false:가로
    factory.printing.portrait        = false;
    
    // 좌측여백
    factory.printing.leftMargin      = 1.0;
    
    // 상단여백
    factory.printing.topMargin       = 1.0;
    
    // 우측여백
    factory.printing.rightMargin     = 1.0;
    
    // 하단여백
    factory.printing.bottomMargin    = 1.0;
    
    // 한장만 출력하라는뜻
    factory.printing.copies          = 1;
    
    // 백그라운드까지 출력
    factory.printing.printBackground = true;
    
    // 현재윈도를 프린트하는뜻
    // window대신 frame을 지정하면 해당 프레임을 출력.
    factory.printing.Print(true, window);
} 
</script> 

이밗에도 인쇄미리보기,수없이 많은 기능들이 있더군요.
프린트 출력하는 곳이 상업적인 용도로 사용해야 하는 곳이면 라이센스도 생각해 보셔야 할꺼에요.
기타 다른 기술적인 부분에 대해서는 MeadCo의 Tech Docs 부분을 참고하세요.
전 이 두가지 방법 모두다 사용해 보았습니다.

하지만 가장 마지막에 선택한것은 ^^ 인쇄버튼을 클릭하면 여백을 설정하는 화면과 가로로 출력하는 방법을 설명하는 페이지를 보여주는것을 선택했습니다. MeadCo ScriptX그렇게 비싸지는 않던데 구입하기도 귀찮고 클라이언트도 출력하는 방법을 보여주는 페이지를 보니까 그대로 잘 하더라구요 

?

List of Articles
번호 분류 제목 글쓴이 날짜 조회 수
1173 Develop '2014 모바일 개발 트렌드' 발표자료입니다. file hooni 2014.10.02 986
1172 System/OS Apache CORS 설정 1 hooni 2020.09.04 2721
1171 Develop Aspect Oriented Programming in Objective-C hooni 2015.05.18 676
1170 System/OS asx미디어 정보 기록.. hooni 2003.04.23 20534
1169 System/OS CentOS 6.5 USB 설치 6 file hooni 2013.12.18 37680
1168 System/OS CentOS 에서 Cacti 설치하기 hooni 2015.01.02 1770
1167 System/OS Configure Postfix to Use Gmail SMTP on Ubuntu 18.04 file hooni 2020.02.07 1256
1166 Develop DDay Memo 1.9.4 소스코드 secret hooni 2015.10.03 0
1165 Etc EBS [수학영역] 미적분과 통계 기본 - 정규분포의 의미와 특징은? hooni 2015.04.20 1006
1164 System/OS Enable Safari Hidden Debug Menu in Mac OS X file hooni 2017.02.07 1153
1163 System/OS Enable the Develop Menu in Safari file hooni 2017.02.07 1079
1162 Develop GCM 사용하기 2 (단말에 GCM 구현하기) file hooni 2013.07.06 23248
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 98 Next
/ 98