PcoWSkbVqDnWTu_dm2ix
The Developer Hub is now deprecated and information on this page may no longer be accurate. To see our new and improved documentation, please click here. You can read more about the future of documentation here.
Collapse Sidebar

MeshPart

Show deprecated

MeshPart

Show deprecated

MeshParts are a form of BasePart that includes a physically simulated custom mesh. Unlike with other mesh classes, such as SpecialMesh and BlockMesh, they are not parented to a BasePart but rather behave as a BasePart in their own right.

How do I use MeshParts

The mesh and texture of a MeshPart are determined by the MeshPart/MeshId and MeshPart/TextureID properties. For more information on how to use MeshParts please see Articles/Mesh Parts|here.

SpecialMesh or MeshPart?

There are currently two ways of using a developer created mesh. They are using a SpecialMesh with the SpecialMesh/FileType set to ‘FileMesh’, or by using a MeshPart. Although, on the whole, the MeshPart object has superseded the SpecialMesh there are some differences developers should be aware of.

  • BasePart/Material displays correctly on the mesh when using a MeshPart and not when using a SpecialMesh
  • MeshParts include the MeshPart/CollisionFidelity property, meaning the collision model of a MeshPart can be set to resemble the geometry of the mesh. The SpecialMesh object by contrast, uses the parent BaseParts collision model
  • The mesh of a MeshPart scales on all axis depending on the BasePart/Size property of the MeshPart, the mesh of a SpecialMesh does not
  • The SpecialMesh object includes the DataModelMesh/Offset and DataModelMesh/Scale properties whereas MeshParts do not
  • The DataModelMesh/MeshId property of a SpecialMesh can be changed by a Script or LocalScript during runtime. The MeshPart/MeshId property of a MeshPart can not

In most, but not all cases, using a MeshPart is more suitable. As MeshParts are a relatively new feature however, developers should expect some of the above behaviour to change.

Properties

bool

DoubleSided

Render both faces of polygons in the mesh

bool

HasJointOffset

[Hidden]
bool

HasSkinnedMesh

[Hidden]
Vector3

JointOffset

[Hidden]
Content

MeshID

[NotScriptable] [Deprecated]

The MeshId is the content ID of the mesh that is to be displayed on the MeshPart

Content

MeshId

The MeshId is the content ID of the mesh that is to be displayed on the MeshPart

Vector3

MeshSize

[ReadOnly] [NotReplicated]
RenderFidelity

RenderFidelity

[NotReplicated]

Determines the level of detail that solid-modeled and mesh parts will be shown in

Content

TextureID

The texture applied to the MeshPart.

Inherited from BasePart: Show Hide

bool

Anchored

Determines whether a part is immovable by physics

Vector3

AssemblyAngularVelocity

[NotReplicated]

The angular velocity of the part’s assembly

Vector3

AssemblyCenterOfMass

[ReadOnly] [NotReplicated]

The center of mass of the part’s assembly in world space

Vector3

AssemblyLinearVelocity

[NotReplicated]

The linear velocity of the part’s assembly

float

AssemblyMass

[ReadOnly] [NotReplicated]

The total mass of the part’s assembly

BasePart

AssemblyRootPart

[ReadOnly] [NotReplicated]

A reference to the root part of the assembly

float

BackParamA

[Hidden] [Deprecated]

Determines the first parameter for the SurfaceType on the Back face of a part (+Z direction)

float

BackParamB

[Hidden] [Deprecated]

Determines the second parameter for the SurfaceType on the Back face of a part (+Z direction)

SurfaceType

BackSurface

Determines the type of surface for the Back face of a part (+Z direction)

InputType

BackSurfaceInput

[Hidden] [Deprecated]

Determines the kind of input for the Back face of a part (+Z direction)

float

BottomParamA

[Hidden] [Deprecated]

Determines the first parameter for the SurfaceType on the Bottom face of a part (-Y direction)

float

BottomParamB

[Hidden] [Deprecated]

Determines the second parameter for the SurfaceType on the Bottom face of a part (-Y direction)

SurfaceType

BottomSurface

Determines the type of surface for the Bottom face of a part (-Y direction)

InputType

BottomSurfaceInput

[Hidden] [Deprecated]

Determines the kind of input for the Bottom face of a part (-Y direction)

BrickColor

BrickColor

[NotReplicated]

Determines the color of a part.

CFrame

CFrame

Determines the position and rotation of a part in the world

bool

CanCollide

Determines whether a part may collide with other parts.

bool

CanQuery

Determines whether the part is considered during spatial query operations

bool

CanTouch

Determines if the part will trigger BasePart/Touched|Touched/BasePart/TouchEnded|TouchEnded events on other BasePart|BaseParts with TouchTransmitter|TouchTransmitters

bool

