拋射運動:更改舊程式碼並使其更美觀

拋射運動:更改舊程式碼並使其更美觀

鑑於這張圖片,

在此輸入影像描述

高爾夫球手以高於水平線的角度54.0°和速度投擲球v₀=13.5 m/s。看著這個優秀的舊答案使用 LaTeX 繪製映射彈丸運動的圖形用戶@Mark Wibrow

在此輸入影像描述

完整的程式碼:

\documentclass[tikz,border=5]{standalone}
\usepackage[prefix=]{xcolor-material}
\begin{document}
\begin{tikzpicture}[x=(330:1cm),y=(30:1cm),z=(90:1cm)]
\fill [LightGreen] (-1,-1,0) -- (-.5,1,0) -- (11,2,0) -- (11,-2,0) -- cycle;
\fill [Green] (9,0,0) circle [x radius=1.5, y radius=1];
\fill [black] (10,0,0) circle [x radius=.1, y radius=.1];
\draw [Brown, thick, line cap=round] (10,0,0) -- (10,0,1);
\fill [Red] (10,0,1) -- (9.8,0,0.9) -- (10,0,0.8) -- cycle;
\fill [Yellow, shift={(7,0,0)}] 
  plot [domain=0:340, samples=20, smooth cycle, variable=\t] 
    (\t:rnd/16+0.25 and rnd/8+0.75);
\foreach \a [evaluate={\v=70; \T=\v*sin(\a)/9.807*2;}] in {10, 20, ..., 80} {
  \draw [x=(330:0.5pt), z=(90:0.5pt), Black, dashed]
    plot [smooth, domain=0:\T, samples=50, variable=\t] 
      (\v*\t*cos \a, 0, -9.807/2*\t^2+\v*\t*sin \a +0.1016) coordinate (end);
  \fill [White] (end) circle [radius=1pt];
}
\end{tikzpicture}
\end{document} 

從共同軌跡方程式出發

y=(tan α)x-[1/(2gv₀²cos²α)]x²

是否可以

  • 添加x- 軸和y帶有刻度線(和標籤)的 - 軸?
  • 讓高爾夫球非常接近高度附近且位於軌蹟的黑色虛線(或連續線)下方,就像開始圖像一樣?

編輯:

我對消失OP的程式碼做了一些更改...

\documentclass[tikz,border=5]{standalone}
\usepackage[prefix=]{xcolor-material}
\begin{document}
\begin{tikzpicture}[x=(330:1cm),y=(30:1cm),z=(90:1cm),
    declare function={v=70;% <- velocity (input)
        alpha=30;% <- angle (input)
        h=2*v*sin(alpha)/9.807;}]
\fill [LightGreen] (-1,-1,0) -- (-.5,1,0) -- (11,2,0) -- (11,-2,0) -- cycle;
\fill [Green] (9,0,0) circle [x radius=1.5, y radius=1];
\fill [black] (10,0,0) circle [x radius=.1, y radius=.1];
\draw [Brown, thick, line cap=round] (10,0,0) -- (10,0,1);
\fill [Red] (10,0,1) -- (9.8,0,0.9) -- (10,0,0.8) -- cycle;
\fill [Yellow, shift={(7,0,0)}] 
  plot [domain=0:320, samples=40, smooth cycle, variable=\t] 
    (\t:rnd/16+0.25 and rnd/8+0.75);
  \draw [x=(330:0.5pt), z=(90:0.5pt), White, dash pattern=on 0.1pt off 4pt, double, double distance=1pt, line cap=round]
    plot [smooth, domain=0:h, samples=50, variable=\t] 
      ({v*\t*cos(alpha)}, 0,{-9.807/2*\t*\t+v*\t*sin(alpha)+0.1016}) 
      coordinate (end);
  \fill [White] (end) circle [radius=2pt];
\end{tikzpicture}
\end{document} 

但我無法將軌跡、球之間的距離以及帶有標籤的軸顯示為 3D 繪圖。

在此輸入影像描述

答案1

兩個主要變化:

  • 繪製兩個軸以及原點和
  • 一些<mark options>用於\draw plot[..., <mark options>]繪製(等距)高爾夫球的球。
