Click here to Skip to main content
Click here to Skip to main content

Spherical Coordinates in C#

, 27 Mar 2007
Rate this:
Please Sign up or sign in to vote.
This article shows how to create spherical graphics objects

Introduction

Normally, the Cartesian coordinate system is used in transformations and projections for graphics objects. In this case, you simply specify a point using X, Y, and Z coordinates. In practice, other coordinate systems can also be applied, and are sometimes more convenient than the Cartesian coordinate system.

In this article, I will discuss the spherical coordinate system in 3D space and show you how to create the spherical graphics objects in this system.

Background

In the spherical coordinate system, a point is specified by r, θ, and φ. Here r is the distance from the point to the origin, θ is the polar angle, and φ is the azimuthal angle in the X-Z plane from the X axis. In this notation, I alternate the conventional Y and Z axes so that the computer screen is described by the X-Y plane. Figure 1 shows a point in this spherical coordinate system

Figure 1: Spherical coordinate system.

From this figure, we can obtain the following relationships:

The spherical coordinates (r, θ, φ) are related to the Cartesian coordinates by:

Sometimes it is more convenient to create sphere-like objects in terms of the spherical coordinate system. The following example application program will create two spheres. We need to add the Matrix3 and Point3 classes to the current project. And also add a new class, DrawSphere, to the project.

Now we need to add a Spherical method to the Matrix3 class. The Matrix3 class has been discussed in Chapter 5 of my new book "Practical C# Charts and Graphics".

public Point3 Spherical(float r, float theta, float phi) 
{
    Point3 pt = new Point3();
    float snt = (float)Math.Sin(theta * Math.PI / 180); 
    float cnt = (float)Math.Cos(theta * Math.PI / 180); 
    float snp = (float)Math.Sin(phi * Math.PI / 180); 
    float cnp = (float)Math.Cos(phi * Math.PI / 180); 
    pt.X = r * snt * cnp; 
    pt.Y = r * cnt; 
    pt.Z = -r * snt * snp; 
    pt.W = 1; 
    return pt; 
} 

This method transforms a point in the spherical coordinate system to a point in the Cartesian coordinate system. We then Add a DrawSphere class to the project. This class allows you to specify the radius and positions (the center location) of a sphere object. The SphereCoordinates method in this class creates the points on a sphere surface by specifying their longitude and latitude. The DrawIsometricView draws the sphere using the isometric projection.

Using the code

This application can be tested using the following Form1 class:
using System;
using System.Drawing;
using System.Drawing.Drawing2D; 
using System.Windows.Forms; 

namespace Example5_6 
{ 
    public partial class Form1 : Form
    { 
      public Form1() 
      { 
            InitializeComponent(); 
            this.SetStyle(ControlStyles.ResizeRedraw, true); 
            // Subscribing to a paint eventhandler to drawingPanel:
            panel1.Paint += new PaintEventHandler(panel1Paint); 
      } 

      private void panel1Paint(object sender, PaintEventArgs e) 
      { 
            Graphics g = e.Graphics; 
            g.SmoothingMode = SmoothingMode.AntiAlias; 
            float a = panel1.Height / 3; 
            DrawSphere ds = new DrawSphere(this, a, 0, 0, -a / 2); 
            ds.DrawIsometricView(g); 
            ds = new DrawSphere(this, 2 * a / 3, -a/2, -a/2, a / 2); 
            ds.DrawIsometricView(g); 
      } 
    } 
} 

Here we create two spheres with different radii and positions. By building and running this project, you should obtain the results shown in Figure 2.

Figure 2: Spheres created in a spherical coordinate system.

This project is from the examples (example5-6 in Chapter 5) of the new book "Practical C# Charts and Graphics", where you can find more advanced chart and graphics programming for real-world .NET applications. For more information, please visit the website at www.publishing.unicadinc.com

About the Author

Dr. Jack Xu has a Ph.D in theoretical physics. He has over 15 years programming experience in Basic, Fortran, C, C++, Matlab, and C#, specializing in numerical computation methods, algorithms, physical modeling, computer-aided design (CAD) development, graphics user interface, and 3D graphics. Currently, he is responsible for developing commercial CAD tools based on Microsoft .NET framework.

Please read my other articles:

License

This article has no explicit license attached to it but may contain usage terms in the article text or the download files themselves. If in doubt please contact the author via the discussion board below.

A list of licenses authors might use can be found here

Share

About the Author

Jack J. H. Xu

United States United States
No Biography provided

Comments and Discussions

 
QuestionDrawSphere Pinmemberemad_awad18-Mar-12 12:42 
AnswerRe: DrawSphere [modified] PinmemberAlaric_24-Apr-12 7:39 
GeneralMy vote of 5 Pinmembermanoj kumar choubey18-Feb-12 3:23 
GeneralMy vote of 1 Pinmembervictorbos29-Sep-09 13:17 
QuestionCube? PinmemberDarchangel7-Aug-07 3:46 
AnswerRe: Cube? PinmemberAlbinAbel15-Mar-11 4:15 
QuestionHow do you draw a 3d pyramid and funnel/Cone PinmemberPatrick Blackman27-Mar-07 16:44 
AnswerRe: How do you draw a 3d pyramid and funnel/Cone [modified] PinmemberJack JH Xu28-Mar-07 5:36 
GeneralRe: How do you draw a 3d pyramid and funnel/Cone PinmemberPatrick Blackman28-Mar-07 14:00 
GeneralRe: How do you draw a 3d pyramid and funnel/Cone PinmemberJack JH Xu29-Mar-07 9:37 

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Rant Rant    Admin Admin   

Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+Shift+Left/Right to switch pages.

| Advertise | Privacy | Mobile
Web03 | 2.8.140827.1 | Last Updated 27 Mar 2007
Article Copyright 2007 by Jack J. H. Xu
Everything else Copyright © CodeProject, 1999-2014
Terms of Service
Layout: fixed | fluid