채택된 답변

Azzi Abdelmalek
Azzi Abdelmalek 2013년 12월 31일
편집: Azzi Abdelmalek 2013년 12월 31일

6 개 추천

r=1
teta=-pi:0.01:pi
x=r*cos(teta);
y=r*sin(teta)
plot3(x,y,zeros(1,numel(x)))

댓글 수: 6

reza
reza 2014년 1월 1일
thanks a lot. know i can create a 3d cone using 2d circles.
Beril Sirmacek
Beril Sirmacek 2018년 1월 25일
thanks :)
Anand S
Anand S 2020년 7월 31일
how can i vary the location of circle in the z axis
Image Analyst
Image Analyst 2020년 7월 31일
% Define circle parameters:
radius = 1;
xCenter = 1.5;
yCenter = 4;
zCenter = 3;
% Make an array for all the angles:
theta = linspace(0, 2 * pi, 2000);
% Create the x and y locations at each angle:
x = radius * cos(theta) + xCenter;
y = radius * sin(theta) + yCenter;
% Need to make a z value for every (x,y) pair:
z = zeros(1, numel(x)) + zCenter;
% Do the plot:
% First plot the center:
plot3(xCenter, yCenter, zCenter, 'r*', 'LineWidth', 2, 'MarkerSize', 15);
hold on; % Don't let circle blow away our center.
% Next plot the circle:
plot3(x, y, z, 'b-', 'LineWidth', 2);
grid on;
axis('square');
xlabel('x', 'FontSize', 20);
ylabel('y', 'FontSize', 20);
zlabel('z', 'FontSize', 20);
Priodyuti Pradhan
Priodyuti Pradhan 2020년 11월 2일
Thanks for sharing!
Tong Zhao
Tong Zhao 2021년 9월 13일
편집: Tong Zhao 2021년 9월 13일
The next question would be, how to draw a filled circle in 3D, parallel to say, x-y plane.
OK. I found an answer using patch at this thread.

댓글을 달려면 로그인하십시오.

추가 답변 (2개)

Image Analyst
Image Analyst 2021년 9월 13일

0 개 추천

Try this:
ellipsoid(0,-0.5,0.5,6,3.25,0.01)
zlim([0,1]);

0 개 추천

%A circle in 3D is parameterized by six numbers: two for the orientation of its unit normal vector, one for the radius, and three for the circle center.
function drawCircle(rad,pos,n,color)
%https://demonstrations.wolfram.com/ParametricEquationOfACircleIn3D/
%draws a 3D circle at position pos with radius rad, normal to the
%circle n, and color color.
phi = atan2(n(2),n(1)); %azimuth angle, in [-pi, pi]
theta = atan2(sqrt(n(1)^2 + n(2)^2) ,n(3));% zenith angle, in [0,pi]
t = 0:pi/32:2*pi;
x = pos(1)- rad*( cos(t)*sin(phi) + sin(t)*cos(theta)*cos(phi) );
y = pos(2)+ rad*( cos(t)*cos(phi) - sin(t)*cos(theta)*sin(phi) );
z = pos(3)+ rad*sin(t)*sin(theta);
plot3(x,y,z,color)
% then call the function as
pos = rand(3,1);rad = 1;R = eye(3);
drawCircle(rad,pos,R(:,1),'r')
hold on
drawCircle(rad,pos,R(:,2),'g')
drawCircle(rad,pos,R(:,3),'b')
axis equal

카테고리

도움말 센터File Exchange에서 Axis Labels에 대해 자세히 알아보기

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by