.PS #.PS 3.5 # csc.m4 # This file includes AntiqueClock and works for PSTricks, Tikz, and SVG gen_init NeedDpicTools skale = 0.878 circlerad=1.91*skale hubrad=0.10*skale s=0.5*skale define(`midnight',`0.1, 0.1, 0.44') define(`white',`1, 1, 1') define(`spokewidth',0.1) define(`spoke',`dnl {line from rvec_(0,hubrad-spokewidth/2) to rvec_(circlerad-0.05,0)} {line from rvec_(0,-(hubrad-spokewidth/2)) to rvec_(circlerad-0.05,0)}') define(`lwid',1) define(`coord',`(s*(`$1'),s*(`$2'))') # Circle and spokes CSC: [ rgbdraw(midnight, linethick=`0.'eval(lwid*15)/(1pt__) {circle with .c at Here circle invis diam last circle.diam + linethick pt__ at last circle } linethick=spokewidth/(1pt__) for angle = 0 to 330 by 30 do { Point_(angle) {spoke} } ) # Whiten where the hull will be linethick=`0.'eval(lwid*20)/(1pt__) rgbdraw(white, Point_(-60){line to rvec_(circlerad*0.72,0)} Point_(-90){line to rvec_(circlerad*0.72,0)} Point_(-120){line to rvec_(circlerad*0.72,0)} linethick=`0.'eval(lwid*15)/(1pt__) {move to coord(1.8,-2.3)+(0,0.025) spline to Here+coord(-0.8,-0.3) then to Here+coord(-1.8,-0.3) \ then to Here+coord(-2.18,-0.27) \ then to Here+coord(-3.93,-0.1)} ) # Sail thinlines_ rgbfill(midnight, line from coord(0.44,3.38) to coord(0.44,2.6) \ then to coord(2.1,-1.75) \ then to coord(1.22,-1.53) \ then to coord(0.62,-1.4) \ then to coord(0.55,-1.6) \ then to coord(-2.2,-1.6) \ then to coord(-2.35,-1.5) spline to coord(-2.14,-0.78) \ then to coord(-1.74,0.22) \ then to coord(-1.42,0.89) \ then to coord(-0.92,1.73) \ then to coord(0,2.9) \ then to coord(0.44,3.38) ) # Hull rgbfill(midnight, spline from coord(2.1,-1.75) to coord(1.9,-2.2) \ then to coord(1.85,-2.3) then to coord(1.8,-2.33) \ then to coord(1,-2.5) then to coord(0,-2.6) then to coord(-0.38,-2.57) \ then to coord(-2.13,-2.4) line to coord(-2.2,-2.05) then to coord(2.1,-1.75) spline to coord(-1,-2.08) then to coord(0.55,-1.77) ) ] Clock: [ # PSTricks, tikz, or svg only: ifelse(ifpstricks(T)`'ifpgf(T)`'ifsvg(T),T,` #.PS # AntiqueClock.m4 #gen_init #NeedDpicTools iflatex(`latexcommand({\sf)') ifsvg(svg_font(font-family="sans-serif" font-stretch="condensed") svg_rot_init(test)) # https://tex.stackexchange.com/questions/236923/generate-analog-clock-with-numbered-face-add-seconds-roman-numerals # `hms2deg(hr,min,sec) hr:min:sec to degrees # blank arg1: degrees for minute hand # blank arg1 and arg2: degrees for second hand' define(`hms2deg',`ifelse(`$1',, `ifelse(`$2',, `(90-pmod(ifelse(`$3',,0,`$3'),60)/60*360)', `(90-(pmod(`$2',60)/60 + pmod(ifelse(`$3',,0,`$3'),60)/60/60)*360)')', `(90-(pmod(`$1',12) + pmod(ifelse(`$2',,0,`$2'),60)/60 + dnl pmod(ifelse(`$3',,0,`$3'),60)/3600)/12*360)')') # `SecondHand(length,hr,min,sec)' define(`SecondHand',`[ shsf = (`$1')/3.2 C: Here { L: rpoint_(to (Rect_(`$1',hms2deg(,,`$4')))) } line thick 8*shsf to rvec_(`$1',0) ]') # `AntiqueMinuteHand(length,hr,min,sec)' define(`AntiqueMinuteHand',`[ mhsf = (`$1')/2.84 L: rpoint_(to (Rect_(`$1',hms2deg(,`$3',`$4')))) C: circle fill_(0) diam 0.47*mhsf at L.start move to C spline from rvec_(0,0.047*mhsf) \ to rvec_(1.65*mhsf,0.11*mhsf) \ then to rvec_(`$1',0.018*mhsf) \ then to rvec_(`$1',-0.018*mhsf) \ then to rvec_(1.65*mhsf,-0.11*mhsf) \ then to rvec_(0,-0.047*mhsf) \ shaded rgbstring(0,0,0) ]') # `AntiqueHourHand(length,hr,min,sec)' define(`AntiqueHourHand',`[ hhsf = (`$1')/2.2 L: rpoint_(to (Rect_(`$1',hms2deg(`$2',`$3',`$4')))) C: circle fill_(0) diam 0.6*hhsf at L.start move to C v = 0.25*hhsf { line to rvec_(1.1*hhsf,0) thick 0.15/(1bp__)*hhsf } C1: rvec_(1.25*hhsf,0) d = `$1'-1.25*hhsf q = 1bp__*hhsf r1 = (d^2 + q^2 - v^2)/(v-q)/2 tang = atan2((r1+q),d) for i=0 to 3 do { X[i]: C1+vec_(rect_(v, pi_+i/3*( tang-pi_))) Y[i]: C1+vec_(rect_(v,-pi_+i/3*(-tang+pi_))) } n = 3 for i=1 to 4 do { aa = -pi_+tang + i/4*(pi_/2-tang) XX: (d,r1+q)+(rect_(r1,aa)) n+=1; X[n]: C1+vec_(XX.x, XX.y) Y[n]: C1+vec_(XX.x,-XX.y) } m = n for i= 0 to m do { n+=1; X[n]: Y[m-i] } fitcurve(X,n,shaded rgbstring(0,0,0)) ]') define(`AntiqueClock',`[ # h,m,s,diam # Clock size parameters: hour = ifelse(`$1',,3,`$1') minute = ifelse(`$2',,41,`$2') second = ifelse(`$3',,51,`$3') # outer radius ifelse(`$4',,`skale=0.5; r1=2',`r1=(`$4')/2; skale=r1/4') r2 = r1-0.5*skale r3 = r2-0.14*skale r4 = r3 - 0.35*skale r5 = r4 - 0.17*skale r6 = r5 - 0.63*skale r7 = r6 - 0.17*skale shadelinethick = 1.0 C: circle thick 0.2 rad r1 define shadeline { s = 1-($`'1)*2 v = r*s h = sqrt(r^2-v^2) t = 1-abs(s) line from (vrot_(-h,v,cost,sint)) to (vrot_(h,v,cost,sint)) \ thick shadelinethick outlined rgbstring(t,t,t) } r = r1 # Bezel outer nlines = int(2*r/(shadelinethick pt__)*1.1) cost = cosd(10); sint = sind(10); ShadeObject(shadeline,nlines, 0, 0,0,0, 0.5, 1,1,1, 1, 0,0,0 ) at C r = r2 # Bezel inner nlines = int(2*r/(shadelinethick pt__)*1.1) cost = cosd(-10); sint = sind(-10); ShadeObject(shadeline,nlines, 0, 0,0,0, 0.25, 0.8,0.8,0.8, 0.5, 1,1,1, 0.75, 0.8,0.8,0.8, 1, 0,0,0 ) at C # Clock face Face: circle thick 0 fill_(1) rad r3 at C circle rad r4 at C circle rad r5 at C circle rad r6 at C circle rad r7 at C # Ad hoc shift of rotated SVG text ifsvg(`define adj {+(-cosd($`'1)*textht*0.5*sign(180-($`'1)),\ (0.25+0.25*cosd(2*($`'1)))*textht) }', `define adj {}') # Outer numbers iflatex(`command sprintf("\font\outerfont=cmss12 at %4.2fin",r3-r4)') ifsvg(`textht = (r3-r4)*0.6') for_(-15,15,5,`aa=90-(m4x)*6 r_text(eval(-(m4x)*6),eval((m4x+60)%60), at C+(Rect_((r3+r4)/2,aa)) adj(aa))') for_(20,40,5,`aa=450-(m4x)*6 r_text(eval(180-m4x*6),m4x,at C+(Rect_((r3+r4)/2,aa)) adj(aa))') # Outer tics for mn = 1 to 60 do { t = 90-mn/60*360 line from C+(Rect_(r5,t)) to C+(Rect_(r4,t)) } # Inner numbers iflatex(`command sprintf("\font\innerfont=cmss12 at %4.2fin",r5-r6)') ifsvg(`textht = (r5-r6)*0.6') Loopover_(`mx',`aa=180-(m4Lx-1)*30 r_text(eval(120-m4Lx*30),iflatex({\innerfont mx},mx), at C+(Rect_((r5+r6)/2,aa)) adj(aa))', IX,X,XI,XII,I,II,III) Loopover_(`mx',`aa=360-m4Lx*30 r_text(eval(90-m4Lx*30), iflatex({\innerfont mx},mx), at C+(Rect_((r5+r6)/2,aa)) adj(aa))', IV,V,VI,VII,VIII) # Inner tics for mn = 5 to 60 by 5 do { t = 90-mn/60*360 line from C+(Rect_(r7,t)) to C+(Rect_(r6,t)) } # Hands AntiqueHourHand(r6,hour,minute,second) with .C at C AntiqueMinuteHand(r5,hour,minute,second) with .C at C SecondHand((r3+r4)/2,hour,minute,second) with .C at C # Center dot(at C,0.1/4*r1,1) ]') `# AntiqueClock' Clock1: AntiqueClock(,,,3.5) # Clock2: AntiqueClock(4,50,07,2) at Clock1.e+(1.5,0) iflatex(`latexcommand(}%)') ifsvg(`command ""') #.PE ',` "AntiqueClock.m4 requires" "PSTricks, Tikz-pgf, or SVG" ') ] with .sw at last [].se+(0.25,0) .PE