csv>python>blender
Clan Afficionado
Inscrit:
17/07/2018 08:26
Post(s): 94
coucou les cocus
ah non, pardon bonjour
sur une base de données de 3 lignes et 4 colonnes
je n'obtiens que la ligne 3 à l'écran (pas les deux premières)
où ai-je faux ?

import bpy, csv

def event_text(event):
    bpy.ops.object.text_add()
    ob = bpy.context.object      
    curve = ob.data
    curve.body = "%s"%event
    bpy.context.active_object.location=(float(lat),float(lon),float(date))

file = '\\Users\essai.csv'

with open( file ) as csvfile:
    rdr = csv.reader( csvfile )
    for row in rdr:
        lat, lon, date, event = row[0], row[1], row[2], row[3]

print(lat, lon, date, event)

event_text(event)

Contribution le : 05/03 15:15:00
Créer un fichier PDF de la contribution Imprimer


Re: csv>python>blender
OverdOzed
Inscrit:
16/01/2011 17:05
De Le plus grand terrier du monde ! Et le plus high-tech.
Post(s): 4074
Bonjour,

Le print est hors de la boucle, donc tu n'as que le résultat final, donc la dernière ligne.

Au fait, petite astuce pour gagner du temps à l'écriture:

lat, lon, date, event = row[0], row[1], row[2], row[3]

Si tu as exactement 4 colonnes dans ta ligne, tu peux remplacer ça ↑ par ça:
lat, lon, date, event = row

C'est équivalent, mais moins pénible à écrire :)

Contribution le : 06/03 13:44:26
Créer un fichier PDF de la contribution Imprimer


Re: csv>python>blender
Clan Afficionado
Inscrit:
17/07/2018 08:26
Post(s): 94
merci @lapineige !
évidemment, les alinéas...
merci !
ps : je ne suis pas certain de ne pas devoir rajouter des colonnes à l'avenir

Contribution le : 08/03 08:49:32
Créer un fichier PDF de la contribution Imprimer


Re: csv>python>blender
Clan Afficionado
Inscrit:
17/07/2018 08:26
Post(s): 94
bon, je progresse, mais j'ai toujours des difficultés pour intégrer dans la boucle : quand je fais la
def camera():
je ne dois pas intégrer la création de caméra dans la boucle, sinon, j'aurai autant de camera que de lignes...

import bpy, csv
from math import pi #useful for text and camera rotation_euler

def event_text(event):
    bpy.ops.object.text_add()
    ob = bpy.context.object      
    curve = ob.data
    curve.body = "%s"%event
    bpy.context.active_object.location=(float(x),float(y),float(z))
    bpy.context.active_object.rotation_euler=(pi*90/180,0,0)
    
def camera_frames():
    camera1 = bpy.data.cameras.new("Camera 1")
    camera1.type = 'ORTHO'
    camera1.lens = 18
    camera_obj1 = bpy.data.objects.new("Camera 1", camera1)
    camera_obj1.location = (x, y, z)
    camera_obj1.rotation_euler = (pi*90/180, 0, 0)
    scn.collection.objects.link(camera_obj1)

#define scene
scn = bpy.context.scene

#extraire les donnees du fichier csv :

file = '\\Users\essai.csv'

with open( file ) as csvfile:
    rdr = csv.reader( csvfile )
    for row in rdr:
        x, y, z, event = row[0], row[1], row[2], row[3]
        print(x, y, z, event)
        #creer les blocs textes 
        event_text(event)
        camera_frames
        
#pour la camera :
#dans un fichier csv organisé comme ceci :
#ligne 0 : x,y,z (cette ligne n'existe pas)
#ligne 1 : 1,2,3 (ou x1, y1, z1)
#ligne 2 : 2,4,6 (ou x2, y2, z2)
#ligne 3 : 3,9,12 (ou x3, y3, z3)
#creer la camera
#extraire les coordonnees x,y,z du fichier csv

#pour chaque ligne du fichier csv :
    #1-une frame de début
    #2-rester 5 secondes (soit 5*24 = 120 frames) au même endroit
    #3-une frame de fin
    #4-et environ 3 secondes pour déplacer la caméra jusqu'au point suivant (soit 3*24 = 72 frames)
#je suppose que Blender fera automatiquement le déplacement en courbe de Bézier, mais c'est un moindre problème.
    # et on recommence en 1
    
    #placer la camera aux coordonnées de la ligne 1 : (x1)-3, (y1)-3, (z1)
    #ajouter une keyframe à la frame 0 pour la ligne 1
    #laisser la camera au même endroit 5 secondes (1*5*24 = 120)
    #déplacer la camera aux coordonnees de la ligne 2 (x2)-3, (y2)-3, (z2)
    
    #placer la camera devant les coordonnées de la ligne 2 : (x2)-3, (y2)-3, (z2)
    #etc.
#enregistrer les images en .avi

#je vois bien qu'il y a une itération : 2 keyframes, une de début et une de fin à chaque ligne du fichier csv,
#mais je ne sais pas comment l'intégrer dans la boucle...

