Module sverchok.utils.curve.bakery

Expand source code
# This file is part of project Sverchok. It's copyrighted by the contributors
# recorded in the version control history of the file, available from
# its original location https://github.com/nortikin/sverchok/commit/master
#
# SPDX-License-Identifier: GPL3
# License-Filename: LICENSE

import numpy as np

import bpy

from sverchok.utils.curve.nurbs import SvNurbsCurve
from sverchok.utils.sv_logging import get_logger


def curve_to_meshdata(curve, resolution):
    t_min, t_max = curve.get_u_bounds()
    ts = np.linspace(t_min, t_max, num=resolution)
    points = curve.evaluate_array(ts).tolist()
    edges = [(i,i+1) for i in range(resolution-1)]
    return points, edges

def bake_curve(curve, resolution, object_name):
    points, edges = curve_to_meshdata(curve, resolution)
    me = bpy.data.meshes.new(object_name)
    me.from_pydata(points, edges, [])
    ob = bpy.data.objects.new(object_name, me)
    bpy.context.scene.collection.objects.link(ob)
    return ob

class CurveData(object):
    def __init__(self, node, curve, resolution):
        self.node = node
        self.curve = curve
        self._nurbs_curve = None
        self.resolution = resolution

        logger = get_logger()

        if node.draw_line or node.draw_verts or node.draw_comb or node.draw_curvature:
            t_min, t_max = curve.get_u_bounds()
            ts = np.linspace(t_min, t_max, num=resolution)
            n = len(ts)
            self.points = curve.evaluate_array(ts).tolist()
        else:
            self.points = None

        if node.draw_line or node.draw_curvature:
            self.edges = [(i,i+1) for i in range(n-1)]
        else:
            self.edges = None

        self.control_points = None
        if (node.draw_control_polygon or node.draw_control_points):
            try:
                if hasattr(curve, 'get_control_points'):
                    cpts = curve.get_control_points().tolist()
                    if cpts:
                        self.control_points = cpts
                if self.control_points is None and self.nurbs_curve is not None:
                    self.control_points = self.nurbs_curve.get_control_points().tolist()
            except Exception as e:
                logger.debug(f"Can't get control points for {curve}: {e}")

        if node.draw_control_polygon and self.control_points is not None:
            n = len(self.control_points)
            self.control_polygon_edges = [(i,i+1) for i in range(n-1)]
        else:
            self.control_polygon_edges = None

        self.node_points = None
        if node.draw_nodes:
            if hasattr(curve, 'calc_greville_points'):
                self.node_points = curve.calc_greville_points().tolist()
            elif self.nurbs_curve is not None:
                self.node_points = self.nurbs_curve.calc_greville_points().tolist()

        if node.draw_comb or node.draw_curvature:
            self.curvatures = curve.curvature_array(ts)
        else:
            self.curvatures = None

        if node.draw_comb:
            n = len(self.points)
            normals = curve.main_normal_array(ts, normalize=True)
            curvatures = self.curvatures[np.newaxis].T
            comb_normals = node.comb_scale * curvatures * normals
            comb_points = self.points - comb_normals
            self.comb_points = np.concatenate((self.points, comb_points)).tolist()
            comb_normal_edges = [(i, i+n) for i in range(n)]
            comb_tangent_edges = [(i, i+1) for i in range(n, 2*n-1)]
            self.comb_edges = comb_normal_edges + comb_tangent_edges
        else:
            self.comb_points = None
            self.comb_edges = None

        if node.draw_curvature:
            color1 = np.array(node.line_color)
            color2 = np.array(node.curvature_color)
            #curvatures = np.tanh(self.curvatures)
            curvatures = self.curvatures
            c, C = curvatures.min(), curvatures.max()
            coefs = (curvatures - c) / (C - c)
            coefs = coefs[np.newaxis].T
            self.curvature_point_colors = (1 - coefs) * color1 + coefs * color2
            self.curvature_edge_colors = 0.5 * (self.curvature_point_colors[1:] + self.curvature_point_colors[:-1])
        else:
            self.curvature_point_colors = None
            self.curvature_edge_colors = None

    @property
    def nurbs_curve(self):
        if self._nurbs_curve is None:
            self._nurbs_curve = SvNurbsCurve.to_nurbs(self.curve)
        return self._nurbs_curve

    def bake(self, object_name):
        me = bpy.data.meshes.new(object_name)
        me.from_pydata(self.points, self.edges, [])
        ob = bpy.data.objects.new(object_name, me)
        bpy.context.scene.collection.objects.link(ob)
        return ob

Functions