\documentclass{article}
\usepackage{tikz}
\usepackage[prefix=]{xcolor-material}

\begin{document}
\begin{tikzpicture}[x=(330:1cm),y=(30:1cm),z=(90:1cm)]
  % green ground
  \fill [LightGreen] (-1,-1,0) -- (-.5,1,0) -- (11,2,0) -- (11,-2,0) -- cycle;
  \fill[Green] (9,0,0) circle [x radius=1.5, y radius=1];
  % black hole
  \fill[black] (10,0,0) circle [x radius=.1, y radius=.1];
  % red flag
  \draw[Brown, thick, line cap=round] (10,0,0) -- (10,0,1);
  \fill[Red] (10,0,1) -- (9.8,0,0.9) -- (10,0,0.8) -- cycle;
  % yellow sand hill
  \fill[Yellow, shift={(7,0,0)}] 
    plot [domain=0:340, samples=20, smooth cycle, variable=\t] 
      (\t:rnd/16+0.25 and rnd/8+0.75);

  % origin
  \node[below left] {$O$};
  % x-axis
  \draw (0, 0) -- (10, 0) 
    node[midway, yshift=-.8cm, rotate=330] {Distance, x (m)};
  \draw foreach \i in {2,4,6,8} 
    { (\i, 0) node[below, rotate=330] {\i} -- ++(0, .15) };
  % y-axis
  \draw (0, 0, 0) -- (0, 0, 5) 
    node[pos=.8, xshift=-.8cm, rotate=90] {Height, y(m)};
  \draw foreach \i in {2,4} 
    { (0, 0, \i) node[left] {\i} -- ++(.15, 0, 0) };

  \foreach \a[evaluate={\v=70; \T=\v*sin(\a)/9.807*2;}] in {10, 20, ..., 80} {
    \draw[x=(330:0.5pt), z=(90:0.5pt), Black, dashed]
      plot [smooth, domain=0:\T, samples=50, variable=\t,
            mark=*, mark repeat=2, mark size=1.8pt, mark options={fill=white, solid}]
        (\v*\t*cos \a, 0, -9.807/2*\t^2+\v*\t*sin \a +0.1016) coordinate (end);
    \filldraw[fill=White] (end) circle [radius=1.8pt];
  }
\end{tikzpicture}
\end{document} 

在此輸入影像描述

答案2

您發布的程式碼幾乎回答了所有問題,至少是我解釋它們的方式。我所做的就是將v和存儲alpha在“函數”中,並使用一些雙線技巧來獲得軌蹟的不同表示。

\documentclass[tikz,border=5]{standalone}
\usepackage[prefix=]{xcolor-material}
\begin{document}
\begin{tikzpicture}[x=(330:1cm),y=(30:1cm),z=(90:1cm),
    declare function={v=70;% <- velocity (input)
        alpha=30;% <- angle (input)
        T=2*v*sin(alpha)/9.807;}]
\fill [LightGreen] (-1,-1,0) -- (-.5,1,0) -- (11,2,0) -- (11,-2,0) -- cycle;
\fill [Green] (9,0,0) circle [x radius=1.5, y radius=1];
\fill [black] (10,0,0) circle [x radius=.1, y radius=.1];
\draw [Brown, thick, line cap=round] (10,0,0) -- (10,0,1);
\fill [Red] (10,0,1) -- (9.8,0,0.9) -- (10,0,0.8) -- cycle;
\fill [Yellow, shift={(7,0,0)}] 
  plot [domain=0:340, samples=20, smooth cycle, variable=\t] 
    (\t:rnd/16+0.25 and rnd/8+0.75);
  \draw [x=(330:0.5pt), z=(90:0.5pt), Black, dash pattern=on 0.1pt off 4pt,
    double,double distance=2pt,line cap=round]
    plot [smooth, domain=0:T, samples=50, variable=\t] 
      ({v*\t*cos(alpha)}, 0,{ -9.807/2*\t*\t+v*\t*sin(alpha)+0.1016}) 
      coordinate (end);
  \fill [White] (end) circle [radius=1pt];
\end{tikzpicture}
\end{document} 

在此輸入影像描述

相關內容