CastShadow

Determines whether or not a part casts a shadow.

Vector3

CenterOfMass

[ReadOnly] [NotReplicated]

Describes the world position in which a part’s center of mass is located.

int

CollisionGroupId

Describes the automatically-set ID number of a part’s collision group

Color3

Color

[NotReplicated]

Determines the color of a part.

PhysicalProperties

CustomPhysicalProperties

Determines several physical properties of a part

float

Elasticity

[Hidden] [NotReplicated] [Deprecated]

Used to control the Elasticity of the part, but it no longer does anything

float

Friction

[Hidden] [NotReplicated] [Deprecated]

Used to control the Friction of the part, but now it no longer does anything.

float

FrontParamA

[Hidden] [Deprecated]

Determines the first parameter for the SurfaceType on the Front face of a part (-Z direction)

float

FrontParamB

[Hidden] [Deprecated]

Determines the second parameter for the SurfaceType on the Front face of a part (-Z direction)

SurfaceType

FrontSurface

Determines the type of surface for the Front face of a part (-Z direction)

InputType

FrontSurfaceInput

[Hidden] [Deprecated]

Determines the kind of input for the Front face of a part (-Z direction)

float

LeftParamA

[Hidden] [Deprecated]

Determines the first parameter for the SurfaceType on the Left face of a part (-Z direction)

float

LeftParamB

[Hidden] [Deprecated]

Determines the second parameter for the SurfaceType on the Left face of a part (-Z direction)

SurfaceType

LeftSurface

Determines the type of surface for the Left face of a part (-X direction)

InputType

LeftSurfaceInput

[Hidden] [Deprecated]

Determines the kind of input for the Left face of a part (+X direction)

float

LocalTransparencyModifier

[Hidden] [NotReplicated]

Determines a multiplier for BasePart/Transparency that is only visible to the local client

bool

Locked

Determines whether a part is selectable in Studio.

float

Mass

[ReadOnly] [NotReplicated]

Describes the mass of the part, the product of its density and volume

bool

Massless

Determines whether the part contributes to the total mass or inertia of its rigid body

Material

Material

Determines the texture and default physical properties of a part

Vector3

Orientation

[NotReplicated]

Describes the position of the part in the world

CFrame

PivotOffset

Specifies the offset of the part’s pivot from its datatype/CFrame.

Vector3

Position

[NotReplicated]

Describes the position of the part in the world

float

ReceiveAge

[Hidden] [ReadOnly] [NotReplicated]

Time since last recorded physics update

float

Reflectance

Determines how much a part reflects the skybox.

int

ResizeIncrement

[ReadOnly] [NotReplicated]

Describes the smallest change in size allowable by the Resize method

Faces

ResizeableFaces

[ReadOnly] [NotReplicated]

Describes the faces on which a part may be resized

float

RightParamA

[Hidden] [Deprecated]

Determines the first parameter for the SurfaceType on the Right face of a part (-X direction)

float

RightParamB

[Hidden] [Deprecated]

Determines the second parameter for the SurfaceType on the Right face of a part (-X direction)

SurfaceType

RightSurface

Determines the type of surface for the Right face of a part (+X direction)

InputType

RightSurfaceInput

[Hidden] [Deprecated]

Determines the kind of input for the Right face of a part (-X direction)

int

RootPriority

The main rule in determining the root part of an assembly

Vector3

RotVelocity

[Hidden] [Deprecated]

Determines a part’s change in orientation over time

Vector3

Rotation

[NotReplicated]

The rotation of the part in degrees for the three axes

Vector3

Size

[NotReplicated]

Determines the dimensions of a part (length, width, height)

float

SpecificGravity

[ReadOnly] [NotReplicated] [Deprecated]

The ratio of the part’s density to the density of water determined by the BasePart/Material

float

TopParamA

[Hidden] [Deprecated]

Determines the first parameter for the SurfaceType on the Top face of a part (+Y direction)

float

TopParamB

[Hidden] [Deprecated]

Determines the second parameter for the SurfaceType on the Top face of a part (+Y direction)

SurfaceType

TopSurface

Determines the type of surface for the Top face of a part (+Y direction)

InputType

TopSurfaceInput

[Hidden] [Deprecated]

Determines the kind of input for the Top face of a part (+Y direction)

float

Transparency

Determines how much a part can be seen through (the inverse of part opacity)

Vector3

Velocity

[Hidden] [Deprecated]

Determines a part’s change in position over time

BrickColor

brickColor

[NotReplicated] [Deprecated]

Inherited from PVInstance: Show Hide

Vector3

Origin Orientation

[NotReplicated] [NotScriptable]

Editor-only property used to rotate the object around its pivot. Scripts must use PVInstance/PivotTo instead.

Vector3

Origin Position

