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): 4080
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 Fond animé indéfiniment 1 10 Aujourd'hui 01:19:03
yawdpwal 
Questions & Réponses Rigging: Soucis au niveau du weight painting, obtenir un meilleur résultat lors d'un étirement ? 4 679 Hier 17:42:45
PounchPounch 
Questions & Réponses Problème de rendu Blender 0 32 Hier 17:17:45
byk 
Hors Sujet !! Sappling gen generateur d'arbres - tuto blender 7 1161 Hier 16:30:53
meltingman 
Questions & Réponses Adaptation terrain 7 175 Hier 16:08:44
Redstar 
Graphisme alternatif faire de la bd avec blender    [1][2][3]...[11] 105 7057 Hier 10:55:38
blend74 
Moteur de jeu GameBlender et alternatives [WIP] Godot Engine - Projet Arsenal    [1][2] 10 322 Hier 10:44:47
Redstar 
Questions & Réponses Maillage et système de particules 6 132 Hier 08:37:06
yawdpwal 
Questions & Réponses [non résolu] Problème Aspect du verre (Glass BSDF) 3 180 27/09 16:55:18
tulipe-rouge 
[WIP] et travaux terminés Bonjour à tous, une vanité moderde 2 74 27/09 16:37:06
tulipe-rouge 
Questions & Réponses Texture importée déformée... HELP 2 114 27/09 09:50:36
Jreno 
Questions & Réponses Couleur de peau 1 205 26/09 07:22:23
Horemheb 
Questions & Réponses image as plane: éviter les ombres 5 145 25/09 19:07:45
blend74 
Questions & Réponses Blender et Mac, faisons le point 6 177 25/09 11:26:02
Bibi09 
Graphisme alternatif Dessiner à la tablette avec Krita : demande conseils    [1][2] 17 27823 24/09 16:49:32
blend74 
Hors Sujet !! un visage avec Blender tutoriel facile débutant 1 333 24/09 16:44:38
blend74 
Questions & Réponses Blender et Mac, faisons le point 0 76 24/09 09:11:50
ludo66 
Questions & Réponses Aplanir plusieurs surfaces à la fois 3 104 24/09 02:45:51
Vinke013 
Questions & Réponses message d'erreur help 0 79 23/09 12:45:05
blend74 
Graphisme alternatif les addons pour blender : bumarin etc    [1][2] 13 670 23/09 11:13:07
blend74 

Qui est en ligne
116 utilisateur(s) en ligne (dont 58 sur Forums)

Membre(s): 6
Invité(s): 110


LVQArthur5, Venetta501, RomanV2756, AhmadBurg5, DylanCalve, Carissa89Q, plus...
Nouveaux membres
MarieHarts 29/9/2021
HolleyEcuy 29/9/2021
Randi99159 29/9/2021
Poppy5844 29/9/2021
SaulBrooki 29/9/2021
NicholSalm 29/9/2021
DylanCalve 29/9/2021
JanineShel 29/9/2021
ChassidyMa 29/9/2021
OrvalCrow8 29/9/2021
Dernier Ajout
2020-09-24.jpg

Evènements à venir
Oct 8
Anniversaire du Grand Mechant Fadge
Nov 18
Anniversaire de RichDeg
Dec 29
Anniversaire d'ebrain
plus 248 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