Nhu cầu mô phỏng 3D

Một phần của tài liệu Tìm hiểu về đồ 3D Plug-in API và ứng dụng (Trang 37 - 45)

Công nghệ 3D hiện nay, đã có mặt hầu hết trong mọi ứng dụng của đời sống, 3D đã được ứng dụng trong: thiết kế kiến trúc, nội ngoại thất, gian hàng, hội chợ , Thiết kế mẫu 3D, nữ trang, thiết kế game 3d, phim hoạt hình 3d, quảng cáo, điện ảnh, giáo dục, mô phỏng thực tế ảo ...

Với công nghệ 3D giúp người thiết kế có thể xây dựng, mô tả nhiều đặc trưng của hệ thống cơ, một khi xây dựng xong mô hình, người thiết kế có thể tiến hành mô phỏng đặt các lực (ngẫu lực, trọng lực, lực tập trung, lực ma sát v.v) lên mô hình để khảo sát.

Cho phép mô phỏng nhiều dạng liên kết cơ bản như liên kết thanh, khớp quay, tời, rãnh trượt hay các liên kết phức tạp như bánh răng, motor, cơ cấu chấp hành, lò xo thẳng, lò xo xoắn, giảm chấn v.v. Thực hiện hiệu chỉnh quá trình mô phỏng với những công cụ tác động lên đối tượng với các ràng buộc cho trước. Có thể hiệu chỉnh các tham số trong những điều kiện môi trường khác nhau.

Có thể thực hiện, dừng, hiệu chỉnh lại quá trình mô phỏng tại bất kỳ thời điểm nào

Khả năng mô hình hóa cho các phương pháp phân tích . Kết quả có thể xuất ra dưới định dạng vector, giá trị số hay đồ thị với các hệ đơn vị khác nhau.

Giảm chi phí trong thiết kế tạo mẫu.

Có thể phân tích kết cấu tĩnh cho kết quả biểu đồ nội lực, mô phỏng quá trình thường gặp trong cuộc sống như tiếp xúc, va chạm, ma sát.

4.2 Xây dựng mô phỏng tƣơng tác vật lý sử dựng O3d Plugin Mô phỏng về lực đẩy cuả pittông

Mô phỏng về chuyền động của đối tƣợng

4.3.1 Mã nguồn minh họa

Tạo tham chiếu va thiết lập kích thước cho đối tượng

function setClientSize() {

var newWidth = g.client.width; var newHeight = g.client.height;

if (newWidth != g.o3dWidth || newHeight != g.o3dHeight) { g.o3dWidth = newWidth;

g.o3dHeight = newHeight;

// Create a perspective projection matrix(tao mot tham chieu diem trong ma tran)

g.viewInfo.drawContext.projection = g.math.matrix4.perspective( g.math.degToRad(45), g.o3dWidth / g.o3dHeight, 0.1, 5000);

// Sets a new area size for arcball.(thiet lap kich thuoc cho qua? cau)

g.aball.setAreaSize(g.o3dWidth, g.o3dHeight); }

}

Tạo ra một đồ thị và cài đặt nền màu

// Create the render graph for a view.(tao ra 1do thi) g.viewInfo = o3djs.rendergraph.createBasicView( g.pack,

g.client.root,

g.client.renderGraphRoot);

// Set the background color to black.(cai dat nên mau den) g.viewInfo.clearBuffer.clearColor = [0, 0, 0, 0];

// Set states for shards.(thiet lap gioi han cho manh) g.viewInfo.zOrderedState.getStateParam('CullMode').value = g.o3d.State.CULL_NONE; g.viewInfo.zOrderedState.getStateParam('DestinationBlendFunction').value = g.o3d.State.BLENDFUNC_ONE; g.viewInfo.zOrderedState.getStateParam('ZWriteEnable').value = false; g.viewInfo.performanceDrawPass.sortMethod = g.o3d.DrawList.BY_PRIORITY; g.lastRot = g.math.matrix4.identity(); g.thisRot = g.math.matrix4.identity(); var root = g.client.root;

Tạo ra tham số cho các vị trí mặt trời và mắt của chúng ta có thể nhìn được

// Create a param for the sun and eye positions that we can bind(tao 1tham so cho cac vi tri mat troi va mat cua chng ta co the nhin dc) ) // to auto update a bunch of materials.(de tu dong thiet lap cac nguyen vat lieu)

g.globalParams = g.pack.createObject('ParamObject');

g.sunPosParam = g.globalParams.createParam('sunPos', 'ParamFloat3'); g.sunPosParam.value = [1000, 200, 100];

g.eyePosParam = g.globalParams.createParam('eyePos', 'ParamFloat3'); updateViewFromCamera();

g.aball = o3djs.arcball.create(100, 100); setClientSize();

g.client.setRenderCallback(onRender);

Tạo ra vật liệu

// Create Materials.(tao vat lieu) var effectNames = [ "noTexture", "dayOnly", "nightAndDay", "mask", "energy", "atmosphere" ]; g.materials = [];

for (var ii = 0; ii < effectNames.length; ++ii) { var effectName = effectNames[ii];

var effect = g.pack.createObject('Effect');

effect.loadFromFXString(document.getElementById(effectName).value); // Create a Material for the effect.(tao ra 1vat lieu cho hieu luc) var material = g.pack.createObject('Material');

// Apply our effect to this material. The effect tells the 3D hardware(ap dung hieu ung)

// which shader to use.(do bong) material.effect = effect;

// Set the material's drawList(thiet lap cac tai lieu cua drawlist) material.drawList = g.viewInfo.performanceDrawList;

// This will create the effects's params on the material.(dieu nay tao ra cac hieu ung tren vat lieu)

Tạo ra nặng lượng kết cấu

// Create energy texture(s)(tao ra nang luong ket cau) {

var dots = [ 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0 ]; var texture = g.pack.createTexture2D(3,

dots.length,

g.o3d.Texture.XRGB8, 1,

false); var pixels = [];

for (var yy = 0; yy < dots.length; ++yy) { for (var xx = 0; xx < 3; ++xx) {

var pixelOffset = (yy * 3 + xx) * 3; var color = (xx == 1) ? dots[yy] : 0; for (var cc = 0; cc < 3; ++cc) { pixels[pixelOffset + cc] = color; } } } texture.set(0, pixels); g.energySampler.texture = texture; }

Tạo một hình cầu cho trái đất

// Create a sphere at the origin for the earth.(tao mot hinh cau cho trai dat)

var earth = o3djs.primitives.createSphere(g.pack,

g.noTextureMaterial, 25,

50, 50);

// Get a the element so we can set its material later. g.earthPrimitive = earth.elements[0]; g.atmosphereState = g.pack.createObject('State'); g.atmosphereState.getStateParam('AlphaBlendEnable').value = true; g.atmosphereState.getStateParam('SourceBlendFunction').value = g.o3d.State.BLENDFUNC_SOURCE_ALPHA; g.atmosphereState.getStateParam('DestinationBlendFunction').value = g.o3d.State.BLENDFUNC_INVERSE_SOURCE_ALPHA; g.atmosphereState.getStateParam('ZWriteEnable').value = false; g.atmosphereMaterial.state = g.atmosphereState; g.root = g.pack.createObject('Transform'); g.root.parent = g.client.root; g.earth = g.pack.createObject('Transform'); g.earth.addShape(earth); g.earth.parent = g.root;

// Create a sphere at the origin for the atmosphere.(tao hinh cau tai nguon goc cua khi quyen)

var atmosphere = o3djs.primitives.createSphere(g.pack,

g.atmosphereMaterial, 26, 50, 50); g.atmospherePrimitive = atmosphere.elements[0]; g.atmospherePrimitive.priority = 1; g.atmosphere = g.pack.createObject('Transform'); g.atmosphere.addShape(atmosphere); g.atmosphere.parent = g.root; g.energyShape = createEnergyShape(g.pack, g.energyMaterial, g.ENERGY_WIDTH, g.ENERGY_HEIGHT); addEnergyShard(0, 0, 1, 1, [1, 1, 1, 1]);

KẾT LUẬN

-

tác vật lý, mô phỏng về địa

lý, -

.

Trong tương lai em sẽ tiếp tục nghiên cứu thêm để có thể hoàn thiện hơn nữa về gia

.

Tuy nhiên do hạn chế về điều kiện và thời gian, khoá luận sẽ không thể tránh khỏi những thiếu xót. Kính mong được sự đóng góp ý kiến của thầy cô và các bạn để em có thể hoàn thiện hơn đề tài nghiên cứu của mình trong đợt làm khoá luận tốt nghiệp này.

TÀI LIỆU THAM KHẢO

[1.] James D.Foley, Andrie van Dam, Steven K.Feiner, Jonhn F. Hughes, Computer Graphics Principles and Practice, Addison Wesley, 1994.

[2.] Lê Tấn Hùng, Huỳnh Quyết Thắng. Kỹ thuật đồ hoạ máy tính, NXB khoa học và kỹ thuật, 2002.

[3.] Steven Harrington, Computer Graphics A Programming Approach, McGraw Hill International Edition, 1987.

Một phần của tài liệu Tìm hiểu về đồ 3D Plug-in API và ứng dụng (Trang 37 - 45)

Tải bản đầy đủ (PDF)

(45 trang)