Mich hätte interessiert, wie ich das

% How to make this better? \newcommand{\Chapter}[2][\thechapter]{ \chapter{#2}\label{ch:#1}% \addthumb{#2}{% \space\Large\sffamily\bfseries\thechapter}{white}{black} }

für den normalen Befehl \chapter[short]{long} hinbekomme, also so dass ich nicht \Chapter verwenden muss.

alt text

\documentclass[ngerman, fontsize=9pt, paper=a5]{scrreprt}
\usepackage{thumbs}

% How to make this better?
\newcommand{\Chapter}[2][\thechapter]{
\chapter{#2}\label{ch:#1}%
\addthumb{#2}{%
\space\Large\sffamily\bfseries\thechapter}{white}{black}
}

\usepackage{mwe}
\begin{document}
\pagenumbering{arabic} %thumbs needs that?!

\Chapter{Chapter 1}
\section{Very important section}
\lipsum[1]

\Chapter{Chapter 2}
\lipsum[1-2]
\end{document}

gefragt 03 Jun '19, 19:38

cis's gravatar image

cis
9.5k95459491
Akzeptiert-Rate: 29%

bearbeitet 03 Jun '19, 19:46

Für so was gibt's titlesec.

(04 Jun '19, 01:18) Community

Was soll den bei \addchap und den Sternformen passieren? Die setzen zwar mit dem Beispiel keinen neuen, eigenen Thumb, aber die Seiten bekommen den des vorherigen Kapitels.

(06 Jun '19, 14:01) esdd

Ich würde entweder den KOMA-Autor um einen geeigneten Hook bitten, oder einen internen Befehl patchen (das Inhaltsverzeichnis bekommt dabei bewusst keinen Thumb). Meiner Ansicht nach, ist es keine gute Idee, automatisiert ein label zu setzen - wenn du die Kapitel umbenennst oder umstellst, fliegen dir die Referenzen um die Ohren.

\documentclass[ngerman, fontsize=9pt, paper=a5]{scrreprt}
\usepackage{thumbs}
\usepackage[T1]{fontenc}
\usepackage{xpatch,expl3}
\ExplSyntaxOn\makeatletter
\cs_new_protected:Npn \addthumbstochapter #1
 {
  \int_compare:nNnTF { \c@secnumdepth } < { \chapternumdepth }
   { %für \addchap ??
    \addthumb{#1}{%
    \space\Large\sffamily\bfseries ??}{white}{black}
   }
   { %für \chapter
    \addthumb{#1}{%
    \space\Large\sffamily\bfseries \thechapter}{white}{black}}
 }
\ExplSyntaxOff
\patchcmd\scr@@startchapter
 {\@afterheading}
 {\@afterheading
  \addthumbstochapter{#2}%
 }
 {}
 {\fail}
\makeatother
\usepackage{mwe}
\begin{document}
\pagenumbering{arabic}
\tableofcontents
\chapter[short]{Chapter 1 \label{short}}
\section{Very important section}
\lipsum[1] \ref{short},\ref{Chapter 2}

\chapter{Chapter 2 \label{Chapter 2}}
\lipsum[1-2]

\addchap{addchap}
\end{document}
Permanenter link

beantwortet 04 Jun '19, 16:25

Ulrike%20Fischer's gravatar image

Ulrike Fischer
3.6k23
Akzeptiert-Rate: 52%

bearbeitet 05 Jun '19, 09:57

cis's gravatar image

cis
9.5k95459491

@UlrikeFischer Ok, kannst Du bitte das label als opt. Argument wieder rausnehmen?

(04 Jun '19, 21:29) cis
1

label{ch:\thechapter} ist komplett nutzlos.

(05 Jun '19, 07:51) Johannes

Diese Änderung zieht natürlich dann das Vergeben von Labels nach sich. Das habe ich jetzt mal geändert.

(05 Jun '19, 09:58) cis

Von einem Befehl mit mehreren direkt aufeinander folgenden optionalen Argument würde ich abraten, die Implementierung wäre nicht hübsch. Ich würde zu Folgendem raten:

EDIT: Ich habe die gesternte Form von \chapter vergessen, deshalb funktionieren Befehle wie \tableofcontents nicht, hier also eine korrigierte Implementierung:

\documentclass[ngerman, fontsize=9pt, paper=a5]{scrreprt}
\usepackage{thumbs}

\usepackage{letltxmacro}
\usepackage{xparse}

\LetLtxMacro\chapterORIG\chapter
\RenewDocumentCommand \chapter { s o m o }
  {%
    \IfBooleanTF{#1}
      {\stopthumb\chapterORIG*}
      {%
        \cleardoublepage
        \addthumb{#3}{\Large\sffamily\bfseries\thechapter}{white}{black}%
        \IfValueTF{#2}
          {\chapterORIG[#2]}
          {\chapterORIG}%
      }%
      {#3\IfValueT{#4}{\label{#4}}}%
  }

\usepackage{mwe}
\begin{document}
\tableofcontents
\pagenumbering{arabic} %thumbs needs that?!

\chapter{Chapter 1}
\section{Very important section}
\lipsum[1]

Reference: \ref{label2}.

\chapter{Chapter 2}[label2]
\lipsum[1-2]
\end{document}
Permanenter link

beantwortet 03 Jun '19, 21:40

Skillmon's gravatar image

Skillmon
1.2k6
Akzeptiert-Rate: 46%

bearbeitet 07 Jun '19, 22:46

@Skillmon Ah gut, mir ist gerade noch aufgefallen, dass im Inhaltsverzeichnis auch ein thumb erzeugt wird. Das müsste an sich etwas mit der chapter-Methode zu tun haben.
alt text

(04 Jun '19, 15:34) cis

@cis man könnte den \addthumb Befehl auch in ein \IfBooleanF{#1}{...} packen, um das zu verhindern.

(05 Jun '19, 11:10) Skillmon
1

Oder vielleicht \IfBooleanTF{#1}{\stopthumb}{...}. Damit würde dann auch für spätere \chapter* die Ausgabe von Thumbs unterdrückt bzw. unterbrochen. Darüber hinaus fehlt noch eine Aussage von @cis, wie sich \addchap bzw. dessen Sternform verhalten soll.

(06 Jun '19, 13:57) esdd

@esdd Guter Hinweis, danke.

(07 Jun '19, 22:44) Skillmon

Hier ist ein weiterer Vorschlag, bei dem alle Kapitel, die einen Eintrag ins Inhaltsverzeichnis erhalten, auch eine Randmarkierung bekommen. Der eventuell benötigte Eintrag ins Verzeichnis der Thumbs entspricht dann dem Eintrag ins Inhaltsverzeichnis.

\documentclass[ngerman, fontsize=9pt, paper=a5]{scrreprt}
\usepackage{babel}
\usepackage{lipsum}
\usepackage{thumbs}
\usepackage[T1]{fontenc}
\usepackage{xpatch}
\xapptocmd{\addchaptertocentry}
  {\addthumb{#2}{\space\Large\sffamily\bfseries #1}{white}{black}}
  {}{\PatchFailed}
\AddtoDoHook{heading/branch/star/chapter}{\stopthumb}
\begin{document}
\pagenumbering{arabic}
\tableofcontents
\chapter[short]{Chapter 1\label{short}}
\section{Very important section}
\lipsum[1] \ref{short},\ref{Chapter 2}

\chapter{Chapter 2\label{Chapter 2}}
\lipsum[1-2]
\addchap{Beispiel für addchap}
\end{document}

Mit dem Code wird für nicht nummerierte Kapitel auch keine Nummer in der Randmarkierung ausgegeben. Ändern ließe sich das, in dem man mit \Ifstr{#1}{}{...}{...} eine Fallunterscheidung für die Ausgabe der Randmarkierungen einfügt.

Eine andere Frage ist, was passieren soll, wenn nach dem Beginn der Randmarkierungen noch Kapitel ohne Eintrag ins Inhaltsverzeichnis folgen. Dann wird in diesen Kapiteln die Markierung des vorherigen Kapitels weiter verwendet. Sie kann aber auch mit \stopthumb unterbrochen werden. Dabei muss man Sorge dafür tragen, dass das (erst) auf der richtigen Seite wirksam wird:

\documentclass[ngerman, fontsize=9pt, paper=a5]{scrreprt}
\usepackage{babel}
\usepackage{lipsum}
\usepackage{thumbs}
\usepackage[T1]{fontenc}
\usepackage{xpatch}
\xapptocmd{\addchaptertocentry}
  {\addthumb{#2}{\space\Large\sffamily\bfseries #1}{white}{black}}
  {}{\PatchFailed}
\begin{document}
\pagenumbering{arabic}
\tableofcontents
\chapter[short]{Chapter 1\label{short}}
\section{Very important section}
\lipsum[1] \ref{short},\ref{Chapter 2}

\chapter{Chapter 2\label{Chapter 2}}
\lipsum[1-2]
\addchap{Beispiel für addchap}
\lipsum[3]
\clearpage
\stopthumb
\addchap*{Beispiel für addchap* ohne Randmarkierung}
\lipsum[4]
\chapter{Chapter 3}
\lipsum[5-6]
\end{document}

Mit der aktuellen Prerelease von KOMA-Script lässt sich das auch mit dem Hook

\AddtoDoHook{heading/branch/star/chapter}{\stopthumb}

automatisieren.

\documentclass[ngerman, fontsize=9pt, paper=a5]{scrreprt}[2019/03/05]
\usepackage{babel}
\usepackage{lipsum}
\usepackage{thumbs}
\usepackage[T1]{fontenc}
\usepackage{xpatch}
\xapptocmd{\addchaptertocentry}
  {\addthumb{#2}{\space\Large\sffamily\bfseries #1}{white}{black}}
  {}{\PatchFailed}
\AddtoDoHook{heading/branch/star/chapter}{\stopthumb}
\begin{document}
\pagenumbering{arabic}
\tableofcontents
\chapter[short]{Chapter 1\label{short}}
\section{Very important section}
\lipsum[1] \ref{short},\ref{Chapter 2}

\chapter{Chapter 2\label{Chapter 2}}
\lipsum[1-2]
\addchap{Beispiel für addchap}
\lipsum[3]
\addchap*{Beispiel für addchap* ohne Randmarkierung}
\lipsum[4]
\addchap*{Beispiel für chapter* ohne Randmarkierung}
\lipsum[4]
\chapter{Chapter 3}
\lipsum[5-6]
\KOMAScriptVersion
\end{document}

Ergebnis:

alt text

Permanenter link

beantwortet 06 Jun '19, 14:59

esdd's gravatar image

esdd
17.8k284257
Akzeptiert-Rate: 62%

bearbeitet 16 Jan '20, 13:39

Deine Antwort
Vorschau umschalten

Folgen dieser Frage

Per E-Mail:

Wenn sie sich anmelden, kommen Sie für alle Updates hier in Frage

Per RSS:

Antworten

Antworten und Kommentare

Markdown-Grundlagen

  • *kursiv* oder _kursiv_
  • **Fett** oder __Fett__
  • Link:[Text](http://url.com/ "Titel")
  • Bild?![alt Text](/path/img.jpg "Titel")
  • nummerierte Liste: 1. Foo 2. Bar
  • zum Hinzufügen ein Zeilenumbruchs fügen Sie einfach zwei Leerzeichen an die Stelle an der die neue Linie sein soll.
  • grundlegende HTML-Tags werden ebenfalls unterstützt

Frage-Themen:

×131
×42
×9
×5
×3

gestellte Frage: 03 Jun '19, 19:38

Frage wurde gesehen: 8,684 Mal

zuletzt geändert: 07 Jun '19, 22:46