[NotReplicated] [NotScriptable]

Editor-only property used to move the object. Scripts must use PVInstance/PivotTo instead.

Vector3

Pivot Offset Orientation

[NotReplicated] [NotScriptable]

Editor-only property to set the orientation of the pivot relative to a part. Scripts must use BasePart/PivotOffset instead.

Vector3

Pivot Offset Position

[NotReplicated] [NotScriptable]

Editor-only property to set the position of the pivot relative to a part. Scripts must use BasePart/PivotOffset instead.

Inherited from Instance: Show Hide

bool

Archivable

Determines if an Instance can be cloned using /Instance/Clone or saved to file.

string

ClassName

[ReadOnly] [NotReplicated]

A read-only string representing the class this Instance belongs to

int

DataCost

[Hidden] [ReadOnly] [NotReplicated] [Deprecated]

The cost of saving the instance using data persistence.

string

Name

A non-unique identifier of the Instance

Instance

Parent

[NotReplicated]

Determines the hierarchical parent of the Instance

bool

RobloxLocked

[Hidden]

A deprecated property that used to protect CoreGui objects

int64

SourceAssetId

[Hidden] [NotReplicated]
bool

archivable

[Hidden] [NotReplicated] [Deprecated]
string

className

[ReadOnly] [NotReplicated] [Deprecated]

Functions

void

ApplyMesh ( Instance meshPart )

Inherited from BasePart: Show Hide

void

ApplyAngularImpulse ( Vector3 impulse )

Apply an angular impulse to the assembly

void

ApplyImpulse ( Vector3 impulse )

Apply an impulse to the assembly at the assembly’s BasePart/AssemblyCenterOfMass|center of mass

void

ApplyImpulseAtPosition ( Vector3 impulse , Vector3 position )

Apply an impulse to the assembly at specified position

void

BreakJoints ( )

Breaks any surface connection with any adjacent part, including Weld and other JointInstance.

bool

CanCollideWith ( BasePart part )

Returns whether the parts can collide with each other.

Tuple

CanSetNetworkOwnership ( )

Checks whether you can set a BasePart|part's network ownership

Objects

GetConnectedParts ( bool recursive )

Returns a table of parts connected to the the object by any kind of rigid joint.

Objects

GetJoints ( )

Return all Joints or Constraints that is connected to this Part.

float

GetMass ( )

Returns the value of the BasePart/Mass|Mass property.

Instance

GetNetworkOwner ( )

Returns the current player who is the network owner of this part, or nil in case of the server.

bool

GetNetworkOwnershipAuto ( )

Returns true if the game engine automatically decides the network owner for this part.

CFrame

GetRenderCFrame ( )

[Deprecated]

(OBSOLETE) Returns a CFrame describing where the part is being rendered at

Instance

GetRootPart ( )

Returns the base part of an assembly of parts

Objects

GetTouchingParts ( )

Returns a table of all BasePart/CanCollide true parts that intersect with this part

Vector3

GetVelocityAtPosition ( Vector3 position )

bool

IsGrounded ( )

Returns true if the object is connected to a part that will hold it in place (eg an BasePart/Anchored part), otherwise returns false.

void

MakeJoints ( )

Creates a joint on any side of the object that has a surface ID that can make a joint

bool

Resize ( NormalId normalId , int deltaAmount )

Changes the size of an object just like using the Studio resize tool.

void

SetNetworkOwner ( Player playerInstance )

Sets the given player as network owner for this and all connected parts

void

SetNetworkOwnershipAuto ( )

Lets the game engine dynamically decide who will handle the part’s physics (one of the clients or the server).

Instance

SubtractAsync ( Objects parts , CollisionFidelity collisionfidelity , RenderFidelity renderFidelity )

[Yields]

Creates a new UnionOperation which occupies the same space as the part minus the space(s) occupied by the parts in the given array.

Instance

UnionAsync ( Objects parts , CollisionFidelity collisionfidelity , RenderFidelity renderFidelity )

[Yields]

Performs a Union operation on the calling BasePart and the list of parts passed in as the first parameter

void

breakJoints ( )

[Deprecated]
float

getMass ( )

[Deprecated]
void

makeJoints ( )

[Deprecated]
bool

resize ( NormalId normalId , int deltaAmount )

[Deprecated]

Inherited from PVInstance: Show Hide

CFrame

GetPivot ( )

Gets the pivot of a PVInstance.

void

PivotTo ( CFrame targetCFrame )

Transforms the PVInstance along with all of its descendant PVInstance|PVInstances such that the pivot is now located at the specified datatype/CFrame.

Inherited from Instance: Show Hide

void

ClearAllChildren ( )

This function destroys all of an Instance’s children.

Instance

Clone ( )

Create a copy of an object and all its descendants, ignoring objects that are not Instance/Archivable|Archivable