Merci à vous !

Contribution le : 08/03 14:44:39
Créer un fichier PDF de la contribution Imprimer


Re: csv>python>blender
Clan Afficionado
Inscrit:
17/07/2018 08:26
Post(s): 94
Bon, voici où j'en suis...
mais dans les frames rendues, je n'observe pas le déplacement
et blender fige
je suppose que je dois définir une frame de début et une frame de fin
import bpy, csv
from math import pi #useful for text and camera rotation_euler

mat= Material.New('newMat')
mat.rgbCol = [t1,t2,t3]


def event_text(event):
bpy.ops.object.text_add()
ob = bpy.context.object
curve = ob.data
curve.body = "%s"%event
bpy.ops.material.new()
bpy.context.active_object.location=(float(x),float(y),float(z))
bpy.context.active_object.rotation_euler=(pi*90/180,0,0)
ob.setMaterials([mat])
ob.activeMaterial
bpy.context.scene.render.filepath = '\\Users\essai.avi'
bpy.ops.render.render(animation=True)


#define scene
scn = bpy.context.scene

#extraire les donnees du fichier csv :

file = '\\Users\essai.csv'

# create the first camera
cam1 = bpy.data.cameras.new("Camera 1")
cam1.lens = 18

# create the first camera object
cam_obj1 = bpy.data.objects.new("Camera 1", cam1)
cam_obj1.rotation_euler = (pi*90/180, 0, 0)
scn.collection.objects.link(cam_obj1)

with open( file, 'r' ) as f:
reader = csv.reader(f, delimiter=',')
for row in reader:
x, y, z, event = row[0], row[1], row[2], row[3]
cam_obj1.location = (float(x),float(y)-3,float(z))
print (row)
print (reader.line_num)
#creer les blocs textes
event_text(event)

Contribution le : 09/03 10:37:54
Créer un fichier PDF de la contribution Imprimer


Re: csv>python>blender
Clan Afficionado
Inscrit:
17/07/2018 08:26
Post(s): 94
Bonjour
J'aurais encore besoin d'aide
Après avoir essayé beaucoup de combines et eu quelques résultats mais peu probants
Quelle est la meilleure méthode, dans mon cas, pour enregistrer ma séquence en .avi ?
En vous remerciant d'avance

import bpy
import csv
from math import pi #useful for text and camera rotation_euler
        

def event_text(event):
    bpy.ops.object.text_add()
    ob = bpy.context.object      
    curve = ob.data
    curve.body = "%s"%event
    bpy.ops.material.new()
    bpy.context.active_object.location=(float(x),float(y),float(z))
    bpy.context.active_object.rotation_euler=(pi*90/180,0,0)
#define scene
scn = bpy.context.scene
# create the first camera
cam1 = bpy.data.cameras.new("Camera 1")
cam1.lens = 18
# create the first camera object
cam_obj1 = bpy.data.objects.new("Camera 1", cam1)
cam_obj1.rotation_euler = (pi*90/180, 0, 0)
scn.collection.objects.link(cam_obj1) 
#extract datas from csv file :
file = '\essai.csv'
#make the loop 
with open( file, 'r' ) as f:
    reader = csv.reader(f, delimiter=',')
    for row in reader:
        x, y, z, event = row[0], row[1], row[2], row[3]
        cam_obj1.location = (float(x),float(y)-3,float(z))
        cam_obj1.keyframe_insert(data_path=("location"), frame=((reader.line_num)-1)*120)
        cam_obj1.keyframe_insert(data_path=("location"), frame=((reader.line_num)-1)*120+120)
        print (reader.line_num)
        #creer les blocs textes 
        event_text(event)
        #render

Contribution le : 10/03 09:56:45
Créer un fichier PDF de la contribution Imprimer


Re: csv>python>blender
Clan Afficionado
Inscrit:
17/07/2018 08:26
Post(s): 94
Pliz ?

Contribution le : 11/03 14:55:58
Créer un fichier PDF de la contribution Imprimer


Re: csv>python>blender
Clan Afficionado
Inscrit:
17/07/2018 08:26
Post(s): 94
j'y suis finalement parvenu
apparemment, le type de fichier devait être "AVI_RAW"
ce qui donne :

import bpy
import csv
from math import pi #useful for text and camera rotation_euler
#create material
material_basic = bpy.data.materials.new(name= "Basic")
material_basic.use_nodes = True
principled_node = material_basic.node_tree.nodes.get('Principled BSDF')
principled_node.inputs[17].default_value = (1,1,1,1)


def event_text(event):
    bpy.ops.object.text_add()
    ob = bpy.context.object      
    curve = ob.data
    curve.body = "%s"%event
    bpy.context.active_object.location=(float(x),float(y),float(z))
    bpy.context.active_object.rotation_euler=(pi*90/180,0,0)
    bpy.context.active_object.data.materials.append(material_basic)
