[제나플러스] cheditor5 에디터 - 모바일, 파이어폭스(파폭) 색상 문제 해결 방법 > 팁앤테크

본문 바로가기
사이트 내 전체검색

팁앤테크

[제나플러스] cheditor5 에디터 - 모바일, 파이어폭스(파폭) 색상 문제 해결 방법

페이지 정보

본문

cheditor5/cheditor.js 파일에서 아래 2가지를 수정/추가합니다.

1. 수정

changeFontColor 을 찾아 코드를 수정합니다. (빨강색 부분만 수정)


changeFontColor : function (color, type) {
 if (type == 'BackColor' && !GB.browser.msie) {
  type = 'HiliteColor';
 }
 this.doCmdPopup(type, this.colorConvert(color, 'hex'));
},


2. 추가

위 changeFontColor 코드  아래에 추가합니다. (사실 순서는 상관없습니다. 편한 곳에 붙여주세요,위아래 콤마주의)

changeFontColor : function (color, type) {  
 if (type == 'BackColor' && !GB.browser.msie) {
  type = 'HiliteColor';
 }
 this.doCmdPopup(type, this.colorConvert(color, 'hex'));
},
colorConvert : function (color, which, opacity) {
    if (!which) {
        which = "rgba";
 }
 
    color = color.replace( /^\s*#|\s*$/g, "" );
 if (color.length === 3) {
        color = color.replace( /(.)/g, "$1$1" );
 }
 
    color = color.toLowerCase();
 which = which.toLowerCase();
    
 var colorDefs = [{
        re: /^rgb\((\d{1,3}),\s*(\d{1,3}),\s*(\d{1,3})\)$/,
            process: function (bits) {
                return [
                    parseInt(bits[1], 10),
                    parseInt(bits[2], 10),
                    parseInt(bits[3], 10),
                    1
                ];
            }
        },
        {
            re : /^rgba\((\d{1,3}),\s*(\d{1,3}),\s*(\d{1,3}),\s*(\d+(?:\.\d+)?|\.\d+)\s*\)/,
            process: function (bits) {
                return [
                    parseInt(bits[1], 10),
                    parseInt(bits[2], 10),
                    parseInt(bits[3], 10),
                    parseFloat(bits[4])
                ];
            }
        },
        {
            re: /^([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/,
            process: function (bits) {
                return [
                    parseInt(bits[1], 16),
                    parseInt(bits[2], 16),
                    parseInt(bits[3], 16),
                    1
                ];
            }
        },
        {
            re: /^([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/,
            process: function (bits) {
                return [
                    parseInt(bits[1] * 2, 16),
                    parseInt(bits[2] * 2, 16),
                    parseInt(bits[3] * 2, 16),
                    1
                ];
            }
        }
    ];
    var r, g, b, a, i, re, processor, bits, channels, min, rData;
            
    for (i = 0; i < colorDefs.length; i++) {
        re = colorDefs[i].re;
        processor = colorDefs[i].process;
        bits = re.exec(color);
        if (bits) {
            channels = processor(bits);
            r = channels[0];
            g = channels[1];
            b = channels[2];
            a = channels[3];
        }
    }
    
    r = (r < 0 || isNaN(r)) ? 0 : ((r > 255) ? 255 : r);
    g = (g < 0 || isNaN(g)) ? 0 : ((g > 255) ? 255 : g);
    b = (b < 0 || isNaN(b)) ? 0 : ((b > 255) ? 255 : b);
    a = (a < 0 || isNaN(a)) ? 0 : ((a > 1) ? 1 : a);
    
    function hex(x) {
        return ("0" + parseInt(x).toString(16)).slice(-2);
    }
    
    switch (which) {
        case "rgba":
            if (opacity) {
                a = (255 - (min = Math.min(r, g, b))) / 255;
                r = (0 || (r - min) / a).toFixed(0);
                g = (0 || (g - min) / a).toFixed(0);
                b = (0 || (b - min) / a).toFixed(0);
                a = a.toFixed(4);
            }
            rData = "rgba(" + r + "," + g + "," + b + "," + a + ")";
            break;
        case "rgb":
            rData = "rgb(" + r + "," + g + "," + b + ")";
            break;
        case "hex":
            rData = "#" + hex(r) + hex(g) + hex(b);
            break;
    }
    return rData;
},

getElement : function (elem, tag) { // 다른 함수일 수도 있어요.
     while (elem != null && elem.tagName != tag) {
          if (elem.nodeName == 'BODY') break;
          elem = elem.parentNode;
     }
     return elem;
},
추천0

댓글목록

등록된 댓글이 없습니다.

Total 285건 11 페이지
  • RSS
팁앤테크 목록
번호 제목 글쓴이 조회 추천 날짜
35 제로쪽지보내기 메일보내기 홈페이지 자기소개 아이디로 검색 전체게시물 18124 0 05-08
34 제로쪽지보내기 메일보내기 홈페이지 자기소개 아이디로 검색 전체게시물 18212 0 11-26
33 제로쪽지보내기 메일보내기 홈페이지 자기소개 아이디로 검색 전체게시물 35009 0 09-14
32 제로쪽지보내기 메일보내기 홈페이지 자기소개 아이디로 검색 전체게시물 22264 0 04-25
31 제로쪽지보내기 메일보내기 홈페이지 자기소개 아이디로 검색 전체게시물 19613 0 11-16
30 제로쪽지보내기 메일보내기 홈페이지 자기소개 아이디로 검색 전체게시물 18075 0 04-10
29 제로쪽지보내기 메일보내기 홈페이지 자기소개 아이디로 검색 전체게시물 21836 0 05-19
28 제로쪽지보내기 메일보내기 홈페이지 자기소개 아이디로 검색 전체게시물 19898 0 06-29
27 제로쪽지보내기 메일보내기 홈페이지 자기소개 아이디로 검색 전체게시물 21523 0 11-05
26 제로쪽지보내기 메일보내기 홈페이지 자기소개 아이디로 검색 전체게시물 18928 0 01-16
25 제로쪽지보내기 메일보내기 홈페이지 자기소개 아이디로 검색 전체게시물 16205 0 04-18
24 제로쪽지보내기 메일보내기 홈페이지 자기소개 아이디로 검색 전체게시물 19568 0 05-06
23 제로쪽지보내기 메일보내기 홈페이지 자기소개 아이디로 검색 전체게시물 29048 0 08-06
22 제로쪽지보내기 메일보내기 홈페이지 자기소개 아이디로 검색 전체게시물 18140 0 09-19
21 제로쪽지보내기 메일보내기 홈페이지 자기소개 아이디로 검색 전체게시물 16328 0 12-12
20 제로쪽지보내기 메일보내기 홈페이지 자기소개 아이디로 검색 전체게시물 19007 0 11-28
19 제로쪽지보내기 메일보내기 홈페이지 자기소개 아이디로 검색 전체게시물 16102 0 05-18
18 제로쪽지보내기 메일보내기 홈페이지 자기소개 아이디로 검색 전체게시물 17430 0 11-26
17 제로쪽지보내기 메일보내기 홈페이지 자기소개 아이디로 검색 전체게시물 17237 0 05-04
16 제로쪽지보내기 메일보내기 홈페이지 자기소개 아이디로 검색 전체게시물 38690 0 09-19
열람중 제로쪽지보내기 메일보내기 홈페이지 자기소개 아이디로 검색 전체게시물 20909 0 10-16
14 제로쪽지보내기 메일보내기 홈페이지 자기소개 아이디로 검색 전체게시물 17296 1 05-21
13 제로쪽지보내기 메일보내기 홈페이지 자기소개 아이디로 검색 전체게시물 18379 1 05-06
12 제로쪽지보내기 메일보내기 홈페이지 자기소개 아이디로 검색 전체게시물 23607 1 05-10
11 제로쪽지보내기 메일보내기 홈페이지 자기소개 아이디로 검색 전체게시물 25534 1 05-11

검색

회원로그인

회원가입

사이트 정보

株式会社YHPLUS / 대표 : ZERO
〒140-0011 東京都品川区東大井2-5-9-203
050-5539-7787
오픈카카오톡 (YHPLUS) :
https://open.kakao.com/o/slfDj15d

접속자집계

오늘
3,167
어제
5,045
최대
9,679
전체
2,617,545
Copyright (c) 株式会社YHPLUS. All rights reserved.