void

Destroy ( )

Sets the Instance/Parent property to nil, locks the Instance/Parent property, disconnects all connections, and calls Destroy on all children.

Instance

FindFirstAncestor ( string name )

Returns the first ancestor of the Instance whose Instance/Name is equal to the given name.

Instance

FindFirstAncestorOfClass ( string className )

Returns the first ancestor of the Instance whose Instance/ClassName is equal to the given className.

Instance

FindFirstAncestorWhichIsA ( string className )

Returns the first ancestor of the Instance for whom Instance/IsA returns true for the given className.

Instance

FindFirstChild ( string name , bool recursive )

Returns the first child of the Instance found with the given name.

Instance

FindFirstChildOfClass ( string className )

Returns the first child of the Instance whose Instance/ClassName|ClassName is equal to the given className.

Instance

FindFirstChildWhichIsA ( string className , bool recursive )

Returns the first child of the Instance for whom Instance/IsA returns true for the given className.

Instance

FindFirstDescendant ( string name )

Returns the first descendant found with the given Instance/Name.

Actor

GetActor ( )

Returns the Actor associated with the Instance, usually the first Actor ancestor

Variant

GetAttribute ( string attribute )

Returns the attribute which has been assigned to the given name

RBXScriptSignal

GetAttributeChangedSignal ( string attribute )

Returns an event that fires when the given attribute changes

Dictionary

GetAttributes ( )

Returns a dictionary of string → variant pairs for each of the Instance|Instance’s attributes

Objects

GetChildren ( )

Returns an array containing all of the Instance’s children.

string

GetDebugId ( int scopeLength )

[NotBrowsable]

Returns a coded string of the Instances DebugId used internally by Roblox.

Array

GetDescendants ( )

[CustomLuaState]

Returns an array containing all of the descendants of the instance

string

GetFullName ( )

Returns a string describing the Instance’s ancestry.

RBXScriptSignal

GetPropertyChangedSignal ( string property )

Get an event that fires when a given property of an object changes.

bool

IsA ( string className )

[CustomLuaState]

Returns true if an Instance’s class matches or inherits from a given class

bool

IsAncestorOf ( Instance descendant )

Returns true if an Instance is an ancestor of the given descendant.

bool

IsDescendantOf ( Instance ancestor )

Returns true if an Instance is a descendant of the given ancestor.

void

Remove ( )

[Deprecated]

Sets the object’s Parent to nil, and does the same for all its descendants.

void

SetAttribute ( string attribute , Variant value )

Sets the attribute with the given name to the given value

Instance

WaitForChild ( string childName , double timeOut )

[CustomLuaState] [CanYield]

Returns the child of the Instance with the given name. If the child does not exist, it will yield the current thread until it does.

Objects

children ( )

[Deprecated]

Returns an array of the object’s children.

Instance

clone ( )

[Deprecated]
void

destroy ( )

[Deprecated]
Instance

findFirstChild ( string name , bool recursive )

[Deprecated]
Objects

getChildren ( )

[Deprecated]
bool

isA ( string className )

[Deprecated] [CustomLuaState]
bool

isDescendantOf ( Instance ancestor )

[Deprecated]
void

remove ( )

[Deprecated]

Events

Inherited from BasePart: Show Hide

RBXScriptSignal

LocalSimulationTouched ( BasePart part )

[Deprecated]

.

RBXScriptSignal

OutfitChanged ( )

[Deprecated]

.

RBXScriptSignal

StoppedTouching ( BasePart otherPart )

[Deprecated]

.

RBXScriptSignal

TouchEnded ( BasePart otherPart )

Fired when a part stops touching another part.

RBXScriptSignal

Touched ( BasePart otherPart )

Fired when a part comes in contact with another part

Inherited from Instance: Show Hide

RBXScriptSignal

AncestryChanged ( Instance child , Instance parent )

Fires when the Instance/Parent property of the object or one of its ancestors is changed.

RBXScriptSignal

AttributeChanged ( string attribute )

Fires whenever an attribute is changed on the Instance

RBXScriptSignal

Changed ( string property )

Fired immediately after a property of an object changes.

RBXScriptSignal

ChildAdded ( Instance child )

Fires after an object is parented to this Instance.

RBXScriptSignal

ChildRemoved ( Instance child )

Fires after a child is removed from this Instance.

RBXScriptSignal

DescendantAdded ( Instance descendant )

Fires after a descendant is added to the Instance

RBXScriptSignal

DescendantRemoving ( Instance descendant )

Fires immediately before a descendant of the Instance is removed.

RBXScriptSignal

Destroying ( )

Fires immediately before the instance is destroyed via Instance/Destroy.

RBXScriptSignal

childAdded ( Instance child )

[Deprecated]