Tikz - destaque o texto em uma imagem

Tikz - destaque o texto em uma imagem

Como posso destacar o texto em uma imagem com tikz usando um retângulo e ter o resto da página preenchido com um tom cinza (ou preto opaco), veja o exemplo abaixo (retirado deaqui)?

insira a descrição da imagem aqui

Você pode ver uma captura de tela tirada do GIMP onde apenas destaco o texto usando a ferramenta seletora de retângulo. Como posso conseguir um efeito semelhante usando tikz em xetex (sem as linhas tracejadas amarelas nas bordas)?

Meu código que tenho até agora é:

\begin{tikzpicture}[remember picture, overlay]
        \node [anchor=south west,inner sep=0] (A) at (0,0) {\includegraphics[width=\linewidth, height=\paperheight]{image}}{};
        \fill [draw=none, fill=black, fill opacity=0.3]
        (0,0) -- 
        (A.north west) -- (A.north east) -- (A.south east) -- 
        (0,0) -- (0,0) -- cycle;
        \filldraw [fill=white, draw=white, fill opacity=.3] (3.2,3.2) rectangle (14.6,10.5);
    \end{tikzpicture}

O problema que encontro com este código é que preencher a página inteira com um preto opaco e preencher o retângulo com um branco opaco resulta em um cinza opaco.

Responder1

Aqui está uma receita e um aplicativo. Primeiro a receita, usandoesta resposta.

  1. Adicione uma grade no topo.
  2. Desenhe o contorno que deseja destacar.
  3. Use o contorno em um even odd rulepreenchimento (e solte a grade).

Propositalmente usei um documento no qual você pode não querer usar uma caixa horizontal.

\documentclass[tikz,border=3.14mm]{standalone}
\begin{document}
\foreach \X in {0,1,2}
{\begin{tikzpicture}
    \node[anchor=south west,inner sep=0] (image) at (0,0) 
    {\includegraphics[width=0.9\textwidth]{Dunlap_broadside_copy_of_the_United_States_Declaration_of_Independence,_LOC.jpg}};
    % ^^^ https://upload.wikimedia.org/wikipedia/commons/4/4e/Dunlap_broadside_copy_of_the_United_States_Declaration_of_Independence%2C_LOC.jpg
    \begin{scope}[x={(image.south east)},y={(image.north west)}]
      \path[use as bounding box] (-0.1,-0.1) rectangle (1,1);
       % ^^^ only for animation
      \ifnum\X<2
        \draw[help lines,xstep=.1,ystep=.1] (0,0) grid (1,1);
        \foreach \x in {0,1,...,9} { \node [anchor=north] at (\x/10,0) {0.\x}; }
        \foreach \y in {0,1,...,9} { \node [anchor=east] at (0,\y/10) {0.\y}; }
      \fi   
      \ifnum\X=1    
        \draw (0.11,0.4) -- (0.37,0.404) --  (0.37,0.414) -- (0.11,0.41) -- cycle;
      \fi
      \ifnum\X=2
        \fill[even odd rule,opacity=0.4]
        (0.11,0.4) -- (0.37,0.404) --  (0.37,0.414) -- (0.11,0.41) -- cycle
        (0,0) rectangle (1,1);
      \fi       
    \end{scope} 
\end{tikzpicture}}
\end{document}

insira a descrição da imagem aqui

Claro, no final você abandona todo o material auxiliar para chegar ao

\documentclass[tikz,border=3.14mm]{standalone}
\begin{document}
\begin{tikzpicture}
    \node[anchor=south west,inner sep=0] (image) at (0,0) 
    {\includegraphics[width=0.9\textwidth]{Dunlap_broadside_copy_of_the_United_States_Declaration_of_Independence,_LOC.jpg}};
    % ^^^ https://upload.wikimedia.org/wikipedia/commons/4/4e/Dunlap_broadside_copy_of_the_United_States_Declaration_of_Independence%2C_LOC.jpg
    \begin{scope}[x={(image.south east)},y={(image.north west)}]
        \fill[even odd rule,opacity=0.4]
        (0.11,0.4) -- (0.37,0.404) --  (0.37,0.414) -- (0.11,0.41) -- cycle
        (0,0) rectangle (1,1);
    \end{scope} 
\end{tikzpicture}
\end{document}

insira a descrição da imagem aqui

insira a descrição da imagem aqui

Se a minha escolha do texto destacado tem ou não algo a ver com um muro na fronteira com o México, não quero entrar em detalhes.

Responder2

Dependendo do formato das imagens, não é tikznecessário:

\documentclass{article}
\usepackage{graphicx,stackengine,trimclip}
\begin{document}
\stackinset{l}{150pt}{b}{130pt}{%
  \clipbox{150pt 130pt 100pt 50pt}{\includegraphics{example-image.jpg}}%
}{%
  \includegraphics[decodearray={.3 .5 .3 .5 .3 .5}]{example-image.jpg}%
}
\end{document}

insira a descrição da imagem aqui

Dependendo da paleta de cores, decodearraypode ser necessário ajustes:

\documentclass{article}
\usepackage{graphicx,stackengine,trimclip}
\begin{document}
\stackinset{l}{20pt}{b}{40pt}{%
  \clipbox{20pt 40pt 15pt 15pt}{\includegraphics{example-grid-100x100bp.png}}%
}{%
  \includegraphics[decodearray={.3 .6 .3 .6 .3 .6}]{example-grid-100x100bp.jpg}%
}
\end{document}

decodearraynão funcionará para cmykesquemas de cores e apenas para um número limitado de formatos de imagem (sendo jpeg um).

insira a descrição da imagem aqui

informação relacionada