Încerc să obțin o pictogramă fa-home într-un document pe care îl compilez folosind pdflatex. Sunt conștient că fa-home funcționează numai sub XeLaTeX. Există oricum, aș putea reproduce această pictogramă folosind desenul Tikz? Orice intrare va fi foarte apreciată.

Comentarii

  • ce ' este o pictogramă fa-home?
  • Este o comandă utilizată de font awesome sub XeLaTeX pentru a obține o pictogramă de acasă. Verificați acest lucru: fortawesome.github.io/Font-Awesome/icon/home
  • când am nevoie de un simbol aleatoriu dintr-un font iconic care nu este ' t disponibil pentru LaTeX, de obicei folosesc icomoon.io/app/#/select/library pentru a genera o .svg / .png a pictogramei dorite pentru a fi inclusă cu \includegraphics.
  • M-am gândit la asta. Cu toate acestea, nu pot obține niciodată grafica care să se potrivească cu dimensiunea textului și, mai important, să mă aliniez cu textul.
  • Am reușit să folosesc una dintre pictograme ca fișier png folosind / insertgraphics. L-am redus la 3,5 mm și așa se aliniază cu textul. Mulțumim pentru sfat.

Răspunde

Pisica ia versiunea SVG a Font Awesom copiați codul ha-home (unicode: f015) în \fill svg={...}; prin scalare (și yshifting ) folosind informațiile de la <font-face units-per-em="1792" ascent="1536" descent="-256" />. Puneți toate acestea într-o imagine și folosiți-le astfel \tikz\pic{fa-home};.

\documentclass{article} \usepackage{tikz} \usetikzlibrary{svg.path} \tikzset { fa-home/.pic = {\fill[scale=1em/1792] svg {M1408 544v-480q0 -26 -19 -45t-45 -19h-384v384h-256v-384h-384q-26 0 -45 19t-19 45v480q0 1 0.5 3t0.5 3l575 474l575 -474q1 -2 1 -6zM1631 613l-62 -74q-8 -9 -21 -11h-3q-13 0 -21 7l-692 577l-692 -577q-12 -8 -24 -7q-13 2 -21 11l-62 74q-8 10 -7 23.5t11 21.5 l719 599q32 26 76 26t76 -26l244 -204v195q0 14 9 23t23 9h192q14 0 23 -9t9 -23v-408l219 -182q10 -8 11 -21.5t-7 -23.5z};} } \begin{document} \foreach \size in {tiny,scriptsize, footnotesize, small, normalsize, large, Large, LARGE, huge, Huge} {{\csname\size\endcsname \size \ \tikz\pic{fa-home};}\par} \end{document} 

introduceți descrierea imaginii aici

Singura problemă este că atunci când compilați primiți ! Dimension too large.. O soluție posibilă este să împărțiți toate coordonatele la 1792 și apoi să le utilizați cu simple scale=1em. Iată codul final:

\documentclass{article} \usepackage{tikz} \usetikzlibrary{svg.path} \tikzset { fa-home/.pic = {\fill[scale=1em] svg {M0.786 0.304v-0.268q0.0 -0.015 -0.011 -0.025t-0.025 -0.011h-0.214v0.214h-0.143v-0.214h-0.214q-0.015 0.0 -0.025 0.011t-0.011 0.025v0.268q0.0 0.001 0.0 0.002t0.0 0.002l0.321 0.265l0.321 -0.265q0.001 -0.001 0.001 -0.003zM0.91 0.342l-0.035 -0.041q-0.004 -0.005 -0.012 -0.006h-0.002q-0.007 0.0 -0.012 0.004l-0.386 0.322l-0.386 -0.322q-0.007 -0.004 -0.013 -0.004q-0.007 0.001 -0.012 0.006l-0.035 0.041q-0.004 0.006 -0.004 0.013t0.006 0.012 l0.401 0.334q0.018 0.015 0.042 0.015t0.042 -0.015l0.136 -0.114v0.109q0.0 0.008 0.005 0.013t0.013 0.005h0.107q0.008 0.0 0.013 -0.005t0.005 -0.013v-0.228l0.122 -0.102q0.006 -0.004 0.006 -0.012t-0.004 -0.013z};} } \begin{document} \foreach \size in {tiny,scriptsize, footnotesize, small, normalsize, large, Large, LARGE, huge, Huge} { {\csname\size\endcsname \size \ \tikz\pic{fa-home};}\par } \end{document} 

Dacă doriți să utilizați informațiile descent="-256", puteți schimba cu – 256 ca acesta \fill[scale=1em/1792, yscale=-256] și apoi utilizați-l cu baseline ca acesta \tikz[baseline]\pic{fa-home}; (dacă utilizați al doilea cod, ar trebui să înlocuiți -256 cu -256/1792 = 0.14)

Răspuns

Colțuri rotunjite (și parametrizarea unghiul acoperișului) lăsat ca exercițiu …

\documentclass[varwidth,border=5]{standalone} \usepackage{tikz} \tikzset{pics/home/.style={ code={ % \fill [x=1ex/6, y=1ex/6] (-1, 3) -- (-1, 0) -- (-5, 0) -- (-5, 4) -- (0,4+5*tan 35) -- ( 5, 4) -- ( 5, 0) -- ( 1, 0) -- ( 1, 3) -- cycle (-6, 4) -- (0, 4+6*tan 35) -- ( 6, 4) -- (6+sin 35, 4+cos 35) -- ( 5, 4+1*tan 35+sec 35) -- ( 5, 4+5*tan 35+sec 35) -- ( 3, 4+5*tan 35+sec 35) -- ( 3, 4+3*tan 35+sec 35) -- ( 0, 4+6*tan 35+sec 35) -- (-6-sin 35, 4+cos 35) -- cycle; % } }} \begin{document} \foreach \f in {Huge, huge, Large, large, normalsize, small, footnotesize, scriptsize, tiny}{ \leavevmode\csname\f\endcsname\f~\tikz\pic {home};\par } \end{document} 

introduceți descrierea imaginii aici

Răspuns

De la versiunea 4.3.0 din iulie 2015, fontawesome funcționează și cu pdflatex

\documentclass{article} \usepackage{fontawesome} \usepackage{pgffor} \begin{document} \foreach \size in {tiny,scriptsize, footnotesize, small, normalsize, large, Large, LARGE, huge, Huge} { \csname\size\endcsname \size\ \faHome\par } \end{document} 

introduceți descrierea imaginii aici

Lasă un răspuns

Adresa ta de email nu va fi publicată. Câmpurile obligatorii sunt marcate cu *