\documentclass[a4paper]{ltxdoc}% \usepackage[english]{babel}% \usepackage[latin1]{inputenc}% \usepackage[T1]{fontenc}% \usepackage{textcomp}% \usepackage{lmodern}% \usepackage{bera}% \usepackage{ccicons} \usepackage{microtype}% \usepackage{ltxdocext}% \usepackage{listings} \usepackage{marginnote}% \usepackage[svgnames,rgb]{xcolor}% \usepackage[automark,nouppercase]{scrpage2} \usepackage[width=4cm,shipcolor=Teal,scale=0.66,fontsize=large, sbindent=0.6cm,sbwidth=3.4cm]{battleship}% \usepackage{hyperref} % \setlength{\headheight}{1.1\baselineskip}% % \hypersetup{colorlinks=true,urlcolor=NavyBlue,linkcolor=NavyBlue,citecolor=CornflowerBlue,naturalnames=true,hypertexnames=false}% \lstset{language=[LaTeX]TeX,numbers=left,numberstyle=\tiny,basicstyle=\ttfamily\small,frame=single,backgroundcolor=\color{LightGoldenrodYellow},keywordstyle=\color{Blue},emph={mathstyle,style}, emphstyle=\color{Tomato},emph={[2]rows,columns,width,shipcolor,fontsize,scale,sbindent,sbwidth,sbshipscale},emphstyle={[2]\color{SeaGreen}},morekeywords={titleformat,definecounterstyle,marginnote,tikz,node,puzzlecounter,color,battleship,,placeship,placesegment,ship,shipH,shipV,shipbox,Ship,ShipC,ShipL,ShipR,ShipB,ShipT,[,]}} \makeatletter \renewcommand{\maketitle}% {% \thispagestyle{empty}% \pagecolor{Ivory}% \begin{titlepage}% \begin{tikzpicture}[remember picture,overlay]% \node[yshift=-2cm] at (current page.north west)% {% \begin{tikzpicture}[remember picture, overlay]% \draw[fill=CornflowerBlue,color=CornflowerBlue] (0,0) rectangle% (\paperwidth,2cm);% \draw[anchor=west,yshift=-4cm,xshift=3cm,color=NavyBlue] (0,0) node% {\parbox{15cm}{\RaggedRight\Huge\sffamily\textbf{\@title}}};% \draw[anchor=west,yshift=-6cm,xshift=3cm,color=NavyBlue] (0,0) node% {\parbox{15cm}{\huge\sffamily\textbf{\@fileversion}}};% \draw[anchor=west,yshift=-9cm,xshift=3cm,color=NavyBlue] (0,0) node% {\parbox{15cm}{\RaggedRight\huge\sffamily\textbf{\@subtitle}}};% \draw[anchor=west,yshift=-13cm,xshift=3cm,color=NavyBlue] (0,0) node% {\includegraphics[height=5cm]{logo.png}};% \draw[anchor=west,yshift=-17cm,xshift=3cm,color=NavyBlue] (0,0) node% {\parbox{15cm}{\huge\sffamily\textbf{\@date}}};% \draw[anchor=west,yshift=-20cm,xshift=3cm,color=NavyBlue] (0,0) node% {\parbox{15cm}{\Large\sffamily{\@authorline\\\textbf{\@author}}}};% \end{tikzpicture}% };% \node[yshift=0cm] at (current page.south west)% {% \begin{tikzpicture}[remember picture, overlay]% \draw[fill=NavyBlue,color=NavyBlue,yshift=6cm,xshift=2cm] (0,0) rectangle (0.2cm,19cm);% \draw[fill=CornflowerBlue,color=CornflowerBlue] (0,0) rectangle (\paperwidth,2cm);% \draw[anchor=west,yshift=1cm,xshift=3cm,color=NavyBlue] (0,0) node% {\parbox{15cm}{\large\sffamily{\@refline}}};% \end{tikzpicture}% };% \end{tikzpicture}% \end{titlepage}% \pagecolor{white}% }% % \newcommand*{\@tikzhead}[1]% {% \begin{tikzpicture}[remember picture,overlay]% \node[yshift=-2cm] at (current page.north west)% {% \begin{tikzpicture}[remember picture, overlay]% \draw[fill=CornflowerBlue] (0,0) rectangle (\paperwidth,2cm);% \draw[anchor=west,yshift=1cm,xshift=1.5cm,color=NavyBlue] (0,0) node% {\parbox{15cm}{\LARGE\sffamily\textbf{\@title}}};% \node[anchor=east,xshift=.9\paperwidth,rectangle,% rounded corners=15pt,inner sep=11pt,fill=NavyBlue]% {\color{white}\textsc{#1}};% \end{tikzpicture}% };% \end{tikzpicture}% }% \clearscrheadings% \ihead{\@tikzhead{\headmark}}% \cfoot{\upshape\thepage}% \pagestyle{scrheadings}% % %\newcommand*{\headline}[1]{\@mkboth{\MakeUppercase{#1}}{\MakeUppercase{#1}}}% \newcommand*{\Headline}[1]{\@mkboth{#1}{#1}}% % \renewcommand{\headfont}{\normalfont\mdseries\scshape} % \gdef\@subtitle{}% \providecommand*{\Subtitle}[1]{\gdef\@subtitle{#1}}% \gdef\@fileversion{}% \providecommand*{\Fileversion}[1]{\gdef\@fileversion{#1}}% \gdef\@author{}% \providecommand*{\Author}[1]{\gdef\@author{#1}}% \gdef\@authorline{Package author:}% \providecommand*{\Authorline}[1]{\gdef\@authorline{#1}}% \gdef\@refline{}% \providecommand*{\Refline}[1]{\gdef\@refline{#1}}% \gdef\and{\unskip{}, }% \newcommand\doubledash{-\kern0.5pt-} \def\enoteformat{\rightskip\z@ \leftskip\z@ \parindent=1em\leavevmode\llap{\makeenmark}} \makeatother % \def\filename{battleship.sty}% \def\XeLaTeX{Xe\LaTeX}% % \makeatletter% \renewcommand\tableofcontents% {% %\section*{\contentsname}% \@mkboth{% \MakeUppercase\contentsname}{\MakeUppercase\contentsname}% \@starttoc{toc}% }% % \newcommand\styleoption{\name@idx{style option}}% \newcommand\stylename{\name@idx{document style}}% \def\name@idx#1#2{% {\ttfamily#2}% \index{#2\space#1=\string\ttt{#2}\space#1}\index{#1>#2=\string\ttt{#2}}% }% \newcommand*\margcs[1]{\marginnote{\raggedleft\scriptsize #1}}% \newcommand*\package[1]{\texttt{#1}\index{#1=\string\ttt{#1}}}% \newcommand*\mco[1]{\mbox{\LANGLE\itshape#1\RANGLE}\index{#1, class option value}\index{class option value>#1}}% % \renewcommand\@biblabel[1]{\makebox[1.5cm][l]{[#1]}} \renewcommand*\l@subsection{\@dottedtocline{2}{1.2em}{2.8em}} \renewcommand*\l@subsubsection{\@dottedtocline{3}{2.4em}{3.7em}} \makeatother % \setlength\parindent{0pt}% \hypersetup{pdfauthor={Josef Kleber},pdftitle={A style file for typesetting Battleship logic puzzles},pdfsubject={Documentation for LaTeX style \filename}}% % \begin{document} \title{\filename}% \Subtitle{A style file for typesetting Battleship logic puzzles}% \author{Josef Kleber} \Fileversion{v1.2} \Refline{\href{mailto:josef.kleber@gmx.de}{\texttt{josef.kleber@gmx.de}}\\\href{https://bitbucket.org/kleberj/battleship/}{\texttt{https://bitbucket.org/kleberj/battleship/}}} \maketitle \tableofcontents \clearpage \section{The puzzle} Try to find the positions of the ships listed below the puzzle. The numbers on the side of the puzzle reveals how many ship segments can be found in the rows and columns. All remaining fields indicate 'water'. Consider the following rules: The ships are arranged horizontally and vertically. No ship touches another ship at any point, not even diagonally. Here's a little self-explanatory example: \begin{center} \begin{battleship} \placesegment{4}{1}{\ShipR} \shipH{4,1,2,2,2} \shipV{3,1,4,0,3} \shipbox{3,3,2,2,1} \end{battleship} \hspace{1cm} \begin{battleship} \placeship{V}{1}{1}{3} \placeship{H}{1}{5}{2} \placeship{H}{3}{1}{2} \placeship{H}{3}{3}{3} \placeship{H}{5}{5}{1} \shipH{4,1,2,2,2} \shipV{3,1,4,0,3} \end{battleship} \end{center} \bigskip \begin{lstlisting} \begin{center} \begin{battleship} \placesegment{4}{1}{\ShipR} \shipH{4,1,2,2,2} \shipV{3,1,4,0,3} \shipbox{3,3,2,2,1} \end{battleship} \hspace{1cm} \begin{battleship} \placeship{V}{1}{1}{3} \placeship{H}{1}{5}{2} \placeship{H}{3}{1}{2} \placeship{H}{3}{3}{3} \placeship{H}{5}{5}{1} \shipH{4,1,2,2,2} \shipV{3,1,4,0,3} \end{battleship} \end{center} \end{lstlisting} \clearpage \section{Options} \subsection[\texttt{rows}]{\styleoption{rows} (\underline{\texttt{5}})} With the option \styleoption{rows}, you can define the number of rows in the grid. \subsection[\texttt{columns}]{\styleoption{columns} (\underline{\texttt{5}})} With the option \styleoption{columns}, you can specify the number of columns in the grid \subsection[\texttt{shipcolor}]{\styleoption{shipcolor} (\underline{\texttt{green}})} With the option \styleoption{shipcolor}, you can set the color of the ship segments. \subsection[\texttt{width}]{\styleoption{width} (\underline{\texttt{6cm}})} With the option \styleoption{width}, you can set the width of the minipage, in which the grid is typeset. \subsection[\texttt{scale}]{\styleoption{scale} (\underline{\texttt{1}})} With the option \styleoption{scale}, you can scale the size of the grid in the minipage. \subsection[\texttt{fontsize}]{\styleoption{fontsize} (\underline{\texttt{Large}})} With the option \styleoption{fontsize}, you can specify the size of the numbers next to the grid. Here, the usual \LaTeX\ sizes are used. Possible values: \texttt{tiny}, \texttt{scriptsize}, \texttt{footnotesize}, \texttt{small}, \texttt{normalsize}, \texttt{large}, \underline{\texttt{Large}}, \texttt{LARGE}, \texttt{huge}, \texttt{Huge}) \subsection[\texttt{title}]{\styleoption{title} (\underline{\texttt{\{\}}})} With the option \styleoption{title}, you can specify the title of a puzzle. \subsection[\texttt{counterstyle}]{\styleoption{counterstyle} (\underline{\texttt{none}}),left,right} With the option \styleoption{counterstyle}, you can define the counter style. \subsection[\texttt{bgcolor}]{\styleoption{bgcolor} (\underline{\texttt{\{\}}})} With the option \styleoption{bgcolor}, you can set the background color of the grid. \subsection[\texttt{sbindent}]{\styleoption{sbindent} (\underline{\texttt{0.75cm}})} With the option \styleoption{sbindent}, you can define the indent of the ship box below the grid. \subsection[\texttt{sbwidth}]{\styleoption{sbwidth} (\underline{\texttt{5.15cm}})} With the option \styleoption{sbwidth}, you can specify the width of the minipage, in which the ships are typeset. \subsection[\texttt{sbshipscale}]{\styleoption{sbshipscale} (\underline{\texttt{1}})} With the option \styleoption{sbshipscale}, you can scale the size of the ships in the ship box. \section{Environments} \subsection{\texttt{battleship}} The \env{battleship} environment\marginnote{\hbadness=10000\RaggedLeft\scriptsize\envb{battleship}\oarg{options}\\\dots\\\enve{battleship}} is the central core of the style file. With the optional argument of the environment, you can reset the options with local scope. Here, a blank grid is created that you can fill with ships using other commands. \section{Commands} \subsection{Ships, water, islands, ...} \subsubsection{\texttt{placeship}} With the command \cs{placeship}\margcs{\cmd\placeship\{\marg{direction}\}\\\{\marg{column}\}\{\marg{row}\}\{\marg{length}\}} you can place complete ships in the grid. It expects the specification of the direction as horizontal (H) or vertical (V). Furthermore, it requires the starting coordinates and the length of the ship. \subsubsection{\texttt{placesegment}} The command \cs{placesegment}\margcs{\cmd\placesegment\{\marg{column}\}\{\marg{row}\}\\\{\marg{ship segment}\}} is used for the placement of ship segments in the grid. In the mandatory argument \marg{ship segment}, you can use the following commands: \begin{center} \begin{tabular}{lccl} \cs{Ship} & \scalebox{.5}{\Ship} & \scalebox{.5}{\ShipC} & \cs{ShipC} \\ \cs{ShipL} & \scalebox{.5}{\ShipL} & \scalebox{.5}{\ShipR} & \cs{ShipR} \\ \cs{ShipB} & \scalebox{.5}{\ShipB} & \scalebox{.5}{\ShipT} & \cs{ShipT} \\ \end{tabular} \end{center} \subsubsection{\texttt{ship}} The command \cs{ship} was replaced by the \cs{placesegment} command. The command \cs{ship} is deprecated and should not be used longer. It may still be used, but it is not recommended. \subsubsection{\texttt{placewater}} With the command \cs{placewater}\margcs{\cmd\placewater\{\marg{column}\}\{\marg{row}\}} you can place water markers ( \raisebox{2pt}{\Water} ) in the grid. \subsubsection{\texttt{placeisland}} With the command \cs{placeisland}\margcs{\cmd\placeisland\{\marg{column}\}\{\marg{row}\}} you can place islands ( \raisebox{-2pt}{\resizebox{!}{10pt}{\Island}} ) in the grid. The island outlines are created randomly: \raisebox{-2pt}{\resizebox{!}{10pt}{\Island}}, \raisebox{-2pt}{\resizebox{!}{10pt}{\Island}}, \raisebox{-2pt}{\resizebox{!}{10pt}{\Island}}, ... \subsection{Presentation} \subsubsection{\texttt{shipH}} The command \cs{shipH}\margcs{\cmd\shipH\{\marg{csv list}\}} typesets the horizontal numbers above the grid. It expects a comma-separated list as an argument. \subsubsection{\texttt{shipV}} The command \cs{shipV}\margcs{\cmd\shipV\{\marg{csv list}\}} typesets the vertical numbers beside the grid. It also expects a comma separated list. \subsubsection{\texttt{shipbox}} The command \cs{shipbox}\margcs{\cmd\shipbox\{\marg{csv list}\}} defines the number and size of the ships, which are typeset under the grid. \subsubsection{\texttt{definecounterstyle}} The command \cs{definecounterstyle}\margcs{\cmd\definecounterstyle\{\marg{name}\}\\\{\marg{definition}\}} allows you to define your own styles. For example, the style \texttt{left} is defined as follows: \begin{lstlisting} \definecounterstyle{left}{ \begingroup\reversemarginpar\marginnote{ \tikz\node[shape=rectangle,fill=yellow!40,inner sep=7pt, draw,rounded corners=3pt,thick] {\Huge\puzzlecounter};}[-23pt]\endgroup } \end{lstlisting} To typeset the counter into the margin we use the command \cmd\marginnote. We need to use the command \cmd\reversemarginpar\ to set the counter into the left margin. Of course, we must use this command in a group for local scope. Finally we use \cmd\puzzlecounter\ in a \cmd\tikz\ node with a vertical offset of 23 points. \subsubsection{\texttt{puzzlecounter}} The command \cs{puzzlecounter}\margcs{\cmd\puzzlecounter} provides the counter in textual form to use it for example in \cmd\definecounterstyle. \subsubsection{\texttt{titleformat}} With the command \cs{titleformat}\margcs{\cmd\titleformat\{\marg{format}\}}, you can define the format of the title. By default, the definition is as follows: \begin{lstlisting} \titleformat{\centering\Large\color{blue}} \end{lstlisting} \subsection{Miscellaneous} \subsubsection{\texttt{battleshipsetup}} With the command \cs{battleshipsetup}\margcs{\cmd\battleshipsetup\{\marg{options}\}} you can reset the options with global scope. \subsubsection{\texttt{classicgame}} The command \cs{classicgame}\margcs{\cmd\classicgame\{\marg{csv list}\}} typesets a game sheet for playing classic Battleship. It expects a comma separated list with the number and sizes of the ships. \subsubsection{\texttt{setpuzzlecounter}} With the command \cs{setpuzzlecounter}\margcs{\cmd\setpuzzlecounter\{\marg{number}\}}, you can reset the puzzle counter, for example before the solutions. \section{Examples \& Solutions} You\marginnote{\includegraphics[height=2cm]{qrcode.png}} can download application examples and their solutions from the \href{https://bitbucket.org/kleberj/battleship/}{project page}. The puzzles are originally licensed under \href{http://creativecommons.org/licenses/by-nc-sa/3.0/}{\ccbyncsa}. You can also download a \href{https://bitbucket.org/kleberj/battleship/downloads/classicsheet.pdf}{game sheet} for playing the classic Battleship. \end{document}