Вход/Регистрация
Введение в написание скриптов на Питоне для Блендера 2.5x. Примеры кода
вернуться

Larsson Thomas

Шрифт:

# File uvs.py

#----------------------------------------------------------

import bpy import os

def createMesh(origin):

# Создание меша и объекта

me = bpy.data.meshes.new('TetraMesh')

ob = bpy.data.objects.new('Tetra', me)

ob.location = origin

# Привязка объекта к сцене

scn = bpy.context.scene

scn.objects.link(ob)

scn.objects.active = ob scn.update

# Списки вершин и граней

verts = [

(1.41936, 1.41936, -1),

(0.589378, -1.67818, -1),

(-1.67818, 0.58938, -1),

(0, 0, 1)

]

faces = [(1,0,3), (3,2,1), (3,0,2), (0,1,2)]

# Создание меша из передаваемых списков вершин, рёбер, граней.

# Или рёбра или грани должны быть [], или Вам нужны проблемы

me.from_pydata(verts, [], faces)

# Обновление меша с новыми данными

me.update(calc_edges=True)

# Первый текстурный слой: Главная UV текстура (UVMain)

texFaces = [

[(0.6,0.6), (1,1), (0,1)],

[(0,1), (0.6,0), (0.6,0.6)],

[(0,1), (0,0), (0.6,0)],

[(1,1), (0.6,0.6), (0.6,0)]

]

uvMain = createTextureLayer("UVMain", me, texFaces)

# Второй текстурный слой: проекция спереди (UVFront)

texFaces = [

[(0.732051,0), (1,0), (0.541778,1)],

[(0.541778,1), (0,0), (0.732051,0)],

[(0.541778,1), (1,0), (0,0)],

[(1,0), (0.732051,0), (0,0)]

]

uvFront = createTextureLayer("UVFront", me, texFaces)

# Третий текстурный слой: Умная проекция

bpy.ops.mesh.uv_texture_add

uvCyl = me.uv_textures.active

uvCyl.name = 'UVCyl'

bpy.ops.object.mode_set(mode='EDIT')

bpy.ops.uv.cylinder_project

bpy.ops.object.mode_set(mode='OBJECT')

# Хотим сделать Главный слой активным, но, кажется, это не работает - TBF

me.uv_textures.active = uvMain

me.uv_texture_clone = uvMain

uvMain.active_render = True

uvFront.active_render = False

uvCyl.active_render = False

return ob

def createTextureLayer(name, me, texFaces):

uvtex = me.uv_textures.new

uvtex.name = name

for n,tf in enumerate(texFaces):

datum = uvtex.data[n]

datum.uv1 = tf[0]

datum.uv2 = tf[1]

datum.uv3 = tf[2]

return uvtex

def createMaterial:

# Создание текстуры image из картинки. Измените здесь, если

# каталог snippet расположен не в Вашем домашнем каталоге.

realpath = os.path.expanduser('~/snippets/textures/color.png')

tex = bpy.data.textures.new('ColorTex', type = 'IMAGE')

tex.image = bpy.data.images.load(realpath)

tex.use_alpha = True 

# Создание незатеняемого материала и MTex

mat = bpy.data.materials.new('TexMat')

  • Читать дальше
  • 1
  • ...
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • ...

Ебукер (ebooker) – онлайн-библиотека на русском языке. Книги доступны онлайн, без утомительной регистрации. Огромный выбор и удобный дизайн, позволяющий читать без проблем. Добавляйте сайт в закладки! Все произведения загружаются пользователями: если считаете, что ваши авторские права нарушены – используйте форму обратной связи.

Полезные ссылки

  • Моя полка

Контакты

  • chitat.ebooker@gmail.com

Подпишитесь на рассылку: