% tkz-obj-eu-sectors.tex
% Copyright 2024  Alain Matthes
% This work may be distributed and/or modified under the
% conditions of the LaTeX Project Public License, either version 1.3
% of this license or (at your option) any later version.
% The latest version of this license is in
%   http://www.latex-project.org/lppl.txt
% and version 1.3 or later is part of all distributions of LaTeX
% version 2005/12/01 or later.
% This work has the LPPL maintenance status “maintained”.
% The Current Maintainer of this work is Alain Matthes.

\def\fileversion{5.10c}
\def\filedate{2024/04/19}
\typeout{2024/04/19 5.10c tkz-obj-eu-sectors.tex}
\makeatletter
%<-----------------------    Sectors         ------------------------------–>
\gdef\tkz@nums{0}
\pgfkeys{/drawsector/.cd,
  towards/.code               = {\def\tkz@nums{0}},
  rotate/.code                = {\def\tkz@nums{1}},
  R/.code                     = {\def\tkz@nums{2}},
  R with nodes/.code          = {\def\tkz@nums{3}},
  towards,
  /drawsector/.search also  = {/tikz},
} 

\def\tkzDrawSector{\pgfutil@ifnextchar[{\tkz@DrawSector}{\tkz@DrawSector[]}}
\def\tkz@DrawSector[#1](#2,#3)(#4){% 
\begingroup
\pgfqkeys{/drawsector}{#1}       
\ifcase\tkz@nums%
   \tkzDrawSectorN[#1](#2,#3)(#4)  
\or% 1
   \tkzDrawSectorRotate[#1](#2,#3)(#4)  
\or% 2
   \tkzDrawSectorRAngles[#1](#2,#3)(#4)
\or% 3
   \tkzDrawSectorR[#1](#2,#3)(#4)
\fi    
\endgroup
}
\def\tkzDrawSectorRAngles{\pgfutil@ifnextchar[{\tkz@DrawSectorRAngles}{%
                                               \tkz@DrawSectorRAngles[]}} 
\def\tkz@DrawSectorRAngles[#1](#2,#3)(#4,#5){%
\begingroup      
  \pgfmathparse{#4}\edef\tkz@FirstAngle{\pgfmathresult}% 
  \pgfmathparse{#5}\edef\tkz@SecondAngle{\pgfmathresult}%  
  \pgfmathgreaterthan{\tkz@FirstAngle}{0}   
  \ifdim\pgfmathresult pt=1 pt\relax%  
    \pgfmathgreaterthan{\tkz@FirstAngle}{\tkz@SecondAngle}
    \ifdim\pgfmathresult pt=1 pt\relax%
     \pgfmathsubtract{\tkz@FirstAngle}{360}
     \edef\tkz@FirstAngle{\pgfmathresult}%
 \fi 
 \else
     \pgfmathgreaterthan{\tkz@FirstAngle}{\tkz@SecondAngle}
    \ifdim\pgfmathresult pt=1 pt\relax%
     \pgfmathadd{\tkz@SecondAngle}{360}
     \edef\tkz@SecondAngle{\pgfmathresult}%
 \fi 
 \fi
 \draw[shift = {(#2)},/drawsector/.cd,#1]%
   (#2) --(\tkz@FirstAngle:#3) arc (\tkz@FirstAngle:\tkz@SecondAngle:#3)--cycle;
 \endgroup
  } %  revoir il y a plus simple que ce shift !!! 
%<--------------------------------------------------------------------------–>
% \tkzDrawSectorN(O,A)(B)
%<--------------------------------------------------------------------------–>
\def\tkzDrawSectorN{\pgfutil@ifnextchar[{\tkz@DrawSectorN}{%
                                         \tkz@DrawSectorN[]}}  
\def\tkz@DrawSectorN[#1](#2,#3)(#4){%
\begingroup
 \tkz@@CalcLengthcm(#2,#3){tkz@radius}
 \tkzFindSlopeAngle(#2,#3)\tkzGetAngle{tkz@FirstAngle}  
 \tkzFindSlopeAngle(#2,#4)\tkzGetAngle{tkz@SecondAngle} 
 \tkz@DrawSectorRAngles[#1](#2,\tkz@radius)(\tkz@FirstAngle,%
                                               \tkz@SecondAngle)      
\endgroup
}
%<--------------------------------------------------------------------------–>
% \tkzDrawSectorRotate(O,A)(angle de rotation) ??? pb avec angle negatif
%<--------------------------------------------------------------------------–>
\def\tkzDrawSectorRotate{\pgfutil@ifnextchar[{\tkz@DrawSectorRotate}{%
                                              \tkz@DrawSectorRotate[]}} 
\def\tkz@DrawSectorRotate[#1](#2,#3)(#4){%
\begingroup
    \tkz@@CalcLengthcm(#2,#3){tkz@radius} 
    \tkzFindSlopeAngle(#2,#3)\tkzGetAngle{tkz@FirstA} 
    \pgfmathadd{\tkz@FirstA}{#4}
    \edef\tkz@SecondA{\pgfmathresult} 
    \pgfmathgreaterthan{#4}{0}   
  \ifdim\pgfmathresult pt=1 pt\relax% 
   \tkz@DrawSectorRAngles[#1](#2,\tkz@radius)(\tkz@FirstA,\tkz@SecondA)    
  \else
  \tkz@DrawSectorRAngles[#1](#2,\tkz@radius)(\tkz@SecondA,\tkz@FirstA)      
  \fi        
\endgroup
}   
% %<--------------------------------------------------------------------------–>
 
%<--------------------------------------------------------------------------–>
%  \tkzDrawSectorR(O, rad)(A,B)
%<--------------------------------------------------------------------------–>
\def\tkzDrawSectorR{\pgfutil@ifnextchar[{\tkz@DrawSectorR}{%
                                         \tkz@DrawSectorR[]}} 
\def\tkz@DrawSectorR[#1](#2,#3)(#4,#5){%
\begingroup 
  \tkzFindSlopeAngle(#2,#4)\tkzGetAngle{tkz@FirstAngle}  
  \tkzFindSlopeAngle(#2,#5)\tkzGetAngle{tkz@SecondAngle} 
  \tkz@DrawSectorRAngles[#1](#2,#3)(\tkz@FirstAngle,\tkz@SecondAngle)  
\endgroup   
}
%<--------------------------------------------------------------------------–>
%                                 Fill
%<--------------------------------------------------------------------------–>
\gdef\tkz@nums{0}
\pgfkeys{/@fillsector/.cd,
      towards/.code               = {\def\tkz@nums{0}},
      rotate/.code                = {\def\tkz@nums{1}},
      R/.code                     = {\def\tkz@nums{2}},
      R with nodes/.code          = {\def\tkz@nums{3}},
      towards,
      /@fillsector/.search also={/tikz},
} 

\def\tkzFillSector{\pgfutil@ifnextchar[{\tkz@FillSector}{\tkz@FillSector[]}}
\def\tkz@FillSector[#1](#2,#3)(#4){% 
\begingroup
\pgfqkeys{/@fillsector}{#1}     
\ifcase\tkz@nums%
   \tkzFillSectorN[#1](#2,#3)(#4)  
\or% 1
   \tkzFillSectorRotate[#1](#2,#3)(#4)  
\or% 2
   \tkzFillSectorRAngles[#1](#2,#3)(#4)
\or% 3
   \tkzFillSectorR[#1](#2,#3)(#4)
\fi    
\endgroup
}   


\def\tkzFillSectorRAngles{\pgfutil@ifnextchar[{\tkz@FillSectorRAngles}{%
                                               \tkz@FillSectorRAngles[]}} 
\def\tkz@FillSectorRAngles[#1](#2,#3)(#4,#5){%
\begingroup
  \pgfmathparse{#4}\edef\tkz@FirstAngle{\pgfmathresult}% 
  \pgfmathparse{#5}\edef\tkz@SecondAngle{\pgfmathresult}%  
   \pgfmathgreaterthan{\tkz@FirstAngle}{0}   
   \ifdim\pgfmathresult pt=1 pt\relax%  
     \pgfmathgreaterthan{\tkz@FirstAngle}{\tkz@SecondAngle}
     \ifdim\pgfmathresult pt=1 pt\relax%
      \pgfmathsubtract{\tkz@FirstAngle}{360}
      \edef\tkz@FirstAngle{\pgfmathresult}%
  \fi 
  \else
      \pgfmathgreaterthan{\tkz@FirstAngle}{\tkz@SecondAngle}
     \ifdim\pgfmathresult pt=1 pt\relax%
      \pgfmathadd{\tkz@SecondAngle}{360}
      \edef\tkz@SecondAngle{\pgfmathresult}%
  \fi\fi
  \pgfmathsubtract{\tkz@FirstAngle}{0}
  \edef\tkz@FirstAngle{\pgfmathresult}%
  \pgfmathadd{\tkz@SecondAngle}{0}
  \edef\tkz@SecondAngle{\pgfmathresult} 
  \path[shift  = {(#2)},/@fillsector/.cd,fill=\tkz@fillcolor,#1] (#2) -- %
      (\tkz@FirstAngle:#3) arc (\tkz@FirstAngle:\tkz@SecondAngle:#3)--cycle; 
\endgroup
}   
%<--------------------------------------------------------------------------–>
% \tkzFillSectorN(O,A)(B)
%<--------------------------------------------------------------------------–>
\def\tkzFillSectorN{\pgfutil@ifnextchar[{\tkz@FillSectorN}{\tkz@FillSectorN[]}} 
\def\tkz@FillSectorN[#1](#2,#3)(#4){%
\begingroup  
  \tkz@@CalcLength(#2,#3){tkz@radius}
  \tkzFindSlopeAngle(#2,#3)\tkzGetAngle{tkz@FirstAngle}  
  \tkzFindSlopeAngle(#2,#4)\tkzGetAngle{tkz@SecondAngle} 
  \tkz@FillSectorRAngles[#1](#2,\tkz@radius pt)(\tkz@FirstAngle,%
                                                \tkz@SecondAngle)    
\endgroup
}
%<--------------------------------------------------------------------------–>
% \tkzFillSectorRotate(O,A)(angle de rotation) ??? pb avec angle negatif
%<--------------------------------------------------------------------------–>
\def\tkzFillSectorRotate{\pgfutil@ifnextchar[{\tkz@FillSectorRotate}{%
                                              \tkz@FillSectorRotate[]}} 
\def\tkz@FillSectorRotate[#1](#2,#3)(#4){%
\begingroup
    \tkz@@CalcLength(#2,#3){tkz@radius} 
    \tkzFindSlopeAngle(#2,#3)\tkzGetAngle{tkz@FirstA} 
    \pgfmathadd{\tkz@FirstA}{#4}
    \edef\tkz@SecondA{\pgfmathresult} 
    \pgfmathgreaterthan{#4}{0}   
  \ifdim\pgfmathresult pt=1 pt\relax% 
   \tkz@FillSectorRAngles[#1](#2,\tkz@radius pt)(\tkz@FirstA,\tkz@SecondA)    
  \else
  \tkz@FillSectorRAngles[#1](#2,\tkz@radius pt)(\tkz@SecondA,\tkz@FirstA)      
  \fi
   \endgroup
}   
%<--------------------------------------------------------------------------–>
%  \tkzFillSectorAngles(O,A)(ang1,ang2)
%<--------------------------------------------------------------------------–>
\def\tkzFillSectorAngles{\pgfutil@ifnextchar[{\tkz@FillSectorAngles}{%
                                              \tkz@FillSectorAngles[]}}
\def\tkz@FillSectorAngles[#1](#2,#3)(#4,#5){%
\begingroup
    \tkz@@CalcLength(#2,#3){tkz@radius} 
    \tkz@FillSectorRAngles[#1](#2,\tkz@radius pt)(#4,#5)      
\endgroup
}  
%<--------------------------------------------------------------------------–>
%  \tkzFillSectorR(O, rad)(A,B)
%<--------------------------------------------------------------------------–>
\def\tkzFillSectorR{\pgfutil@ifnextchar[{\tkz@FillSectorR}{%
                                         \tkz@FillSectorR[]}} 
\def\tkz@FillSectorR[#1](#2,#3)(#4,#5){%
\begingroup 
  \tkzFindSlopeAngle(#2,#4)\tkzGetAngle{tkz@FirstAngle}  
  \tkzFindSlopeAngle(#2,#5)\tkzGetAngle{tkz@SecondAngle} 
  \tkz@FillSectorRAngles[#1](#2,#3)(\tkz@FirstAngle,\tkz@SecondAngle)  
\endgroup   
}
%<--------------------------- Clip Sector ----------------------------------–>
%
%<--------------------------------------------------------------------------–>
\def\tkz@ClipSectorRAngles(#1,#2)(#3,#4){%
\begingroup      
  \pgfmathparse{#3}\edef\tkz@FirstAngle{\pgfmathresult}% 
  \pgfmathparse{#4}\edef\tkz@SecondAngle{\pgfmathresult}%  
  \pgfmathgreaterthan{\tkz@FirstAngle}{0}   
  \ifdim\pgfmathresult pt=1 pt\relax%  
    \pgfmathgreaterthan{\tkz@FirstAngle}{\tkz@SecondAngle}
    \ifdim\pgfmathresult pt=1 pt\relax%
     \pgfmathsubtract{\tkz@FirstAngle}{360}
     \edef\tkz@FirstAngle{\pgfmathresult}%
 \fi 
 \else
     \pgfmathgreaterthan{\tkz@FirstAngle}{\tkz@SecondAngle}
    \ifdim\pgfmathresult pt=1 pt\relax%
     \pgfmathadd{\tkz@SecondAngle}{360}
     \edef\tkz@SecondAngle{\pgfmathresult}%
 \fi 
 \fi
  \clip[shift = {(#1)}] (#1) --(\tkz@FirstAngle:#2)%
        arc(\tkz@FirstAngle:\tkz@SecondAngle:#2) -- cycle;
 \endgroup
  } %  revoir il y a plus simple que ce shift !!! 
%<--------------------------------------------------------------------------–>
%
%<--------------------------------------------------------------------------–>
\def\tkz@ClipSectorRotate(#1,#2)(#3){%
\begingroup
    \tkz@@CalcLength(#1,#2){tkz@radius} 
    \tkzFindSlopeAngle(#1,#2)\tkzGetAngle{tkz@FirstA} 
    \pgfmathadd{\tkz@FirstA}{#3}
    \edef\tkz@SecondA{\pgfmathresult} 
    \pgfmathgreaterthan{#3}{0}   
  \ifdim\pgfmathresult pt=1 pt\relax% 
   \tkz@ClipSectorRAngles(#1,\tkz@radius pt)(\tkz@FirstA,\tkz@SecondA)    
  \else
  \tkz@ClipSectorRAngles(#1,\tkz@radius pt)(\tkz@SecondA,\tkz@FirstA)      
  \fi
   \endgroup 
}
%<--------------------------------------------------------------------------–>
%
%<--------------------------------------------------------------------------–>
\def\tkz@ClipSectorN(#1,#2)(#3){%
\begingroup  
  \tkz@@CalcLength(#1,#2){tkz@radius}
  \tkzFindSlopeAngle(#1,#2)\tkzGetAngle{tkz@FirstAngle}  
  \tkzFindSlopeAngle(#1,#3)\tkzGetAngle{tkz@SecondAngle} 
  \tkz@ClipSectorRAngles(#1,\tkz@radius pt)(\tkz@FirstAngle,\tkz@SecondAngle)    
\endgroup  
} 
%<--------------------------------------------------------------------------–>
%<--------------------------------------------------------------------------–>
\def\tkz@numcs{0}
\pgfkeys{/clipsector/.cd,
      towards/.code               = {\def\tkz@numcs{0}},
      rotate/.code                = {\def\tkz@numcs{1}},
      R/.code                     = {\def\tkz@numcs{2}}, 
}
%<--------------------------------------------------------------------------–>
\def\tkzClipSector{\pgfutil@ifnextchar[{\tkz@ClipSector}{%
                                        \tkz@ClipSector[]}}

\def\tkz@ClipSector[#1](#2,#3)(#4){%
\pgfkeys{/clipsector/.cd}
\pgfqkeys{/clipsector}{#1}
\ifcase\tkz@numcs%
   \tkz@ClipSectorN(#2,#3)(#4)
  \or% 1
   \tkz@ClipSectorRotate(#2,#3)(#4)
  \or% 2 
   \tkz@ClipSectorRAngles(#2,#3)(#4)
  \fi 
} 
\makeatother
\endinput