用MATLAB绘制一个魔方

Matlab 复制代码
clc;close all;clear all;warning off;%清除变量
rand('seed', 100);
randn('seed', 100);
format long g;

% 设置图形窗口
figure;

% 创建一个3D坐标轴
% ax = axes3d;

% 设置坐标轴的范围
xlim([-3 3]);
ylim([-3 3]);
zlim([-3 3]);

% 设置坐标轴的标签
xlabel('X');
ylabel('Y');
zlabel('Z');

% 设置网格线
grid on;

% 绘制魔方
% 假设魔方由27个小立方体组成,每个小立方体的边长为1
for x = -1:1
    for y = -1:1
        for z = -1:1
            % 绘制每个小立方体
            myCuboid([x, x+1], [y, y+1], [z, z+1], rand(1,3));
            hold on;  % 保持当前图形,使得新的图形不会覆盖旧的图形
        end
    end
end

% 设置视角
view(3);
Matlab 复制代码
function myCuboid(xRange, yRange, zRange, faceColor)
% xRange, yRange, zRange 应该是两个元素的向量,分别表示立方体在 x, y, z 方向上的范围
% 例如 xRange = [x1 x2] 表示立方体在 x 轴方向的范围从 x1 到 x2

% 定义立方体的8个顶点
vertices = [
    xRange(1), yRange(1), zRange(1);
    xRange(2), yRange(1), zRange(1);
    xRange(2), yRange(2), zRange(1);
    xRange(1), yRange(2), zRange(1);
    xRange(1), yRange(1), zRange(2);
    xRange(2), yRange(1), zRange(2);
    xRange(2), yRange(2), zRange(2);
    xRange(1), yRange(2), zRange(2)
    ];

% 定义立方体的面
faces = [
    1 2 3 4; % 底面
    5 6 7 8; % 顶面
    1 5 6 2; % 前面
    2 6 7 3; % 右侧面
    3 7 8 4; % 后面
    4 8 5 1  % 左侧面
    ];

% 绘制立方体
patch('Vertices', vertices, 'Faces', faces, 'FaceColor', faceColor, 'EdgeColor', 'none');

% 自动调整视角以更好地显示立方体
axis equal;
view(3);
end
相关推荐
小_太_阳24 分钟前
Scala_【2】变量和数据类型
开发语言·后端·scala·intellij-idea
直裾27 分钟前
scala借阅图书保存记录(三)
开发语言·后端·scala
唐 城1 小时前
curl 放弃对 Hyper Rust HTTP 后端的支持
开发语言·http·rust
码银3 小时前
【python】银行客户流失预测预处理部分,独热编码·标签编码·数据离散化处理·数据筛选·数据分割
开发语言·python
从善若水3 小时前
【2024】Merry Christmas!一起用Rust绘制一颗圣诞树吧
开发语言·后端·rust
2401_858286114 小时前
115.【C语言】数据结构之排序(希尔排序)
c语言·开发语言·数据结构·算法·排序算法
Jelena技术达人4 小时前
Java爬虫获取1688关键字 item_search接口返回值详细解析
java·开发语言·爬虫
数据小爬虫@4 小时前
Java爬虫:速卖通(AliExpress)商品评论获取指南
java·开发语言
waterme1onY4 小时前
Spring AOP 中记录日志
java·开发语言·笔记·后端
2401_879103684 小时前
24.12.25 AOP
java·开发语言·笔记