add support for 'color and 'bgcolor styles
svn: r8064 original commit: e4a588e40563e8ddf71bc7200e9adf602b17bb44
This commit is contained in:
parent
18d1528808
commit
c46667ae55
|
@ -432,15 +432,26 @@
|
||||||
[(string? style)
|
[(string? style)
|
||||||
`((span ([class ,style]) ,@(super render-element e part ri)))]
|
`((span ([class ,style]) ,@(super render-element e part ri)))]
|
||||||
[(and (pair? style)
|
[(and (pair? style)
|
||||||
(eq? (car style) 'show-color))
|
(or (eq? (car style) 'bg-color)
|
||||||
`((font ((style ,(format "background-color: ~a"
|
(eq? (car style) 'color)))
|
||||||
(apply string-append "#"
|
(unless (and (list? style)
|
||||||
(map (lambda (v) (let ([s (format "0~x" v)])
|
(or (and (= 4 (length style))
|
||||||
(substring s (- (string-length s) 2))))
|
(andmap byte? (cdr style)))
|
||||||
(cdr style))))))
|
(and (= 2 (length style))
|
||||||
(tt nbsp nbsp nbsp nbsp nbsp))
|
(member (cadr style)
|
||||||
nbsp
|
'("white" "black" "red" "green" "blue" "cyan" "magenta" "yellow")))))
|
||||||
,@(super render-element e part ri))]
|
(error 'render-font "bad color style: ~e" style))
|
||||||
|
`((font ((style ,(format "~acolor: ~a"
|
||||||
|
(if (eq? (car style) 'bg-color)
|
||||||
|
"background-"
|
||||||
|
"")
|
||||||
|
(if (= 2 (length style))
|
||||||
|
(cadr style)
|
||||||
|
(apply string-append "#"
|
||||||
|
(map (lambda (v) (let ([s (format "0~x" v)])
|
||||||
|
(substring s (- (string-length s) 2))))
|
||||||
|
(cdr style)))))))
|
||||||
|
,@(super render-element e part ri)))]
|
||||||
[(target-url? style)
|
[(target-url? style)
|
||||||
(if (current-no-links)
|
(if (current-no-links)
|
||||||
(super render-element e part ri)
|
(super render-element e part ri)
|
||||||
|
|
|
@ -68,7 +68,11 @@
|
||||||
(printf "\\newcommand{\\smaller}[1]{{\\footnotesize #1}}\n")
|
(printf "\\newcommand{\\smaller}[1]{{\\footnotesize #1}}\n")
|
||||||
(printf "\\definecolor{PaleBlue}{rgb}{0.90,0.90,1.0}\n")
|
(printf "\\definecolor{PaleBlue}{rgb}{0.90,0.90,1.0}\n")
|
||||||
(printf "\\definecolor{LightGray}{rgb}{0.90,0.90,0.90}\n")
|
(printf "\\definecolor{LightGray}{rgb}{0.90,0.90,0.90}\n")
|
||||||
(printf "\\newcommand{\\schemeinput}[1]{\\colorbox{LightGray}{\\hspace{-0.5ex}\\schemeinputbg{#1}\\hspace{-0.5ex}}}\n")
|
(printf "\\newcommand{\\intextcolor}[2]{\\textcolor{#1}{#2}}\n")
|
||||||
|
(printf "\\newcommand{\\intextrgbcolor}[2]{\\textcolor[rgb]{#1}{#2}}\n")
|
||||||
|
(printf "\\newcommand{\\incolorbox}[2]{{\\fboxrule=0pt\\fboxsep=0pt\\colorbox{#1}{#2}}}\n")
|
||||||
|
(printf "\\newcommand{\\inrgbcolorbox}[2]{{\\fboxrule=0pt\\fboxsep=0pt\\colorbox[rgb]{#1}{#2}}}\n")
|
||||||
|
(printf "\\newcommand{\\schemeinput}[1]{\\incolorbox{LightGray}{\\schemeinputbg{#1}}}\n")
|
||||||
(printf "\\newcommand{\\highlighted}[1]{\\colorbox{PaleBlue}{\\hspace{-0.5ex}\\schemeinputbg{#1}\\hspace{-0.5ex}}}\n")
|
(printf "\\newcommand{\\highlighted}[1]{\\colorbox{PaleBlue}{\\hspace{-0.5ex}\\schemeinputbg{#1}\\hspace{-0.5ex}}}\n")
|
||||||
(printf "\\newcommand{\\plainlink}[1]{#1}\n")
|
(printf "\\newcommand{\\plainlink}[1]{#1}\n")
|
||||||
(printf "\\newcommand{\\techlink}[1]{#1}\n")
|
(printf "\\newcommand{\\techlink}[1]{#1}\n")
|
||||||
|
@ -175,6 +179,23 @@
|
||||||
[else (error 'latex-render "unrecognzied style symbol: ~s" style)])]
|
[else (error 'latex-render "unrecognzied style symbol: ~s" style)])]
|
||||||
[(string? style)
|
[(string? style)
|
||||||
(wrap e style (regexp-match? #px"^scheme(?!error)" style))]
|
(wrap e style (regexp-match? #px"^scheme(?!error)" style))]
|
||||||
|
[(and (pair? style)
|
||||||
|
(or (eq? (car style) 'bg-color)
|
||||||
|
(eq? (car style) 'color)))
|
||||||
|
(wrap e (format "~a{~a}"
|
||||||
|
(format (if (eq? (car style) 'bg-color)
|
||||||
|
"in~acolorbox"
|
||||||
|
"intext~acolor")
|
||||||
|
(if (= (length style) 2)
|
||||||
|
""
|
||||||
|
"rgb"))
|
||||||
|
(if (= (length style) 2)
|
||||||
|
(cadr style)
|
||||||
|
(format "~a,~a,~a"
|
||||||
|
(/ (cadr style) 255.0)
|
||||||
|
(/ (caddr style) 255.0)
|
||||||
|
(/ (cadddr style) 255.0))))
|
||||||
|
#f)]
|
||||||
[(image-file? style)
|
[(image-file? style)
|
||||||
(let ([fn (install-file (image-file-path style))])
|
(let ([fn (install-file (image-file-path style))])
|
||||||
(printf "\\includegraphics{~a}" fn))]
|
(printf "\\includegraphics{~a}" fn))]
|
||||||
|
|
|
@ -342,6 +342,19 @@ The @scheme[style] field is normally either
|
||||||
@scheme['subscript], @scheme['superscript], or
|
@scheme['subscript], @scheme['superscript], or
|
||||||
@scheme['hspace];}
|
@scheme['hspace];}
|
||||||
|
|
||||||
|
@item{a list of the form @scheme[(list 'color _name)] or
|
||||||
|
@scheme[(list 'color _byte _byte _byte)] to set the text color,
|
||||||
|
where @scheme[_name] is one of @scheme["white"],
|
||||||
|
@scheme["black"], @scheme["red"], @scheme["green"],
|
||||||
|
@scheme["blue"], @scheme["cyan"], @scheme["magenta"], or
|
||||||
|
@scheme["yellow"], or three @scheme[_byte]s specify RGB
|
||||||
|
values;}
|
||||||
|
|
||||||
|
@item{a list of the form @scheme[(list 'bg-color _name)] or
|
||||||
|
@scheme[(list 'bg-color _byte _byte _byte)] to set the text
|
||||||
|
background color (with the same constraints and meanings as for
|
||||||
|
@scheme['color]);}
|
||||||
|
|
||||||
@item{an instance of @scheme[target-url] to generate a hyperlink; or}
|
@item{an instance of @scheme[target-url] to generate a hyperlink; or}
|
||||||
|
|
||||||
@item{an instance of @scheme[image-file] to support an inline image.}
|
@item{an instance of @scheme[image-file] to support an inline image.}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user