Let's create a block shape by combining six polygons using plot3d
command. We first consider the case where one of the vertices coincides with the origin of the coordinate system and each side is parallel to the coordinate axis as shown in Figure 1 (we call this the "basic configuration"). In this case, if the length of each side (Lx, Ly, Lz) is given, the coordinates of the eight vertices are obvious. The six faces are defined by the following six sequences of vertices.
A Scilab script to draw a block shape in the basic configuration is shown in Code 1. The result of the drawing by this script is shown in Figure 2. Function genpat()
used in the script is a function defined as in Code 2 that generates patches data, which is the input to plot3d
, from vertices and faces matrices.
// make_block_special.sce clear; xdel(winsid()); exec('genpat.sci', -1); // Side lengths Lx = 0.15; Ly = 0.05; Lz = 0.30; // Vertices vertices = [ 0, 0, 0; // #1 Lx, 0, 0; // #2 0, Ly, 0; // #3 0, 0, Lz; // #4 Lx, Ly, 0; // #5 0, Ly, Lz; // #6 Lx, 0, Lz; // #7 Lx, Ly, Lz]; // #8 // Faces faces = [ 1, 2, 5, 3; // #1 1, 3, 6, 4; // #2 1, 4, 7, 2; // #3 4, 7, 8, 6; // #4 2, 5, 8, 7; // #5 3, 6, 8, 5]; // #6 // Patches patches = genpat(vertices, faces); // Draw patches h_fig = figure; h_fig.background = 8; h_pat = plot3d(patches.x, patches.y, patches.z); h_pat.color_mode = 4; h_pat.foreground = 1; h_pat.hiddencolor = 4; // Axes settings xlabel("x"); ylabel("y"); zlabel("z"); h_axes = gca(); h_axes.isoview = "on"; h_axes.box = "off"; h_axes.rotation_angles = [63.5, -127]; h_axes.data_bounds = [-0.2, -0.2, -0.1; 0.4, 0.3, 0.4]; xgrid;
function patches = genpat(vertices, faces) // Generate patches data from vertices and faces patches.x = vertices(:,1)(faces'); patches.y = vertices(:,2)(faces'); patches.z = vertices(:,3)(faces'); endfunction