
Estou escrevendo um algoritmo usando lstlisting :
\lstset{language=C++}
\begin{lstlisting}[frame=single,caption=Algorithme de la méthode "HOG+SVM"]
HOGDescriptor hog;\\
hog.setSVMDetector(HOGDescriptor::getDefaultPeopleDetector());\\
while(1)
{
Mat image=imread("image.jpg");
vecor<Rect> detected_persons;
hog.detectMultiScale(image,detected_persons, 0, Size(8,8), Size(32,32), 1.05, 2);
for(int i=0;i<detected_persons.size();i++)
{
rectangle(image, detected_persons[i], cv::Scalar(0,255,0),1,8,0);
}
imshow("image",image);
}
\end{lstlisting}
Mas obtive a saída deste algoritmo: mostrarComo consertar isso?
Responder1
O lstlisting
ambiente nem sempre fica agradável para longas filas, como você percebeu. Existem alternativas (por exemplo, minted
), mas você pode ajustar a lstlisting
saída para ter uma aparência melhor.
Por exemplo, o tamanho básico pode ser definido como pequeno, as linhas podem ser quebradas (e indicadas como tal), o recuo pode ser menor. O seguinte MWE foi corrigido delistagens: Definir tabsize ao usar espaços para recuo no arquivo carregado não funcionae quebra de linha lstlistinge removendo manualmente o recuo de nível superior.
\documentclass{article}
\usepackage{amsmath}
\usepackage{xcolor}
\usepackage{listings}
\lstset{
language=C++,
basicstyle=\small, % font size
breaklines=true, % line wrap
postbreak=\raisebox{0ex}[0ex][0ex]{\ensuremath{\color{red}\hookrightarrow\space}}, % arrow on wrapped lines
literate={\ \ }{{\ }}1 % adjust tab size
}
\begin{document}
\begin{lstlisting}[frame=single,caption=Algorithme de la m\'{e}thode "HOG+SVM"]
HOGDescriptor hog;
hog.setSVMDetector(HOGDescriptor::getDefaultPeopleDetector());
while(1)
{
Mat image=imread("image.jpg");
vecor<Rect> detected_persons;
hog.detectMultiScale(image,detected_persons, 0, Size(8,8), Size(32,32), 1.05, 2);
for(int i=0;i<detected_persons.size();i++)
{
rectangle(image, detected_persons[i], cv::Scalar(0,255,0),1,8,0);
}
imshow("image",image);
}
\end{lstlisting}
\end{document}