#define scene
scn = bpy.context.scene
# create the first camera
cam1 = bpy.data.cameras.new("Camera 1")
cam1.lens = 18
# create the first camera object
cam_obj1 = bpy.data.objects.new("Camera 1", cam1)
cam_obj1.rotation_euler = (pi*90/180, 0, 0)
scn.collection.objects.link(cam_obj1)
scn.camera = cam_obj1


#extract datas from csv file :
file = '\\Users\essai.csv'
#make the loop 
with open( file, 'r' ) as f:
    reader = csv.reader(f, delimiter=',')
    for row in reader:
        x, y, z, event = row[0], row[1], row[2], row[3]
        cam_obj1.location = (float(x),float(y)-3,float(z))
        cam_obj1.keyframe_insert(data_path=("location"), frame=((reader.line_num)-1)*120)
        cam_obj1.keyframe_insert(data_path=("location"), frame=((reader.line_num)-1)*120+120)
        print (reader.line_num)
        #creer les blocs textes 
        event_text(event)
        #render
bpy.context.scene.render.filepath = '\\Users\essai'
bpy.context.scene.render.image_settings.file_format = "AVI_RAW"
bpy.ops.render.render(animation = True)

Contribution le : 18/03 11:15:03
Créer un fichier PDF de la contribution Imprimer



 Haut   Précédent   Suivant




Enregistrer votre réponse
Compte*
Nom   Mot de passe   Authentification
Message:*



[Recherche avancée]



Sujets récemment répondus
Forums Sujets Réponses Lus Dernières contributions
Questions & Réponses [résolu] Png et liseré blanc 5 126 Hier 20:56:32
meltingman 
Hors Sujet !! Sinoceratops project - Ateliers suivies de A à l'Animation    [1][2][3] 28 1281 Hier 16:11:40
meltingman 
Questions & Réponses [non résolu] armature qui suit une autre armature 2 41 Hier 16:05:53
meltingman 
The Blender Clan 'tchat Avenir du blender clan    [1][2][3]...[26] 256 29484 20/07 20:56:17
Bibi09 
Graphisme alternatif faire de la bd avec blender    [1][2][3]...[5] 43 1921 20/07 20:31:31
blend74 
[WIP] et travaux terminés Visage humain 2 127 19/07 15:04:04
Bibi09 
[WIP] et travaux terminés Mission sur Mars - Terminé 5 141 19/07 11:41:42
BlendX 
[WIP] et travaux terminés [WIP] sinocératops    [1][2] 10 352 18/07 21:02:55
meltingman 
Le coin des geeks Colorisation, Krita ou Photoshop ?    [1][2] 14 416 18/07 20:50:51
sapajou 
Hors Sujet !! les tutos de Moonboots    [1][2][3]...[16] 159 12551 17/07 21:24:45
moonboots 
Questions & Réponses Trace de la trajectoire d'un objet 5 158 17/07 18:33:25
moonboots 
Questions & Réponses Problème intersect boolean 5 175 16/07 15:40:44
Altasien 
Questions & Réponses Artefacts de verre sous Eevee 7 188 14/07 15:58:03
moonboots 
[WIP] et travaux terminés Anatomie open source dans Blender 5 625 14/07 07:26:06
Melodicpinpon 
[WIP] et travaux terminés modelisation et animation de petits persos    [1][2][3][4] 32 1200 12/07 19:21:52
blend74 
Questions & Réponses [résolu] Séparer les objets crées avec Miroir. 2 166 10/07 16:30:26
Papy_Octet 
Hors Sujet !! Adieu Audacity, bonjour Tenacity    [1][2] 17 513 08/07 14:55:48
Redstar 
Questions & Réponses [résolu] Array : modification de dimensions entre des pièces copiées ? 8 474 07/07 18:55:22
JaAlVir657 
The Blender Clan 'tchat RenderMan (logiciel de pixar) gratuit 7 2308 07/07 09:56:43
Sphere3d 
Questions & Réponses [non résolu] acceleration soudaine - contrainte "limit distance" 0 150 06/07 21:54:48
fatili 

Qui est en ligne
148 utilisateur(s) en ligne (dont 100 sur Forums)

Membre(s): 0
Invité(s): 148


plus...
Nouveaux membres

Nemo
11/3/2021
qingjie 10/3/2021
Kask909 9/3/2021
marie-antoinette 7/3/2021
Bugs 7/3/2021
lolorogli75 4/3/2021
Flagiel 4/3/2021
thedeathclown 1/3/2021
Littlespoon 28/2/2021
luxperpetua 27/2/2021
Dernier Ajout
2020-09-24.jpg

Evènements à venir
(continuer) - 22:55
Anniv du BlenderClan !
Aou 4
Anniversaire de xemphra
Aou 7
anniversaire Cem47
plus 253 plus d'élément(s)
 Par Mickaël Guédon [ebrain] © 2003-2021 The Blender Clan - hébergé par TuxFamily - Site déclaré à la CNIL sous le numéro 1155445