1.1.0 • Published 5 years ago
@cofrico/3d-objects v1.1.0
Objects-3d
Object-3d is build on top of react-three-fiber, a react reconciler for ThreeJS. Provides an abstraction for manage 3d objects easily
Install
npm install @cofrico/3d-objectsUsage
import  React  from  'react'
import { Layout } from  '@cofrico/layout-3d'
import { Object3d, Room } from  '@cofrico/layout-3d'
const FBXLoader = __CLIENT__ && require('three/examples/jsm/loaders/FBXLoader').FBXLoader
const  App = () => {
	return {
	<Layout>
    <Object3D
      id="123"
      type="type1"
      objectURL="/evaporador.fbx"
      loader={FBXLoader}
      position={[10, 0, 1]}
    />
    <Room
      nodes={[[-5, 5], [5, 5], [5, -5], [-5, -5]]}
      height={5}
      doors={[{ width: 2, height: 4, offset: 3, roomFaceIndex: 1 }]}
    >
      <Object3D
        id="456"
        type="type1"
        objectURL="/evaporador.fbx"
        loader={FBXLoader}
        position={[0, 0, 0]}
      />
    </Room>
  </Layout>
	}
}Object3D Options
A wrapper to create objects from 3d object file without pain
| Name | Type | Description | Default | Required | 
|---|---|---|---|---|
| objectURL | string | path to object file | true | |
| loader | object | Can be FBXLoader, OBJLoader or any other ThreeJs loader | true | |
| position | array | Array of 3d coordinates | 0, 0, 0 | false | 
| rotation | array | Array of 3d coordinates | 0, 0, 0 | false | 
| selected | bool | Set object as selected or not | false | false | 
| selectedColor | string | Color used when the object is selected. Can be a hex, or other css color type | 'red' | false | 
| userData | object | An object that can be used to store custom data | { } | false | 
Room Options
A wrapper to create rooms (extrude structures) from parameters. Rooms can have childs like other Rooms or Object3D
###Door options A room can have many doors. Each one can be defined with this options
| Name | Type | Description | Default | Required | 
|---|---|---|---|---|
| roomFaceIndex | number | An index representing a room face, in the same order than room nodes | true | |
| width | number | Door with | true | |
| heigh | number | Door height | true | |
| offset | number | Offset from right corner of the room to position the door | 0 | false | 
| color | string | Color used when the object is selected. Can be a hex, or other css color type | '#dcdcdcf' | false | 
| opacity | number | The opacity of the door | 0.5 | false | 
Example
You have a simple playground to show the objects usage in /example folder. To run it, simply install the dependencies with yarn or npm install and run it from /example directory with yarn start. Then you can go to localhost:3000 to see the example working
License
MIT © Glue Digital(https://github.com/Glue Digital)