def bake_curve(curve, resolution, object_name)
Expand source code
def bake_curve(curve, resolution, object_name):
    points, edges = curve_to_meshdata(curve, resolution)
    me = bpy.data.meshes.new(object_name)
    me.from_pydata(points, edges, [])
    ob = bpy.data.objects.new(object_name, me)
    bpy.context.scene.collection.objects.link(ob)
    return ob
def curve_to_meshdata(curve, resolution)
Expand source code
def curve_to_meshdata(curve, resolution):
    t_min, t_max = curve.get_u_bounds()
    ts = np.linspace(t_min, t_max, num=resolution)
    points = curve.evaluate_array(ts).tolist()
    edges = [(i,i+1) for i in range(resolution-1)]
    return points, edges

Classes

class CurveData (node, curve, resolution)
Expand source code
class CurveData(object):
    def __init__(self, node, curve, resolution):
        self.node = node
        self.curve = curve
        self._nurbs_curve = None
        self.resolution = resolution

        logger = get_logger()

        if node.draw_line or node.draw_verts or node.draw_comb or node.draw_curvature:
            t_min, t_max = curve.get_u_bounds()
            ts = np.linspace(t_min, t_max, num=resolution)
            n = len(ts)
            self.points = curve.evaluate_array(ts).tolist()
        else:
            self.points = None

        if node.draw_line or node.draw_curvature:
            self.edges = [(i,i+1) for i in range(n-1)]
        else:
            self.edges = None

        self.control_points = None
        if (node.draw_control_polygon or node.draw_control_points):
            try:
                if hasattr(curve, 'get_control_points'):
                    cpts = curve.get_control_points().tolist()
                    if cpts:
                        self.control_points = cpts
                if self.control_points is None and self.nurbs_curve is not None:
                    self.control_points = self.nurbs_curve.get_control_points().tolist()
            except Exception as e:
                logger.debug(f"Can't get control points for {curve}: {e}")

        if node.draw_control_polygon and self.control_points is not None:
            n = len(self.control_points)
            self.control_polygon_edges = [(i,i+1) for i in range(n-1)]
        else:
            self.control_polygon_edges = None

        self.node_points = None
        if node.draw_nodes:
            if hasattr(curve, 'calc_greville_points'):
                self.node_points = curve.calc_greville_points().tolist()
            elif self.nurbs_curve is not None:
                self.node_points = self.nurbs_curve.calc_greville_points().tolist()

        if node.draw_comb or node.draw_curvature:
            self.curvatures = curve.curvature_array(ts)
        else:
            self.curvatures = None

        if node.draw_comb:
            n = len(self.points)
            normals = curve.main_normal_array(ts, normalize=True)
            curvatures = self.curvatures[np.newaxis].T
            comb_normals = node.comb_scale * curvatures * normals
            comb_points = self.points - comb_normals
            self.comb_points = np.concatenate((self.points, comb_points)).tolist()
            comb_normal_edges = [(i, i+n) for i in range(n)]
            comb_tangent_edges = [(i, i+1) for i in range(n, 2*n-1)]
            self.comb_edges = comb_normal_edges + comb_tangent_edges
        else:
            self.comb_points = None
            self.comb_edges = None

        if node.draw_curvature:
            color1 = np.array(node.line_color)
            color2 = np.array(node.curvature_color)
            #curvatures = np.tanh(self.curvatures)
            curvatures = self.curvatures
            c, C = curvatures.min(), curvatures.max()
            coefs = (curvatures - c) / (C - c)
            coefs = coefs[np.newaxis].T
            self.curvature_point_colors = (1 - coefs) * color1 + coefs * color2
            self.curvature_edge_colors = 0.5 * (self.curvature_point_colors[1:] + self.curvature_point_colors[:-1])
        else:
            self.curvature_point_colors = None
            self.curvature_edge_colors = None

    @property
    def nurbs_curve(self):
        if self._nurbs_curve is None:
            self._nurbs_curve = SvNurbsCurve.to_nurbs(self.curve)
        return self._nurbs_curve

    def bake(self, object_name):
        me = bpy.data.meshes.new(object_name)
        me.from_pydata(self.points, self.edges, [])
        ob = bpy.data.objects.new(object_name, me)
        bpy.context.scene.collection.objects.link(ob)
        return ob

Instance variables

var nurbs_curve
Expand source code
@property
def nurbs_curve(self):
    if self._nurbs_curve is None:
        self._nurbs_curve = SvNurbsCurve.to_nurbs(self.curve)
    return self._nurbs_curve

Methods

def bake(self, object_name)
Expand source code
def bake(self, object_name):
    me = bpy.data.meshes.new(object_name)
    me.from_pydata(self.points, self.edges, [])
    ob = bpy.data.objects.new(object_name, me)
    bpy.context.scene.collection.objects.link(ob)
    return ob