import { LineSegmentsGeometry2 } from '../geometry/LineSegmentsGeometry2';
import { LineMaterial2 } from '../material/LineMaterial2';
import { IObject3D, IObject3DEventMap, IObject3DUserData } from '../IObject';
import { LineSegments2 } from 'three/examples/jsm/lines/LineSegments2.js';
import { IMaterial } from '../IMaterial';
export declare class MeshLineSegments<TGeometry extends LineSegmentsGeometry2 = LineSegmentsGeometry2, TMaterial extends LineMaterial2 = LineMaterial2, TE extends IObject3DEventMap = IObject3DEventMap> extends LineSegments2<TGeometry, TMaterial, TE> implements IObject3D<TE, TGeometry, TMaterial> {
    assetType: "model";
    setDirty: (this: IObject3D, options?: import('../IObject').IObjectSetDirtyOptions, ...args: any[]) => void;
    refreshUi: (this: IObject3D) => void;
    readonly isMeshLineSegments = true;
    material: TMaterial;
    readonly materials: IMaterial[];
    geometry: TGeometry;
    /**
     * @deprecated use `this` instead
     */
    get modelObject(): this;
    constructor(geometry?: TGeometry, material?: TMaterial);
    userData: IObject3DUserData;
    traverse: (callback: (object: IObject3D) => void) => void;
    traverseVisible: (callback: (object: IObject3D) => void) => void;
    traverseAncestors: (callback: (object: IObject3D) => void) => void;
    getObjectById: (id: number) => IObject3D | undefined;
    getObjectByName: (name: string) => IObject3D | undefined;
    getObjectByProperty: (name: string, value: string) => IObject3D | undefined;
    parent: IObject3D | null;
    children: IObject3D[];
    dispose: (removeFromParent?: boolean) => void;
}
//# sourceMappingURL=../../src/core/object/MeshLineSegments.d.ts.map