2002-10-12 11:37:38 +00:00
/**
* $ Id $
*
* * * * * * BEGIN GPL / BL DUAL LICENSE BLOCK * * * * *
*
* This program is free software ; you can redistribute it and / or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation ; either version 2
* of the License , or ( at your option ) any later version . The Blender
* Foundation also sells licenses for use in proprietary software under
* the Blender License . See http : //www.blender.org/BL/ for information
* about this .
*
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU General Public License for more details .
*
* You should have received a copy of the GNU General Public License
* along with this program ; if not , write to the Free Software Foundation ,
* Inc . , 59 Temple Place - Suite 330 , Boston , MA 02111 - 1307 , USA .
*
* The Original Code is Copyright ( C ) 2001 - 2002 by NaN Holding BV .
* All rights reserved .
*
* The Original Code is : all of this file .
*
* Contributor ( s ) : none yet .
*
* * * * * * END GPL / BL DUAL LICENSE BLOCK * * * * *
*/
//#define NAN_LINEAR_PHYSICS
# include <math.h>
2003-10-28 16:26:51 +00:00
# include <string.h>
2002-11-25 12:02:15 +00:00
# ifdef HAVE_CONFIG_H
# include <config.h>
# endif
2002-10-12 11:37:38 +00:00
# ifndef WIN32
# include <unistd.h>
# include <sys/times.h>
# else
# include <io.h>
# include "BLI_winstuff.h"
# endif
# include "MEM_guardedalloc.h"
# include "PIL_time.h"
# include "BMF_Api.h"
# include "IMB_imbuf_types.h"
2003-10-28 16:26:51 +00:00
# include "DNA_action_types.h"
# include "DNA_armature_types.h"
2002-10-12 11:37:38 +00:00
# include "DNA_constraint_types.h"
2003-10-28 16:26:51 +00:00
# include "DNA_curve_types.h"
2002-10-12 11:37:38 +00:00
# include "DNA_group_types.h"
# include "DNA_image_types.h"
2003-10-28 16:26:51 +00:00
# include "DNA_lattice_types.h"
Fix for undo... it didn't do the UV coords (tface) nor the vertexpaint
colors. This because of the pretty weird (ab)use of load & make editmesh...
For each added undo step, the load_editmesh was fed with an empty mesh
to assign data to, without knowledge of what was in the original mesh.
That way UV and color data got lost.
Solved it in 2 steps:
1. removing the ->tface pointer from EditVlak, and make TFace a builtin
struct inside EditVlak. This didnt cost much extra mem, since it already
stored UV and color. This enabled some pretty cleanup in editmesh.c as
well, storing tface pointers was cumbersome.
2. for each undo step, it then generates always a tface and mcol block to
link to the undo Mesh.
Even when it wasn't in the actual Mesh, at exit editmode the original
Mesh is used as reference anyway, and undo-meshes are freed correctly.
The enormous commit is because I had to change the BLI_editVert.h file, and
found it was included in about every file unnecessary. I removed it there.
ALso found out that subsurf has code ready (unfinished) to make UV coords for
the displaylist in EditMode as well, nice to know for later...
2003-11-19 22:00:14 +00:00
# include "DNA_mesh_types.h"
2004-05-30 14:12:14 +00:00
# include "DNA_meta_types.h"
2003-10-28 16:26:51 +00:00
# include "DNA_object_types.h"
2002-10-12 11:37:38 +00:00
# include "DNA_screen_types.h"
# include "DNA_texture_types.h"
# include "DNA_view3d_types.h"
# include "DNA_userdef_types.h"
2003-10-15 12:26:26 +00:00
# include "DNA_space_types.h"
2002-10-12 11:37:38 +00:00
Fix for undo... it didn't do the UV coords (tface) nor the vertexpaint
colors. This because of the pretty weird (ab)use of load & make editmesh...
For each added undo step, the load_editmesh was fed with an empty mesh
to assign data to, without knowledge of what was in the original mesh.
That way UV and color data got lost.
Solved it in 2 steps:
1. removing the ->tface pointer from EditVlak, and make TFace a builtin
struct inside EditVlak. This didnt cost much extra mem, since it already
stored UV and color. This enabled some pretty cleanup in editmesh.c as
well, storing tface pointers was cumbersome.
2. for each undo step, it then generates always a tface and mcol block to
link to the undo Mesh.
Even when it wasn't in the actual Mesh, at exit editmode the original
Mesh is used as reference anyway, and undo-meshes are freed correctly.
The enormous commit is because I had to change the BLI_editVert.h file, and
found it was included in about every file unnecessary. I removed it there.
ALso found out that subsurf has code ready (unfinished) to make UV coords for
the displaylist in EditMode as well, nice to know for later...
2003-11-19 22:00:14 +00:00
# include "BLI_blenlib.h"
# include "BLI_arithb.h"
# include "BLI_editVert.h"
2002-10-12 11:37:38 +00:00
# include "BKE_action.h"
2003-10-28 16:26:51 +00:00
# include "BKE_armature.h"
2002-10-12 11:37:38 +00:00
# include "BKE_anim.h"
# include "BKE_constraint.h"
2003-10-28 16:26:51 +00:00
# include "BKE_curve.h"
2002-10-12 11:37:38 +00:00
# include "BKE_displist.h"
# include "BKE_global.h"
# include "BKE_ika.h"
2003-10-28 16:26:51 +00:00
# include "BKE_lattice.h"
2003-10-15 12:26:26 +00:00
# include "BKE_library.h"
2002-10-12 11:37:38 +00:00
# include "BKE_image.h"
# include "BKE_ipo.h"
# include "BKE_key.h"
# include "BKE_main.h"
# include "BKE_object.h"
# include "BKE_texture.h"
# include "BKE_utildefines.h"
# include "BIF_gl.h"
# include "BIF_resources.h"
# include "BIF_screen.h"
# include "BIF_interface.h"
# include "BIF_space.h"
2003-10-07 18:24:02 +00:00
# include "BIF_butspace.h"
2002-10-12 11:37:38 +00:00
# include "BIF_drawimage.h"
# include "BIF_editgroup.h"
# include "BIF_mywindow.h"
2003-10-28 16:26:51 +00:00
# include "BIF_editarmature.h"
# include "BIF_poseobject.h"
2002-10-12 11:37:38 +00:00
# include "BDR_drawmesh.h"
# include "BDR_drawobject.h"
2004-04-06 19:16:14 +00:00
# include "BDR_editobject.h"
2004-07-10 17:40:40 +00:00
# include "BDR_vpaint.h"
2002-10-12 11:37:38 +00:00
# include "BSE_view.h"
# include "BSE_drawview.h"
# include "BSE_headerbuttons.h"
Commit message and the brunt of the code courtesy of intrr, apologies for the
size of this;
Finally, the Sequencer audio support and global audio/animation sync stuff!
(See http://intrr.org/blender/audiosequencer.html)
Stuff that has been done:
./source/blender/blenloader/intern/writefile.c
./source/blender/blenloader/intern/readfile.c
Added code to make it handle sounds used by audio strips, and to convert
Scene data from older (<2.28) versions to init Scene global audio settings
(Scene->audio) to defaults.
./source/blender/include/BSE_seqaudio.h
./source/blender/src/seqaudio.c
The main audio routines that start/stop/scrub the audio stream at
a certain frame position, provide the frame reference for the current
stream position, mix the audio, convert the audio, mixdown the audio
into a file.
./source/blender/makesdna/DNA_sound_types.h
Introduced new variables in the bSound struct to accomodate the sample
data after converted to the scene's global mixing format (stream, streamlen).
Also added a new flag SOUND_FLAGS_SEQUENCE that gets set if the Sound
belongs to a sequence strip.
./source/blender/makesdna/DNA_scene_types.h
Added AudioData struct, which holds scene-global audio settings.
./source/blender/makesdna/DNA_sequence_types.h
Added support for audio strips. Some variables to hold Panning/Attenuation
information, position information, reference to the sample, and some flags.
./source/blender/makesdna/DNA_userdef_types.h
./source/blender/src/usiblender.c
Added a "Mixing buffer size" userpref. Made the versions stuff initialize
it to a default for versions <2.28.
./source/blender/makesdna/DNA_space_types.h
./source/blender/src/filesel.c
Added a Cyan dot to .WAV files. Any other suggestions on a better color? :)
./source/blender/src/editsound.c
Changes (fixes) to the WAV file loader, re-enabled some gameengine code that
is needed for dealing with bSounds and bSamples.
./source/blender/src/editipo.c
./source/blender/src/drawseq.c
./source/blender/src/editnla.c
./source/blender/src/space.c
./source/blender/src/drawview.c
./source/blender/src/renderwin.c
./source/blender/src/headerbuttons.c
- Created two different wrappers for update_for_newframe(), one which scrubs
the audio, one which doesn't.
- Replaced some of the occurences of update_for_newframe() with
update_for_newframe_muted(), which doesn't scrub the audio.
- In drawview.c: Changed the synchronization scheme to get the current audio
position from the audio engine, and use that as a reference for setting
CFRA. Implements a/v sync and framedrop.
- In editipo.c: Changed handling of Fac IPOs to be usable for audio strips as
volume envelopes.
- In space.c: Added the mixing buffer size Userpref, enabled audio scrubbing
(update_for_newframe()) for moving the sequence editor framebar.
./source/blender/src/editseq.c
Added support for audio strips and a default directory for WAV files which
gets saved from the last Shift-A operation.
./source/blender/src/buttons.c
Added Scene-global audio sequencer settings in Sound buttons.
./source/blender/src/sequence.c
Various stuff that deals with handling audio strips differently than
usual strips.
2003-07-13 20:16:56 +00:00
# include "BSE_seqaudio.h"
2003-10-15 12:26:26 +00:00
# include "BSE_filesel.h"
2004-07-10 17:40:40 +00:00
# include "BSE_trans_types.h"
2002-10-12 11:37:38 +00:00
# include "RE_renderconverter.h"
2003-11-23 14:28:46 +00:00
# include "BPY_extern.h"
2002-10-12 11:37:38 +00:00
# include "blendef.h"
# include "mydevice.h"
2003-10-15 12:26:26 +00:00
# include "butspace.h" // event codes
2002-10-12 11:37:38 +00:00
/* Modules used */
# include "render.h"
# include "radio.h"
/* for physics in animation playback */
# ifdef NAN_LINEAR_PHYSICS
# include "sumo.h"
# endif
/* locals */
void drawname ( Object * ob ) ;
void star_stuff_init_func ( void ) ;
void star_stuff_vertex_func ( float * i ) ;
void star_stuff_term_func ( void ) ;
void star_stuff_init_func ( void )
{
cpack ( - 1 ) ;
glPointSize ( 1.0 ) ;
glBegin ( GL_POINTS ) ;
}
void star_stuff_vertex_func ( float * i )
{
glVertex3fv ( i ) ;
}
void star_stuff_term_func ( void )
{
glEnd ( ) ;
}
void setalpha_bgpic ( BGpic * bgpic )
{
int x , y , alph ;
char * rect ;
alph = ( int ) ( 255.0 * ( 1.0 - bgpic - > blend ) ) ;
rect = ( char * ) bgpic - > rect ;
for ( y = 0 ; y < bgpic - > yim ; y + + ) {
for ( x = bgpic - > xim ; x > 0 ; x - - , rect + = 4 ) {
rect [ 3 ] = alph ;
}
}
}
void default_gl_light ( void )
{
int a ;
2003-10-25 16:53:50 +00:00
/* initialize */
if ( U . light [ 0 ] . flag = = 0 & & U . light [ 1 ] . flag = = 0 & & U . light [ 2 ] . flag = = 0 ) {
U . light [ 0 ] . flag = 1 ;
U . light [ 0 ] . vec [ 0 ] = - 0.3 ; U . light [ 0 ] . vec [ 1 ] = 0.3 ; U . light [ 0 ] . vec [ 2 ] = 0.9 ;
U . light [ 0 ] . col [ 0 ] = 0.8 ; U . light [ 0 ] . col [ 1 ] = 0.8 ; U . light [ 0 ] . col [ 2 ] = 0.8 ;
U . light [ 0 ] . spec [ 0 ] = 0.5 ; U . light [ 0 ] . spec [ 1 ] = 0.5 ; U . light [ 0 ] . spec [ 2 ] = 0.5 ;
U . light [ 0 ] . spec [ 3 ] = 1.0 ;
2003-10-26 20:45:52 +00:00
U . light [ 1 ] . flag = 0 ;
2003-10-25 16:53:50 +00:00
U . light [ 1 ] . vec [ 0 ] = 0.5 ; U . light [ 1 ] . vec [ 1 ] = 0.5 ; U . light [ 1 ] . vec [ 2 ] = 0.1 ;
U . light [ 1 ] . col [ 0 ] = 0.4 ; U . light [ 1 ] . col [ 1 ] = 0.4 ; U . light [ 1 ] . col [ 2 ] = 0.8 ;
U . light [ 1 ] . spec [ 0 ] = 0.3 ; U . light [ 1 ] . spec [ 1 ] = 0.3 ; U . light [ 1 ] . spec [ 2 ] = 0.5 ;
U . light [ 1 ] . spec [ 3 ] = 1.0 ;
U . light [ 2 ] . flag = 0 ;
U . light [ 2 ] . vec [ 0 ] = 0.3 ; U . light [ 2 ] . vec [ 1 ] = - 0.3 ; U . light [ 2 ] . vec [ 2 ] = - 0.2 ;
U . light [ 2 ] . col [ 0 ] = 0.8 ; U . light [ 2 ] . col [ 1 ] = 0.5 ; U . light [ 2 ] . col [ 2 ] = 0.4 ;
U . light [ 2 ] . spec [ 0 ] = 0.5 ; U . light [ 2 ] . spec [ 1 ] = 0.4 ; U . light [ 2 ] . spec [ 2 ] = 0.3 ;
U . light [ 2 ] . spec [ 3 ] = 1.0 ;
}
glLightfv ( GL_LIGHT0 , GL_POSITION , U . light [ 0 ] . vec ) ;
glLightfv ( GL_LIGHT0 , GL_DIFFUSE , U . light [ 0 ] . col ) ;
glLightfv ( GL_LIGHT0 , GL_SPECULAR , U . light [ 0 ] . spec ) ;
2003-10-22 17:34:51 +00:00
2003-10-25 16:53:50 +00:00
glLightfv ( GL_LIGHT1 , GL_POSITION , U . light [ 1 ] . vec ) ;
glLightfv ( GL_LIGHT1 , GL_DIFFUSE , U . light [ 1 ] . col ) ;
glLightfv ( GL_LIGHT1 , GL_SPECULAR , U . light [ 1 ] . spec ) ;
2002-10-12 11:37:38 +00:00
2003-10-25 16:53:50 +00:00
glLightfv ( GL_LIGHT2 , GL_POSITION , U . light [ 2 ] . vec ) ;
glLightfv ( GL_LIGHT2 , GL_DIFFUSE , U . light [ 2 ] . col ) ;
glLightfv ( GL_LIGHT2 , GL_SPECULAR , U . light [ 2 ] . spec ) ;
2003-10-22 17:34:51 +00:00
2003-10-25 16:53:50 +00:00
for ( a = 0 ; a < 8 ; a + + ) {
if ( a < 3 ) {
if ( U . light [ a ] . flag ) glEnable ( GL_LIGHT0 + a ) ;
else glDisable ( GL_LIGHT0 + a ) ;
2003-11-20 17:51:37 +00:00
// clear stuff from other opengl lamp usage
glLightf ( GL_LIGHT0 + a , GL_SPOT_CUTOFF , 180.0 ) ;
glLightf ( GL_LIGHT0 + a , GL_CONSTANT_ATTENUATION , 1.0 ) ;
glLightf ( GL_LIGHT0 + a , GL_LINEAR_ATTENUATION , 0.0 ) ;
2003-10-25 16:53:50 +00:00
}
else glDisable ( GL_LIGHT0 + a ) ;
}
2002-10-12 11:37:38 +00:00
glDisable ( GL_LIGHTING ) ;
glDisable ( GL_COLOR_MATERIAL ) ;
}
void init_gl_stuff ( void )
{
float mat_specular [ ] = { 0.5 , 0.5 , 0.5 , 1.0 } ;
float mat_shininess [ ] = { 35.0 } ;
/* float one= 1.0; */
int a , x , y ;
GLubyte pat [ 32 * 32 ] ;
const GLubyte * patc = pat ;
glMaterialfv ( GL_FRONT_AND_BACK , GL_DIFFUSE , mat_specular ) ;
glMaterialfv ( GL_FRONT_AND_BACK , GL_SPECULAR , mat_specular ) ;
glMaterialfv ( GL_FRONT_AND_BACK , GL_SHININESS , mat_shininess ) ;
default_gl_light ( ) ;
/* no local viewer, looks ugly in ortho mode */
/* glLightModelfv(GL_LIGHT_MODEL_LOCAL_VIEWER, &one); */
glDepthFunc ( GL_LEQUAL ) ;
/* scaling matrices */
glEnable ( GL_NORMALIZE ) ;
glShadeModel ( GL_FLAT ) ;
glDisable ( GL_ALPHA_TEST ) ;
glDisable ( GL_BLEND ) ;
glDisable ( GL_DEPTH_TEST ) ;
glDisable ( GL_FOG ) ;
glDisable ( GL_LIGHTING ) ;
glDisable ( GL_LOGIC_OP ) ;
glDisable ( GL_STENCIL_TEST ) ;
glDisable ( GL_TEXTURE_1D ) ;
glDisable ( GL_TEXTURE_2D ) ;
glPixelTransferi ( GL_MAP_COLOR , GL_FALSE ) ;
glPixelTransferi ( GL_RED_SCALE , 1 ) ;
glPixelTransferi ( GL_RED_BIAS , 0 ) ;
glPixelTransferi ( GL_GREEN_SCALE , 1 ) ;
glPixelTransferi ( GL_GREEN_BIAS , 0 ) ;
glPixelTransferi ( GL_BLUE_SCALE , 1 ) ;
glPixelTransferi ( GL_BLUE_BIAS , 0 ) ;
glPixelTransferi ( GL_ALPHA_SCALE , 1 ) ;
glPixelTransferi ( GL_ALPHA_BIAS , 0 ) ;
2004-09-25 13:42:31 +00:00
glPixelTransferi ( GL_DEPTH_BIAS , 0 ) ;
glPixelTransferi ( GL_DEPTH_SCALE , 1 ) ;
2002-10-12 11:37:38 +00:00
a = 0 ;
for ( x = 0 ; x < 32 ; x + + ) {
for ( y = 0 ; y < 4 ; y + + ) {
if ( ( x ) & 1 ) pat [ a + + ] = 0x88 ;
else pat [ a + + ] = 0x22 ;
}
}
glPolygonStipple ( patc ) ;
init_realtime_GL ( ) ;
}
void two_sided ( int val )
{
2003-04-28 14:43:20 +00:00
/* twosided on: gives errors with x flip! */
2002-10-12 11:37:38 +00:00
glLightModeliv ( GL_LIGHT_MODEL_TWO_SIDE , ( GLint * ) & val ) ;
}
void circf ( float x , float y , float rad )
{
GLUquadricObj * qobj = gluNewQuadric ( ) ;
gluQuadricDrawStyle ( qobj , GLU_FILL ) ;
glPushMatrix ( ) ;
glTranslatef ( x , y , 0. ) ;
gluDisk ( qobj , 0.0 , rad , 32 , 1 ) ;
glPopMatrix ( ) ;
gluDeleteQuadric ( qobj ) ;
}
void circ ( float x , float y , float rad )
{
GLUquadricObj * qobj = gluNewQuadric ( ) ;
gluQuadricDrawStyle ( qobj , GLU_SILHOUETTE ) ;
glPushMatrix ( ) ;
glTranslatef ( x , y , 0. ) ;
gluDisk ( qobj , 0.0 , rad , 32 , 1 ) ;
glPopMatrix ( ) ;
gluDeleteQuadric ( qobj ) ;
}
2003-04-28 14:43:20 +00:00
/* ********** ********** */
2002-10-12 11:37:38 +00:00
static void draw_bgpic ( void )
{
BGpic * bgpic ;
Image * ima ;
float vec [ 3 ] , fac , asp , zoomx , zoomy ;
int x1 , y1 , x2 , y2 , cx , cy ;
short mval [ 2 ] ;
bgpic = G . vd - > bgpic ;
if ( bgpic = = 0 ) return ;
if ( bgpic - > tex ) {
init_render_texture ( bgpic - > tex ) ;
free_unused_animimages ( ) ;
ima = bgpic - > tex - > ima ;
end_render_texture ( bgpic - > tex ) ;
}
else {
ima = bgpic - > ima ;
}
if ( ima = = 0 ) return ;
if ( ima - > ok = = 0 ) return ;
2003-04-28 14:43:20 +00:00
/* test for image */
2002-10-12 11:37:38 +00:00
if ( ima - > ibuf = = 0 ) {
if ( bgpic - > rect ) MEM_freeN ( bgpic - > rect ) ;
bgpic - > rect = 0 ;
if ( bgpic - > tex ) {
ima_ibuf_is_nul ( bgpic - > tex ) ;
}
else {
waitcursor ( 1 ) ;
load_image ( ima , IB_rect , G . sce , G . scene - > r . cfra ) ;
waitcursor ( 0 ) ;
}
if ( ima - > ibuf = = 0 ) {
ima - > ok = 0 ;
return ;
}
}
if ( bgpic - > rect = = 0 ) {
bgpic - > rect = MEM_dupallocN ( ima - > ibuf - > rect ) ;
bgpic - > xim = ima - > ibuf - > x ;
bgpic - > yim = ima - > ibuf - > y ;
setalpha_bgpic ( bgpic ) ;
}
if ( G . vd - > persp = = 2 ) {
rcti vb ;
calc_viewborder ( G . vd , & vb ) ;
x1 = vb . xmin ;
y1 = vb . ymin ;
x2 = vb . xmax ;
y2 = vb . ymax ;
}
else {
2003-04-28 14:43:20 +00:00
/* calc window coord */
2002-10-12 11:37:38 +00:00
initgrabz ( 0.0 , 0.0 , 0.0 ) ;
window_to_3d ( vec , 1 , 0 ) ;
fac = MAX3 ( fabs ( vec [ 0 ] ) , fabs ( vec [ 1 ] ) , fabs ( vec [ 1 ] ) ) ;
fac = 1.0 / fac ;
asp = ( ( float ) ima - > ibuf - > y ) / ( float ) ima - > ibuf - > x ;
vec [ 0 ] = vec [ 1 ] = vec [ 2 ] = 0.0 ;
project_short_noclip ( vec , mval ) ;
cx = mval [ 0 ] ;
cy = mval [ 1 ] ;
x1 = cx + fac * ( bgpic - > xof - bgpic - > size ) ;
y1 = cy + asp * fac * ( bgpic - > yof - bgpic - > size ) ;
x2 = cx + fac * ( bgpic - > xof + bgpic - > size ) ;
y2 = cy + asp * fac * ( bgpic - > yof + bgpic - > size ) ;
}
2003-04-28 14:43:20 +00:00
/* complete clip? */
2002-10-12 11:37:38 +00:00
if ( x2 < 0 ) return ;
if ( y2 < 0 ) return ;
if ( x1 > curarea - > winx ) return ;
if ( y1 > curarea - > winy ) return ;
zoomx = x2 - x1 ;
zoomx / = ( float ) ima - > ibuf - > x ;
zoomy = y2 - y1 ;
zoomy / = ( float ) ima - > ibuf - > y ;
glEnable ( GL_BLEND ) ;
if ( G . zbuf ) glDisable ( GL_DEPTH_TEST ) ;
glBlendFunc ( GL_SRC_ALPHA , GL_ONE_MINUS_SRC_ALPHA ) ;
rectwrite_part ( curarea - > winrct . xmin , curarea - > winrct . ymin , curarea - > winrct . xmax , curarea - > winrct . ymax ,
x1 + curarea - > winrct . xmin , y1 + curarea - > winrct . ymin , ima - > ibuf - > x , ima - > ibuf - > y , zoomx , zoomy , bgpic - > rect ) ;
glBlendFunc ( GL_ONE , GL_ZERO ) ;
glDisable ( GL_BLEND ) ;
if ( G . zbuf ) glEnable ( GL_DEPTH_TEST ) ;
}
void timestr ( double time , char * str )
{
2003-04-28 14:43:20 +00:00
/* format 00:00:00.00 (hr:min:sec) string has to be 12 long */
2002-10-12 11:37:38 +00:00
int hr = ( int ) time / ( 60 * 60 ) ;
int min = ( int ) fmod ( time / 60 , 60.0 ) ;
int sec = ( int ) fmod ( time , 60.0 ) ;
int hun = ( int ) fmod ( time * 100.0 , 100.0 ) ;
if ( hr ) {
sprintf ( str , " %.2d:%.2d:%.2d.%.2d " , hr , min , sec , hun ) ;
} else {
sprintf ( str , " %.2d:%.2d.%.2d " , min , sec , hun ) ;
}
str [ 11 ] = 0 ;
}
2003-10-18 12:21:41 +00:00
static void drawgrid_draw ( float wx , float wy , float x , float y , float dx )
{
float fx , fy ;
x + = ( wx ) ;
y + = ( wy ) ;
fx = x / dx ;
fx = x - dx * floor ( fx ) ;
while ( fx < curarea - > winx ) {
fdrawline ( fx , 0.0 , fx , ( float ) curarea - > winy ) ;
fx + = dx ;
}
fy = y / dx ;
fy = y - dx * floor ( fy ) ;
while ( fy < curarea - > winy ) {
fdrawline ( 0.0 , fy , ( float ) curarea - > winx , fy ) ;
fy + = dx ;
}
}
2002-10-12 11:37:38 +00:00
2003-10-23 16:15:05 +00:00
// not intern, called in editobject for constraint axis too
void make_axis_color ( char * col , char * col2 , char axis )
{
if ( axis = = ' x ' ) {
col2 [ 0 ] = col [ 0 ] > 219 ? 255 : col [ 0 ] + 36 ;
col2 [ 1 ] = col [ 1 ] < 26 ? 0 : col [ 1 ] - 26 ;
col2 [ 2 ] = col [ 2 ] < 26 ? 0 : col [ 2 ] - 26 ;
}
else if ( axis = = ' y ' ) {
col2 [ 0 ] = col [ 0 ] < 46 ? 0 : col [ 0 ] - 36 ;
col2 [ 1 ] = col [ 1 ] > 189 ? 255 : col [ 1 ] + 66 ;
col2 [ 2 ] = col [ 2 ] < 46 ? 0 : col [ 2 ] - 36 ;
}
else {
col2 [ 0 ] = col [ 0 ] < 26 ? 0 : col [ 0 ] - 26 ;
col2 [ 1 ] = col [ 1 ] < 26 ? 0 : col [ 1 ] - 26 ;
col2 [ 2 ] = col [ 2 ] > 209 ? 255 : col [ 2 ] + 46 ;
}
}
2003-10-19 09:19:58 +00:00
static void drawgrid ( void )
2002-10-12 11:37:38 +00:00
{
/* extern short bgpicmode; */
float wx , wy , x , y , fw , fx , fy , dx ;
float vec4 [ 4 ] ;
2003-10-23 16:15:05 +00:00
char col [ 3 ] , col2 [ 3 ] ;
2003-10-18 12:21:41 +00:00
2002-10-12 11:37:38 +00:00
vec4 [ 0 ] = vec4 [ 1 ] = vec4 [ 2 ] = 0.0 ;
vec4 [ 3 ] = 1.0 ;
Mat4MulVec4fl ( G . vd - > persmat , vec4 ) ;
fx = vec4 [ 0 ] ;
fy = vec4 [ 1 ] ;
fw = vec4 [ 3 ] ;
2003-04-28 14:43:20 +00:00
wx = ( curarea - > winx / 2.0 ) ; /* because of rounding errors, grid at wrong location */
2002-10-12 11:37:38 +00:00
wy = ( curarea - > winy / 2.0 ) ;
x = ( wx ) * fx / fw ;
y = ( wy ) * fy / fw ;
vec4 [ 0 ] = vec4 [ 1 ] = G . vd - > grid ;
vec4 [ 2 ] = 0.0 ;
vec4 [ 3 ] = 1.0 ;
Mat4MulVec4fl ( G . vd - > persmat , vec4 ) ;
fx = vec4 [ 0 ] ;
fy = vec4 [ 1 ] ;
fw = vec4 [ 3 ] ;
dx = fabs ( x - ( wx ) * fx / fw ) ;
if ( dx = = 0 ) dx = fabs ( y - ( wy ) * fy / fw ) ;
2003-10-22 09:06:30 +00:00
glDepthMask ( 0 ) ; // disable write in zbuffer
2003-10-18 12:21:41 +00:00
/* check zoom out */
2003-10-19 09:19:58 +00:00
BIF_ThemeColor ( TH_GRID ) ;
2003-10-18 12:21:41 +00:00
persp ( PERSP_WIN ) ;
2002-10-12 11:37:38 +00:00
if ( dx < 6.0 ) {
dx * = 10.0 ;
2003-10-18 12:21:41 +00:00
if ( dx < 6.0 ) {
2002-10-12 11:37:38 +00:00
dx * = 10.0 ;
2003-10-18 12:21:41 +00:00
2002-10-12 11:37:38 +00:00
if ( dx < 6.0 ) {
2003-10-18 12:21:41 +00:00
dx * = 10 ;
if ( dx < 6.0 ) ;
else {
2003-10-19 09:19:58 +00:00
BIF_ThemeColor ( TH_GRID ) ;
2003-10-18 12:21:41 +00:00
drawgrid_draw ( wx , wy , x , y , dx ) ;
}
}
else { // start blending out
2003-10-19 09:19:58 +00:00
BIF_ThemeColorBlend ( TH_BACK , TH_GRID , dx / 60.0 ) ;
2003-10-18 12:21:41 +00:00
drawgrid_draw ( wx , wy , x , y , dx ) ;
2003-10-19 09:19:58 +00:00
BIF_ThemeColor ( TH_GRID ) ;
2003-10-18 12:21:41 +00:00
drawgrid_draw ( wx , wy , x , y , 10 * dx ) ;
2002-10-12 11:37:38 +00:00
}
}
2003-10-18 12:21:41 +00:00
else { // start blending out (6 < dx < 60)
2003-10-19 09:19:58 +00:00
BIF_ThemeColorBlend ( TH_BACK , TH_GRID , dx / 60.0 ) ;
2003-10-18 12:21:41 +00:00
drawgrid_draw ( wx , wy , x , y , dx ) ;
2003-10-19 09:19:58 +00:00
BIF_ThemeColor ( TH_GRID ) ;
2003-10-18 12:21:41 +00:00
drawgrid_draw ( wx , wy , x , y , 10 * dx ) ;
}
}
else {
if ( dx > 60.0 ) { // start blending in
dx / = 10.0 ;
if ( dx > 60.0 ) { // start blending in
dx / = 10.0 ;
if ( dx > 60.0 ) {
2003-10-19 09:19:58 +00:00
BIF_ThemeColor ( TH_GRID ) ;
2003-10-18 12:21:41 +00:00
drawgrid_draw ( wx , wy , x , y , dx ) ;
}
else {
2003-10-19 09:19:58 +00:00
BIF_ThemeColorBlend ( TH_BACK , TH_GRID , dx / 60.0 ) ;
2003-10-18 12:21:41 +00:00
drawgrid_draw ( wx , wy , x , y , dx ) ;
2003-10-19 09:19:58 +00:00
BIF_ThemeColor ( TH_GRID ) ;
2003-10-18 12:21:41 +00:00
drawgrid_draw ( wx , wy , x , y , dx * 10 ) ;
}
}
else {
2003-10-19 09:19:58 +00:00
BIF_ThemeColorBlend ( TH_BACK , TH_GRID , dx / 60.0 ) ;
2003-10-18 12:21:41 +00:00
drawgrid_draw ( wx , wy , x , y , dx ) ;
Commit for the 4 aforementioned "features":
- "Global Pivot": Maintains a global Pivot and Align mode setting for
all 3d views when enabled, instead of seperate settings per 3d view
- "Auto Perspective": Switch to ortho mode automatically on 1/3/7, and
to Perspective when the view is rotated with the mouse
- "Align mode": As suggested on the list, when enabled, transformations
on several objects only transform their locations, not their sizes or
rotations.
- Grid dotted when not 1:1
***ATTENTION***! The User Interface parts of these features have not been
committed, as I work on my own modified UI here. The three features need
toggle buttons to turn them on and off.
I used the following 3 buttons (first two features are in userprefs,
third as a 3d view setting):
uiDefButBitS(block, TOG, USER_AUTOPERSP, B_DRAWINFO, "Auto Persp",
(xpos+edgespace+(3*medprefbut)+(3*midspace)+smallprefbut+2),y3+10,smallprefbut,buth,
&(U.uiflag), 0, 0, 0, 0,
"Automatically switch between orthographic and perspective");
uiDefButBitS(block, TOG, USER_LOCKAROUND, B_DRAWINFO, "Global Pivot",
(xpos+edgespace+(4*midspace)+(4*medprefbut)),y3+10,smallprefbut,buth,
&(U.uiflag), 0, 0, 0, 0,
"Use global pivot setting for all 3d views");
uiDefIconButS(block, TOG|BIT|10, B_AROUND, ICON_ALIGN,
xco+=XIC,0,XIC,YIC,
&G.vd->flag, 0, 0, 0, 0, "Translate only (align)");
Someone needs to add these to the interface in an appropriate manner!
Thanks.
2004-07-15 13:31:18 +00:00
BIF_ThemeColor ( TH_GRID ) ;
2004-07-27 23:24:56 +00:00
drawgrid_draw ( wx , wy , x , y , dx * 10 ) ;
2003-10-18 12:21:41 +00:00
}
}
else {
2003-10-19 09:19:58 +00:00
BIF_ThemeColorBlend ( TH_BACK , TH_GRID , dx / 60.0 ) ;
2004-07-27 23:24:56 +00:00
drawgrid_draw ( wx , wy , x , y , dx ) ;
2003-10-19 09:19:58 +00:00
BIF_ThemeColor ( TH_GRID ) ;
2003-10-18 12:21:41 +00:00
drawgrid_draw ( wx , wy , x , y , dx * 10 ) ;
}
2002-10-12 11:37:38 +00:00
}
x + = ( wx ) ;
y + = ( wy ) ;
2003-10-19 09:19:58 +00:00
BIF_GetThemeColor3ubv ( TH_GRID , col ) ;
2004-07-15 16:40:01 +00:00
setlinestyle ( 0 ) ;
2002-10-12 11:37:38 +00:00
2003-04-28 14:43:20 +00:00
/* center cross */
2003-10-23 16:15:05 +00:00
if ( G . vd - > view = = 3 ) make_axis_color ( col , col2 , ' y ' ) ;
else make_axis_color ( col , col2 , ' x ' ) ;
glColor3ubv ( col2 ) ;
2002-10-12 11:37:38 +00:00
fdrawline ( 0.0 , y , ( float ) curarea - > winx , y ) ;
2003-10-23 16:15:05 +00:00
if ( G . vd - > view = = 7 ) make_axis_color ( col , col2 , ' y ' ) ;
else make_axis_color ( col , col2 , ' z ' ) ;
glColor3ubv ( col2 ) ;
2002-10-12 11:37:38 +00:00
2003-10-18 12:21:41 +00:00
fdrawline ( x , 0.0 , x , ( float ) curarea - > winy ) ;
2002-10-12 11:37:38 +00:00
2003-10-22 09:06:30 +00:00
glDepthMask ( 1 ) ; // enable write in zbuffer
2003-10-16 09:39:19 +00:00
persp ( PERSP_VIEW ) ;
2002-10-12 11:37:38 +00:00
}
2003-10-19 09:19:58 +00:00
static void drawfloor ( void )
2002-10-12 11:37:38 +00:00
{
View3D * vd ;
float vert [ 3 ] , grid ;
int a , gridlines ;
2003-10-23 16:15:05 +00:00
char col [ 3 ] , col2 [ 3 ] ;
2004-01-24 05:06:12 +00:00
short draw_line = 0 ;
2002-10-12 11:37:38 +00:00
vd = curarea - > spacedata . first ;
vert [ 2 ] = 0.0 ;
if ( vd - > gridlines < 3 ) return ;
2004-09-25 14:21:09 +00:00
if ( G . zbuf & & G . obedit ) glDepthMask ( 0 ) ; // for zbuffer-select
2002-10-12 11:37:38 +00:00
gridlines = vd - > gridlines / 2 ;
grid = gridlines * vd - > grid ;
2003-10-19 09:19:58 +00:00
BIF_GetThemeColor3ubv ( TH_GRID , col ) ;
2003-10-18 12:21:41 +00:00
2004-01-24 05:06:12 +00:00
/* draw the Y axis and/or grid lines */
2002-10-12 11:37:38 +00:00
for ( a = - gridlines ; a < = gridlines ; a + + ) {
if ( a = = 0 ) {
2004-01-24 05:06:12 +00:00
/* check for the 'show Y axis' preference */
if ( vd - > gridflag & V3D_SHOW_Y ) {
make_axis_color ( col , col2 , ' y ' ) ;
glColor3ubv ( col2 ) ;
draw_line = 1 ;
} else if ( vd - > gridflag & V3D_SHOW_FLOOR ) {
BIF_ThemeColorShade ( TH_GRID , - 10 ) ;
} else {
draw_line = 0 ;
}
} else {
/* check for the 'show grid floor' preference */
if ( vd - > gridflag & V3D_SHOW_FLOOR ) {
if ( ( a % 10 ) = = 0 ) {
BIF_ThemeColorShade ( TH_GRID , - 10 ) ;
}
else BIF_ThemeColorShade ( TH_GRID , 10 ) ;
draw_line = 1 ;
} else {
draw_line = 0 ;
}
2002-10-12 11:37:38 +00:00
}
2004-01-24 05:06:12 +00:00
if ( draw_line ) {
glBegin ( GL_LINE_STRIP ) ;
vert [ 0 ] = a * vd - > grid ;
vert [ 1 ] = grid ;
glVertex3fv ( vert ) ;
vert [ 1 ] = - grid ;
glVertex3fv ( vert ) ;
glEnd ( ) ;
}
2002-10-12 11:37:38 +00:00
}
2004-01-24 05:06:12 +00:00
/* draw the X axis and/or grid lines */
2002-10-12 11:37:38 +00:00
for ( a = - gridlines ; a < = gridlines ; a + + ) {
if ( a = = 0 ) {
2004-01-24 05:06:12 +00:00
/* check for the 'show X axis' preference */
if ( vd - > gridflag & V3D_SHOW_X ) {
make_axis_color ( col , col2 , ' x ' ) ;
glColor3ubv ( col2 ) ;
draw_line = 1 ;
} else if ( vd - > gridflag & V3D_SHOW_FLOOR ) {
BIF_ThemeColorShade ( TH_GRID , - 10 ) ;
} else {
draw_line = 0 ;
}
} else {
/* check for the 'show grid floor' preference */
if ( vd - > gridflag & V3D_SHOW_FLOOR ) {
if ( ( a % 10 ) = = 0 ) {
BIF_ThemeColorShade ( TH_GRID , - 10 ) ;
}
else BIF_ThemeColorShade ( TH_GRID , 10 ) ;
draw_line = 1 ;
} else {
draw_line = 0 ;
}
2002-10-12 11:37:38 +00:00
}
2004-01-24 05:06:12 +00:00
if ( draw_line ) {
glBegin ( GL_LINE_STRIP ) ;
vert [ 1 ] = a * vd - > grid ;
vert [ 0 ] = grid ;
glVertex3fv ( vert ) ;
vert [ 0 ] = - grid ;
glVertex3fv ( vert ) ;
glEnd ( ) ;
2002-10-12 11:37:38 +00:00
}
2004-01-24 05:06:12 +00:00
}
2002-10-12 11:37:38 +00:00
2004-01-24 05:06:12 +00:00
/* draw the Z axis line */
/* check for the 'show Z axis' preference */
if ( vd - > gridflag & V3D_SHOW_Z ) {
make_axis_color ( col , col2 , ' z ' ) ;
glColor3ubv ( col2 ) ;
2002-10-12 11:37:38 +00:00
glBegin ( GL_LINE_STRIP ) ;
2004-01-24 05:06:12 +00:00
vert [ 0 ] = 0 ;
vert [ 1 ] = 0 ;
vert [ 2 ] = grid ;
glVertex3fv ( vert ) ;
vert [ 2 ] = - grid ;
glVertex3fv ( vert ) ;
2002-10-12 11:37:38 +00:00
glEnd ( ) ;
}
2004-09-25 14:21:09 +00:00
if ( G . zbuf & & G . obedit ) glDepthMask ( 1 ) ;
2002-10-12 11:37:38 +00:00
}
static void drawcursor ( void )
{
if ( G . f & G_PLAYANIM ) return ;
project_short ( give_cursor ( ) , & G . vd - > mx ) ;
G . vd - > mxo = G . vd - > mx ;
G . vd - > myo = G . vd - > my ;
if ( G . vd - > mx ! = 3200 ) {
setlinestyle ( 0 ) ;
cpack ( 0xFF ) ;
circ ( ( float ) G . vd - > mx , ( float ) G . vd - > my , 10.0 ) ;
setlinestyle ( 4 ) ;
cpack ( 0xFFFFFF ) ;
circ ( ( float ) G . vd - > mx , ( float ) G . vd - > my , 10.0 ) ;
setlinestyle ( 0 ) ;
cpack ( 0x0 ) ;
sdrawline ( G . vd - > mx - 20 , G . vd - > my , G . vd - > mx - 5 , G . vd - > my ) ;
sdrawline ( G . vd - > mx + 5 , G . vd - > my , G . vd - > mx + 20 , G . vd - > my ) ;
sdrawline ( G . vd - > mx , G . vd - > my - 20 , G . vd - > mx , G . vd - > my - 5 ) ;
sdrawline ( G . vd - > mx , G . vd - > my + 5 , G . vd - > mx , G . vd - > my + 20 ) ;
}
}
static void view3d_get_viewborder_size ( View3D * v3d , float size_r [ 2 ] )
{
float winmax = MAX2 ( v3d - > area - > winx , v3d - > area - > winy ) ;
float aspect = ( float ) ( G . scene - > r . xsch * G . scene - > r . xasp ) / ( G . scene - > r . ysch * G . scene - > r . yasp ) ;
if ( aspect > 1.0 ) {
size_r [ 0 ] = winmax ;
size_r [ 1 ] = winmax / aspect ;
} else {
size_r [ 0 ] = winmax * aspect ;
size_r [ 1 ] = winmax ;
}
}
void calc_viewborder ( struct View3D * v3d , rcti * viewborder_r )
{
float zoomfac , size [ 2 ] ;
view3d_get_viewborder_size ( v3d , size ) ;
/* magic zoom calculation, no idea what
* it signifies , if you find out , tell me ! - zr
*/
2003-04-28 14:43:20 +00:00
/* simple, its magic dude!
* well , to be honest , this gives a natural feeling zooming
* with multiple keypad presses ( ton )
*/
2002-10-12 11:37:38 +00:00
zoomfac = ( M_SQRT2 + v3d - > camzoom / 50.0 ) ;
zoomfac = ( zoomfac * zoomfac ) * 0.25 ;
size [ 0 ] = size [ 0 ] * zoomfac ;
size [ 1 ] = size [ 1 ] * zoomfac ;
/* center in window */
viewborder_r - > xmin = 0.5 * v3d - > area - > winx - 0.5 * size [ 0 ] ;
viewborder_r - > ymin = 0.5 * v3d - > area - > winy - 0.5 * size [ 1 ] ;
viewborder_r - > xmax = viewborder_r - > xmin + size [ 0 ] ;
viewborder_r - > ymax = viewborder_r - > ymin + size [ 1 ] ;
}
void view3d_set_1_to_1_viewborder ( View3D * v3d )
{
float size [ 2 ] ;
int im_width = ( G . scene - > r . size * G . scene - > r . xsch ) / 100 ;
view3d_get_viewborder_size ( v3d , size ) ;
v3d - > camzoom = ( sqrt ( 4.0 * im_width / size [ 0 ] ) - M_SQRT2 ) * 50.0 ;
v3d - > camzoom = CLAMPIS ( v3d - > camzoom , - 30 , 300 ) ;
}
static void drawviewborder ( void )
{
float fac , a ;
float x1 , x2 , y1 , y2 ;
float x3 , y3 , x4 , y4 ;
rcti viewborder ;
calc_viewborder ( G . vd , & viewborder ) ;
x1 = viewborder . xmin ;
y1 = viewborder . ymin ;
x2 = viewborder . xmax ;
y2 = viewborder . ymax ;
2003-04-28 14:43:20 +00:00
/* edge */
2002-10-12 11:37:38 +00:00
setlinestyle ( 3 ) ;
cpack ( 0 ) ;
glPolygonMode ( GL_FRONT_AND_BACK , GL_LINE ) ;
glRectf ( x1 + 1 , y1 - 1 , x2 + 1 , y2 - 1 ) ;
cpack ( 0xFFFFFF ) ;
glRectf ( x1 , y1 , x2 , y2 ) ;
/* border */
if ( G . scene - > r . mode & R_BORDER ) {
cpack ( 0 ) ;
x3 = x1 + G . scene - > r . border . xmin * ( x2 - x1 ) ;
y3 = y1 + G . scene - > r . border . ymin * ( y2 - y1 ) ;
x4 = x1 + G . scene - > r . border . xmax * ( x2 - x1 ) ;
y4 = y1 + G . scene - > r . border . ymax * ( y2 - y1 ) ;
glRectf ( x3 + 1 , y3 - 1 , x4 + 1 , y4 - 1 ) ;
cpack ( 0x4040FF ) ;
glRectf ( x3 , y3 , x4 , y4 ) ;
}
2003-04-28 14:43:20 +00:00
/* safety border */
2002-10-12 11:37:38 +00:00
fac = 0.1 ;
a = fac * ( x2 - x1 ) ;
x1 + = a ;
x2 - = a ;
a = fac * ( y2 - y1 ) ;
y1 + = a ;
y2 - = a ;
cpack ( 0 ) ;
glRectf ( x1 + 1 , y1 - 1 , x2 + 1 , y2 - 1 ) ;
cpack ( 0xFFFFFF ) ;
glRectf ( x1 , y1 , x2 , y2 ) ;
setlinestyle ( 0 ) ;
glPolygonMode ( GL_FRONT_AND_BACK , GL_FILL ) ;
}
void backdrawview3d ( int test )
{
struct Base * base ;
int tel = 1 ;
if ( G . f & ( G_VERTEXPAINT | G_FACESELECT | G_TEXTUREPAINT | G_WEIGHTPAINT ) ) ;
else {
G . vd - > flag & = ~ V3D_NEEDBACKBUFDRAW ;
return ;
}
if ( G . vd - > flag & V3D_NEEDBACKBUFDRAW ) ; else return ;
if ( G . obedit ) {
G . vd - > flag & = ~ V3D_NEEDBACKBUFDRAW ;
return ;
}
if ( test ) {
if ( qtest ( ) ) {
addafterqueue ( curarea - > win , BACKBUFDRAW , 1 ) ;
return ;
}
}
2003-10-21 12:23:38 +00:00
persp ( PERSP_VIEW ) ;
2003-06-11 15:43:20 +00:00
# ifdef __APPLE__
glDrawBuffer ( GL_AUX0 ) ;
# endif
2002-10-12 11:37:38 +00:00
if ( G . vd - > drawtype > OB_WIRE ) G . zbuf = TRUE ;
curarea - > win_swap & = ~ WIN_BACK_OK ;
glDisable ( GL_DITHER ) ;
glClearColor ( 0.0 , 0.0 , 0.0 , 0.0 ) ;
if ( G . zbuf ) {
glEnable ( GL_DEPTH_TEST ) ;
glClear ( GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT ) ;
}
else {
glClear ( GL_COLOR_BUFFER_BIT ) ;
glDisable ( GL_DEPTH_TEST ) ;
}
G . f | = G_BACKBUFSEL ;
if ( G . f & ( G_VERTEXPAINT | G_FACESELECT | G_TEXTUREPAINT | G_WEIGHTPAINT ) ) {
base = ( G . scene - > basact ) ;
if ( base & & ( base - > lay & G . vd - > lay ) ) {
draw_object ( base ) ;
}
}
else {
base = ( G . scene - > base . first ) ;
while ( base ) {
2003-04-28 14:43:20 +00:00
/* each base, because of multiple windows */
2002-10-12 11:37:38 +00:00
base - > selcol = 0x070707 | ( ( ( tel & 0xF00 ) < < 12 ) + ( ( tel & 0xF0 ) < < 8 ) + ( ( tel & 0xF ) < < 4 ) ) ;
tel + + ;
if ( base - > lay & G . vd - > lay ) {
if ( test ) {
if ( qtest ( ) ) {
addafterqueue ( curarea - > win , BACKBUFDRAW , 1 ) ;
break ;
}
}
cpack ( base - > selcol ) ;
draw_object ( base ) ;
}
base = base - > next ;
}
}
if ( base = = 0 ) G . vd - > flag & = ~ V3D_NEEDBACKBUFDRAW ;
G . f & = ~ G_BACKBUFSEL ;
G . zbuf = FALSE ;
glDisable ( GL_DEPTH_TEST ) ;
glEnable ( GL_DITHER ) ;
2003-06-11 15:43:20 +00:00
# ifdef __APPLE__
glDrawBuffer ( GL_BACK ) ; /* we were in aux buffers */
# endif
2003-12-01 13:01:18 +00:00
/* it is important to end a view in a transform compatible with buttons */
persp ( PERSP_WIN ) ; // set ortho
bwin_scalematrix ( curarea - > win , G . vd - > blockscale , G . vd - > blockscale , G . vd - > blockscale ) ;
2002-10-12 11:37:38 +00:00
}
void drawname ( Object * ob )
{
cpack ( 0x404040 ) ;
glRasterPos3f ( 0.0 , 0.0 , 0.0 ) ;
BMF_DrawString ( G . font , " " ) ;
BMF_DrawString ( G . font , ob - > id . name + 2 ) ;
}
2003-04-28 11:17:21 +00:00
static void draw_selected_name ( char * name )
{
char info [ 128 ] ;
sprintf ( info , " (%d) %s " , CFRA , name ) ;
2003-10-19 09:19:58 +00:00
BIF_ThemeColor ( TH_TEXT_HI ) ;
2003-04-28 11:17:21 +00:00
glRasterPos2i ( 30 , 10 ) ;
BMF_DrawString ( G . fonts , info ) ;
}
2002-10-12 11:37:38 +00:00
static void draw_view_icon ( void )
{
BIFIconID icon ;
if ( G . vd - > view = = 7 ) icon = ICON_AXIS_TOP ;
else if ( G . vd - > view = = 1 ) icon = ICON_AXIS_FRONT ;
else if ( G . vd - > view = = 3 ) icon = ICON_AXIS_SIDE ;
else return ;
glEnable ( GL_BLEND ) ;
glBlendFunc ( GL_SRC_ALPHA , GL_ONE_MINUS_SRC_ALPHA ) ;
2003-10-26 21:09:33 +00:00
glRasterPos2f ( 5.0 , 5.0 ) ;
2002-10-12 11:37:38 +00:00
BIF_draw_icon ( icon ) ;
glBlendFunc ( GL_ONE , GL_ZERO ) ;
glDisable ( GL_BLEND ) ;
}
2003-10-15 12:26:26 +00:00
/* ******************* view3d space & buttons ************** */
static void view3d_change_bgpic_ima ( View3D * v3d , Image * newima ) {
if ( v3d - > bgpic & & v3d - > bgpic - > ima ! = newima ) {
if ( newima )
id_us_plus ( ( ID * ) newima ) ;
if ( v3d - > bgpic - > ima )
v3d - > bgpic - > ima - > id . us - - ;
v3d - > bgpic - > ima = newima ;
if ( v3d - > bgpic - > rect ) MEM_freeN ( v3d - > bgpic - > rect ) ;
v3d - > bgpic - > rect = NULL ;
allqueue ( REDRAWVIEW3D , 0 ) ;
}
}
static void view3d_change_bgpic_tex ( View3D * v3d , Tex * newtex ) {
if ( v3d - > bgpic & & v3d - > bgpic - > tex ! = newtex ) {
if ( newtex )
id_us_plus ( ( ID * ) newtex ) ;
if ( v3d - > bgpic - > tex )
v3d - > bgpic - > tex - > id . us - - ;
v3d - > bgpic - > tex = newtex ;
allqueue ( REDRAWVIEW3D , 0 ) ;
}
}
static void load_bgpic_image ( char * name )
{
Image * ima ;
View3D * vd ;
vd = G . vd ;
if ( vd = = 0 | | vd - > bgpic = = 0 ) return ;
ima = add_image ( name ) ;
if ( ima ) {
if ( vd - > bgpic - > ima ) {
vd - > bgpic - > ima - > id . us - - ;
}
vd - > bgpic - > ima = ima ;
free_image_buffers ( ima ) ; /* force read again */
ima - > ok = 1 ;
}
allqueue ( REDRAWVIEW3D , 0 ) ;
}
2003-10-15 16:01:08 +00:00
/* this one assumes there is only one global active object in blender... (for object panel) */
2003-10-28 16:26:51 +00:00
static float ob_eul [ 4 ] ; // used for quat too....
2003-10-18 12:21:41 +00:00
/* this one assumes there is only one editmode in blender... (for object panel) */
2003-10-28 16:26:51 +00:00
static float ve_median [ 4 ] ;
2003-10-18 12:21:41 +00:00
/* is used for both read and write... */
static void v3d_editvertex_buts ( uiBlock * block , Object * ob , float lim )
{
2004-03-28 08:46:35 +00:00
EditMesh * em = G . editMesh ;
2003-10-18 12:21:41 +00:00
EditVert * eve ;
2004-07-28 16:45:00 +00:00
EditEdge * eed ;
2004-01-24 16:56:12 +00:00
float median [ 4 ] ;
2004-07-28 16:45:00 +00:00
int tot , totw , totedge ;
2003-10-18 12:21:41 +00:00
2004-01-24 16:56:12 +00:00
median [ 0 ] = median [ 1 ] = median [ 2 ] = median [ 3 ] = 0.0 ;
2004-07-28 16:45:00 +00:00
tot = totw = totedge = 0 ;
2003-10-18 12:21:41 +00:00
if ( ob - > type = = OB_MESH ) {
2004-07-28 16:45:00 +00:00
Mesh * me = ob - > data ;
2004-03-28 08:46:35 +00:00
eve = em - > verts . first ;
2003-10-18 12:21:41 +00:00
while ( eve ) {
if ( eve - > f & 1 ) {
tot + + ;
VecAddf ( median , median , eve - > co ) ;
}
eve = eve - > next ;
}
2004-07-28 16:45:00 +00:00
if ( me - > medge ) {
eed = em - > edges . first ;
while ( eed ) {
if ( ( eed - > v1 - > f & 1 ) & & ( eed - > v2 - > f & 1 ) ) {
totedge + + ;
median [ 3 ] + = eed - > crease ;
}
eed = eed - > next ;
}
}
2003-10-18 12:21:41 +00:00
}
2003-10-28 16:26:51 +00:00
else if ( ob - > type = = OB_CURVE | | ob - > type = = OB_SURF ) {
extern ListBase editNurb ; /* editcurve.c */
Nurb * nu ;
BPoint * bp ;
BezTriple * bezt ;
int a ;
nu = editNurb . first ;
while ( nu ) {
if ( ( nu - > type & 7 ) = = 1 ) {
bezt = nu - > bezt ;
a = nu - > pntsu ;
while ( a - - ) {
if ( bezt - > f2 & 1 ) {
VecAddf ( median , median , bezt - > vec [ 1 ] ) ;
tot + + ;
}
else {
if ( bezt - > f1 & 1 ) {
VecAddf ( median , median , bezt - > vec [ 0 ] ) ;
tot + + ;
}
if ( bezt - > f3 & 1 ) {
VecAddf ( median , median , bezt - > vec [ 2 ] ) ;
tot + + ;
}
}
bezt + + ;
}
}
else {
bp = nu - > bp ;
a = nu - > pntsu * nu - > pntsv ;
while ( a - - ) {
if ( bp - > f1 & 1 ) {
VecAddf ( median , median , bp - > vec ) ;
2004-01-24 16:56:12 +00:00
median [ 3 ] + = bp - > vec [ 3 ] ;
totw + + ;
2003-10-28 16:26:51 +00:00
tot + + ;
}
bp + + ;
}
}
nu = nu - > next ;
}
}
2003-10-18 12:21:41 +00:00
if ( tot = = 0 ) return ;
median [ 0 ] / = ( float ) tot ;
median [ 1 ] / = ( float ) tot ;
median [ 2 ] / = ( float ) tot ;
2004-07-28 16:45:00 +00:00
if ( totedge ) median [ 3 ] / = ( float ) totedge ;
else median [ 3 ] / = ( float ) tot ;
2003-10-18 12:21:41 +00:00
if ( block ) { // buttons
2004-01-24 16:56:12 +00:00
QUATCOPY ( ve_median , median ) ;
2003-10-18 12:21:41 +00:00
2003-11-14 15:49:26 +00:00
uiBlockBeginAlign ( block ) ;
2004-07-28 16:45:00 +00:00
if ( tot = = 1 ) {
2003-12-29 20:12:21 +00:00
uiDefButF ( block , NUM , B_OBJECTPANELMEDIAN , " Vertex X: " , 10 , 140 , 300 , 19 , & ( ve_median [ 0 ] ) , - lim , lim , 10 , 3 , " " ) ;
uiDefButF ( block , NUM , B_OBJECTPANELMEDIAN , " Vertex Y: " , 10 , 120 , 300 , 19 , & ( ve_median [ 1 ] ) , - lim , lim , 10 , 3 , " " ) ;
uiDefButF ( block , NUM , B_OBJECTPANELMEDIAN , " Vertex Z: " , 10 , 100 , 300 , 19 , & ( ve_median [ 2 ] ) , - lim , lim , 10 , 3 , " " ) ;
2004-07-28 16:45:00 +00:00
if ( totw = = 1 )
2004-01-29 00:47:35 +00:00
uiDefButF ( block , NUM , B_OBJECTPANELMEDIAN , " Vertex W: " , 10 , 80 , 300 , 19 , & ( ve_median [ 3 ] ) , 0.01 , 100.0 , 10 , 3 , " " ) ;
2003-10-18 12:21:41 +00:00
}
else {
2003-12-29 20:12:21 +00:00
uiDefButF ( block , NUM , B_OBJECTPANELMEDIAN , " Median X: " , 10 , 140 , 300 , 19 , & ( ve_median [ 0 ] ) , - lim , lim , 10 , 3 , " " ) ;
uiDefButF ( block , NUM , B_OBJECTPANELMEDIAN , " Median Y: " , 10 , 120 , 300 , 19 , & ( ve_median [ 1 ] ) , - lim , lim , 10 , 3 , " " ) ;
uiDefButF ( block , NUM , B_OBJECTPANELMEDIAN , " Median Z: " , 10 , 100 , 300 , 19 , & ( ve_median [ 2 ] ) , - lim , lim , 10 , 3 , " " ) ;
2004-01-24 16:56:12 +00:00
if ( totw = = tot )
2004-01-29 00:47:35 +00:00
uiDefButF ( block , NUM , B_OBJECTPANELMEDIAN , " Median W: " , 10 , 80 , 300 , 19 , & ( ve_median [ 3 ] ) , 0.01 , 100.0 , 10 , 3 , " " ) ;
2003-10-18 12:21:41 +00:00
}
2003-11-14 00:44:48 +00:00
uiBlockEndAlign ( block ) ;
2004-07-28 16:45:00 +00:00
if ( totedge = = 1 )
uiDefButF ( block , NUM , B_OBJECTPANELMEDIAN , " Crease W: " , 10 , 60 , 300 , 19 , & ( ve_median [ 3 ] ) , 0.0 , 1.0 , 10 , 3 , " " ) ;
else if ( totedge > 1 )
uiDefButF ( block , NUM , B_OBJECTPANELMEDIAN , " Median Crease W: " , 10 , 60 , 300 , 19 , & ( ve_median [ 3 ] ) , 0.0 , 1.0 , 10 , 3 , " " ) ;
2003-10-18 12:21:41 +00:00
}
else { // apply
VecSubf ( median , ve_median , median ) ;
2004-01-24 16:56:12 +00:00
median [ 3 ] = ve_median [ 3 ] - median [ 3 ] ;
2003-10-18 12:21:41 +00:00
if ( ob - > type = = OB_MESH ) {
2004-03-28 08:46:35 +00:00
eve = em - > verts . first ;
2003-10-18 12:21:41 +00:00
while ( eve ) {
if ( eve - > f & 1 ) {
VecAddf ( eve - > co , eve - > co , median ) ;
}
eve = eve - > next ;
}
2004-07-28 16:45:00 +00:00
eed = em - > edges . first ;
while ( eed ) {
if ( ( eed - > v1 - > f & 1 ) & & ( eed - > v2 - > f & 1 ) ) {
totedge + + ;
eed - > crease + = median [ 3 ] ;
CLAMP ( eed - > crease , 0.0 , 1.0 ) ;
}
eed = eed - > next ;
}
2003-10-18 12:21:41 +00:00
}
2003-10-28 16:26:51 +00:00
else if ( ob - > type = = OB_CURVE | | ob - > type = = OB_SURF ) {
extern ListBase editNurb ; /* editcurve.c */
Nurb * nu ;
BPoint * bp ;
BezTriple * bezt ;
int a ;
nu = editNurb . first ;
while ( nu ) {
if ( ( nu - > type & 7 ) = = 1 ) {
bezt = nu - > bezt ;
a = nu - > pntsu ;
while ( a - - ) {
if ( bezt - > f2 & 1 ) {
VecAddf ( bezt - > vec [ 0 ] , bezt - > vec [ 0 ] , median ) ;
VecAddf ( bezt - > vec [ 1 ] , bezt - > vec [ 1 ] , median ) ;
VecAddf ( bezt - > vec [ 2 ] , bezt - > vec [ 2 ] , median ) ;
}
else {
if ( bezt - > f1 & 1 ) {
VecAddf ( bezt - > vec [ 0 ] , bezt - > vec [ 0 ] , median ) ;
}
if ( bezt - > f3 & 1 ) {
VecAddf ( bezt - > vec [ 2 ] , bezt - > vec [ 2 ] , median ) ;
}
}
bezt + + ;
}
}
else {
bp = nu - > bp ;
a = nu - > pntsu * nu - > pntsv ;
while ( a - - ) {
if ( bp - > f1 & 1 ) {
VecAddf ( bp - > vec , bp - > vec , median ) ;
2004-01-24 16:56:12 +00:00
bp - > vec [ 3 ] + = median [ 3 ] ;
2003-10-28 16:26:51 +00:00
tot + + ;
}
bp + + ;
}
}
test2DNurb ( nu ) ;
testhandlesNurb ( nu ) ; /* test for bezier too */
nu = nu - > next ;
}
}
2003-10-18 12:21:41 +00:00
}
}
2003-10-28 16:26:51 +00:00
static void v3d_posearmature_buts ( uiBlock * block , Object * ob , float lim )
{
bArmature * arm ;
Bone * bone ;
arm = get_armature ( OBACT ) ;
if ( ! arm )
return ;
bone = get_first_selected_bone ( ) ;
if ( ! bone )
return ;
2003-11-14 15:49:26 +00:00
uiBlockBeginAlign ( block ) ;
2003-12-29 20:12:21 +00:00
uiDefButF ( block , NUM , B_ARMATUREPANEL2 , " QuatX: " , 10 , 120 , 140 , 19 , bone - > quat , - 100.0 , 100.0 , 10 , 3 , " " ) ;
uiDefButF ( block , NUM , B_ARMATUREPANEL2 , " QuatZ: " , 10 , 100 , 140 , 19 , bone - > quat + 2 , - 100.0 , 100.0 , 10 , 3 , " " ) ;
2003-11-14 15:49:26 +00:00
uiBlockBeginAlign ( block ) ;
2003-12-29 20:12:21 +00:00
uiDefButF ( block , NUM , B_ARMATUREPANEL2 , " QuatY: " , 160 , 120 , 140 , 19 , bone - > quat + 1 , - 100.0 , 100.0 , 10 , 3 , " " ) ;
uiDefButF ( block , NUM , B_ARMATUREPANEL2 , " QuatW: " , 160 , 100 , 140 , 19 , bone - > quat + 3 , - 100.0 , 100.0 , 10 , 3 , " " ) ;
2003-11-14 15:49:26 +00:00
uiBlockBeginAlign ( block ) ;
2003-12-29 20:12:21 +00:00
uiDefButF ( block , NUM , B_ARMATUREPANEL2 , " LocX: " , 10 , 70 , 140 , 19 , bone - > loc , - lim , lim , 100 , 3 , " " ) ;
uiDefButF ( block , NUM , B_ARMATUREPANEL2 , " LocY: " , 10 , 50 , 140 , 19 , bone - > loc + 1 , - lim , lim , 100 , 3 , " " ) ;
uiDefButF ( block , NUM , B_ARMATUREPANEL2 , " locZ: " , 10 , 30 , 140 , 19 , bone - > loc + 2 , - lim , lim , 100 , 3 , " " ) ;
2003-11-14 15:49:26 +00:00
uiBlockBeginAlign ( block ) ;
2003-12-29 20:12:21 +00:00
uiDefButF ( block , NUM , B_ARMATUREPANEL2 , " SizeX: " , 160 , 70 , 140 , 19 , bone - > size , - lim , lim , 100 , 3 , " " ) ;
2004-03-25 15:32:37 +00:00
uiDefButF ( block , NUM , B_ARMATUREPANEL2 , " SizeY: " , 160 , 50 , 140 , 19 , bone - > size + 1 , - lim , lim , 100 , 3 , " " ) ;
2003-12-29 20:12:21 +00:00
uiDefButF ( block , NUM , B_ARMATUREPANEL2 , " SizeZ: " , 160 , 30 , 140 , 19 , bone - > size + 2 , - lim , lim , 100 , 3 , " " ) ;
2003-11-14 00:44:48 +00:00
uiBlockEndAlign ( block ) ;
2003-10-28 16:26:51 +00:00
}
static void v3d_editarmature_buts ( uiBlock * block , Object * ob , float lim )
{
EditBone * ebone ;
ebone = G . edbo . first ;
for ( ebone = G . edbo . first ; ebone ; ebone = ebone - > next ) {
if ( ebone - > flag & BONE_SELECTED )
break ;
}
if ( ! ebone )
return ;
2003-11-14 15:49:26 +00:00
uiBlockBeginAlign ( block ) ;
2003-12-29 20:12:21 +00:00
uiDefButF ( block , NUM , B_ARMATUREPANEL1 , " RootX: " , 10 , 70 , 140 , 19 , ebone - > head , - lim , lim , 100 , 3 , " " ) ;
uiDefButF ( block , NUM , B_ARMATUREPANEL1 , " RootY: " , 10 , 50 , 140 , 19 , ebone - > head + 1 , - lim , lim , 100 , 3 , " " ) ;
uiDefButF ( block , NUM , B_ARMATUREPANEL1 , " RootZ: " , 10 , 30 , 140 , 19 , ebone - > head + 2 , - lim , lim , 100 , 3 , " " ) ;
2003-11-14 15:49:26 +00:00
uiBlockBeginAlign ( block ) ;
2003-12-29 20:12:21 +00:00
uiDefButF ( block , NUM , B_ARMATUREPANEL1 , " TipX: " , 160 , 70 , 140 , 19 , ebone - > tail , - lim , lim , 100 , 3 , " " ) ;
uiDefButF ( block , NUM , B_ARMATUREPANEL1 , " TipY: " , 160 , 50 , 140 , 19 , ebone - > tail + 1 , - lim , lim , 100 , 3 , " " ) ;
uiDefButF ( block , NUM , B_ARMATUREPANEL1 , " TipZ: " , 160 , 30 , 140 , 19 , ebone - > tail + 2 , - lim , lim , 100 , 3 , " " ) ;
2003-11-14 00:44:48 +00:00
uiBlockEndAlign ( block ) ;
2003-10-28 16:26:51 +00:00
ob_eul [ 0 ] = 180.0 * ebone - > roll / M_PI ;
2003-12-29 20:12:21 +00:00
uiDefButF ( block , NUM , B_ARMATUREPANEL1 , " Roll: " , 10 , 100 , 140 , 19 , ob_eul , - lim , lim , 100 , 3 , " " ) ;
2003-10-28 16:26:51 +00:00
}
2004-05-30 14:12:14 +00:00
static void v3d_editmetaball_buts ( uiBlock * block , Object * ob , float lim )
{
2004-07-21 17:44:44 +00:00
extern MetaElem * lastelem ;
if ( lastelem ) {
uiBlockBeginAlign ( block ) ;
uiDefButF ( block , NUM , B_RECALCMBALL , " LocX: " , 10 , 70 , 140 , 19 , & lastelem - > x , - lim , lim , 100 , 3 , " " ) ;
uiDefButF ( block , NUM , B_RECALCMBALL , " LocY: " , 10 , 50 , 140 , 19 , & lastelem - > y , - lim , lim , 100 , 3 , " " ) ;
uiDefButF ( block , NUM , B_RECALCMBALL , " LocZ: " , 10 , 30 , 140 , 19 , & lastelem - > z , - lim , lim , 100 , 3 , " " ) ;
uiBlockBeginAlign ( block ) ;
if ( lastelem - > type ! = MB_BALL )
uiDefButF ( block , NUM , B_RECALCMBALL , " dx: " , 160 , 70 , 140 , 19 , & lastelem - > expx , 0 , lim , 100 , 3 , " " ) ;
if ( ( lastelem - > type ! = MB_BALL ) & & ( lastelem - > type ! = MB_TUBE ) )
uiDefButF ( block , NUM , B_RECALCMBALL , " dy: " , 160 , 50 , 140 , 19 , & lastelem - > expy , 0 , lim , 100 , 3 , " " ) ;
if ( ( lastelem - > type = = MB_ELIPSOID ) | | ( lastelem - > type = = MB_CUBE ) )
uiDefButF ( block , NUM , B_RECALCMBALL , " dz: " , 160 , 30 , 140 , 19 , & lastelem - > expz , 0 , lim , 100 , 3 , " " ) ;
uiBlockEndAlign ( block ) ;
uiDefButF ( block , NUM , B_RECALCMBALL , " Stiffness: " , 10 , 100 , 140 , 19 , & lastelem - > s , 0 , lim , 100 , 3 , " " ) ;
}
2004-05-30 14:12:14 +00:00
}
2003-10-15 16:01:08 +00:00
2003-10-15 12:26:26 +00:00
void do_viewbuts ( unsigned short event )
{
View3D * vd ;
2003-10-15 16:01:08 +00:00
Object * ob = OBACT ;
2003-10-15 12:26:26 +00:00
char * name ;
vd = G . vd ;
if ( vd = = 0 ) return ;
switch ( event ) {
case B_LOADBGPIC :
if ( vd - > bgpic & & vd - > bgpic - > ima ) name = vd - > bgpic - > ima - > name ;
else name = G . ima ;
2003-11-08 10:47:50 +00:00
if ( G . qual = = LR_CTRLKEY )
2004-06-05 05:55:15 +00:00
activate_imageselect ( FILE_SPECIAL , " Select Image " , name , load_bgpic_image ) ;
2003-11-08 10:47:50 +00:00
else
2004-06-05 05:55:15 +00:00
activate_fileselect ( FILE_SPECIAL , " Select Image " , name , load_bgpic_image ) ;
2003-10-15 12:26:26 +00:00
break ;
2003-10-15 16:01:08 +00:00
2003-10-15 12:26:26 +00:00
case B_BLENDBGPIC :
if ( vd - > bgpic & & vd - > bgpic - > rect ) setalpha_bgpic ( vd - > bgpic ) ;
2003-10-15 17:41:40 +00:00
addqueue ( curarea - > win , REDRAW , 1 ) ;
2003-10-15 12:26:26 +00:00
break ;
2003-10-15 16:01:08 +00:00
2003-10-15 12:26:26 +00:00
case B_BGPICBROWSE :
if ( vd - > bgpic ) {
2003-12-31 13:48:45 +00:00
if ( vd - > menunr = = - 2 ) {
activate_databrowse ( ( ID * ) vd - > bgpic - > ima , ID_IM , 0 , B_BGPICBROWSE , & vd - > menunr , do_viewbuts ) ;
} else if ( vd - > menunr > 0 ) {
Image * newima = ( Image * ) BLI_findlink ( & G . main - > image , vd - > menunr - 1 ) ;
2003-10-15 12:26:26 +00:00
if ( newima )
view3d_change_bgpic_ima ( vd , newima ) ;
}
}
break ;
2003-10-15 16:01:08 +00:00
2003-10-15 12:26:26 +00:00
case B_BGPICCLEAR :
if ( vd - > bgpic )
view3d_change_bgpic_ima ( vd , NULL ) ;
break ;
2003-10-15 16:01:08 +00:00
2003-10-15 12:26:26 +00:00
case B_BGPICTEX :
if ( vd - > bgpic ) {
2003-12-31 13:48:45 +00:00
if ( vd - > texnr = = - 2 ) {
activate_databrowse ( ( ID * ) vd - > bgpic - > tex , ID_TE , 0 , B_BGPICTEX , & vd - > texnr , do_viewbuts ) ;
} else if ( vd - > texnr > 0 ) {
Tex * newtex = ( Tex * ) BLI_findlink ( & G . main - > tex , vd - > texnr - 1 ) ;
2003-10-15 12:26:26 +00:00
if ( newtex )
view3d_change_bgpic_tex ( vd , newtex ) ;
}
}
break ;
2003-10-15 16:01:08 +00:00
2003-10-15 12:26:26 +00:00
case B_BGPICTEXCLEAR :
if ( vd - > bgpic )
view3d_change_bgpic_tex ( vd , NULL ) ;
break ;
2003-10-15 16:01:08 +00:00
case B_OBJECTPANELROT :
if ( ob ) {
ob - > rot [ 0 ] = M_PI * ob_eul [ 0 ] / 180.0 ;
ob - > rot [ 1 ] = M_PI * ob_eul [ 1 ] / 180.0 ;
ob - > rot [ 2 ] = M_PI * ob_eul [ 2 ] / 180.0 ;
allqueue ( REDRAWVIEW3D , 1 ) ;
}
break ;
2004-04-06 19:16:14 +00:00
2003-10-18 12:21:41 +00:00
case B_OBJECTPANELMEDIAN :
if ( ob ) {
v3d_editvertex_buts ( NULL , ob , 1.0 ) ;
2003-10-22 09:06:30 +00:00
makeDispList ( ob ) ;
2003-10-18 12:21:41 +00:00
allqueue ( REDRAWVIEW3D , 1 ) ;
}
break ;
2004-04-06 19:16:14 +00:00
case B_OBJECTPANELPARENT :
if ( ob ) {
if ( test_parent_loop ( ob - > parent , ob ) )
ob - > parent = NULL ;
allqueue ( REDRAWVIEW3D , 1 ) ;
}
break ;
2003-10-28 16:26:51 +00:00
case B_ARMATUREPANEL1 :
{
EditBone * ebone , * child ;
ebone = G . edbo . first ;
for ( ebone = G . edbo . first ; ebone ; ebone = ebone - > next ) {
if ( ebone - > flag & BONE_SELECTED ) break ;
}
if ( ebone ) {
ebone - > roll = M_PI * ob_eul [ 0 ] / 180.0 ;
// Update our parent
if ( ebone - > parent & & ebone - > flag & BONE_IK_TOPARENT ) {
VECCOPY ( ebone - > parent - > tail , ebone - > head ) ;
}
// Update our children if necessary
for ( child = G . edbo . first ; child ; child = child - > next ) {
if ( child - > parent = = ebone & & child - > flag & BONE_IK_TOPARENT ) {
VECCOPY ( child - > head , ebone - > tail ) ;
}
}
allqueue ( REDRAWVIEW3D , 1 ) ;
}
}
break ;
case B_ARMATUREPANEL2 :
{
bPoseChannel * chan ;
bArmature * arm ;
Bone * bone ;
2004-01-23 02:25:51 +00:00
2003-10-28 16:26:51 +00:00
arm = get_armature ( OBACT ) ;
if ( ! arm ) return ;
bone = get_first_selected_bone ( ) ;
if ( ! bone ) return ;
/* This is similar to code in special_trans_update */
if ( ! G . obpose - > pose ) G . obpose - > pose = MEM_callocN ( sizeof ( bPose ) , " pose " ) ;
chan = MEM_callocN ( sizeof ( bPoseChannel ) , " transPoseChannel " ) ;
chan - > flag | = POSE_LOC | POSE_ROT | POSE_SIZE ;
memcpy ( chan - > loc , bone - > loc , sizeof ( chan - > loc ) ) ;
memcpy ( chan - > quat , bone - > quat , sizeof ( chan - > quat ) ) ;
memcpy ( chan - > size , bone - > size , sizeof ( chan - > size ) ) ;
strcpy ( chan - > name , bone - > name ) ;
set_pose_channel ( G . obpose - > pose , chan ) ;
2004-01-23 02:25:51 +00:00
2004-01-27 06:08:37 +00:00
rebuild_all_armature_displists ( ) ;
2004-01-23 02:25:51 +00:00
2003-10-28 16:26:51 +00:00
allqueue ( REDRAWVIEW3D , 1 ) ;
}
2003-10-15 12:26:26 +00:00
}
}
2003-10-18 12:21:41 +00:00
2003-10-16 00:17:24 +00:00
static void view3d_panel_object ( short cntrl ) // VIEW3D_HANDLER_OBJECT
2003-10-15 16:01:08 +00:00
{
uiBlock * block ;
Object * ob = OBACT ;
float lim ;
if ( ob = = NULL ) return ;
2003-10-16 00:17:24 +00:00
Another mega commit... loadsof restructure, and a pretty good one! :)
- changed the BIF_DrawString() function. it used to work different for
AA fonts as for default fonts. Now it's identical. Setting color for fonts
can just be done with OpenGL, for both font types.
Removed: BIF_DrawStringRGB()
- added theme color options for Buttons
- recoded DefButton, so it automatically chooses the right color.
- had to remove a 1000 uiBlockSetCol() calls for that reason...
- uiBlockSetCol() still works, to override automatic color
- removed entirely the silly old color system (BIFColorID). All color
calls can now be done with a BIF_ThemeColor() call, including fonts and
buttons and opengl stuff
- all buttons in button header have headercolor by default
- recoded drawing icons, it was a really bad & old loop doing manually
colorshading and blending... which was per pixel a load of code!
Now it uses a single OpenGL call to blend or colorize. Quite faster!
- (as test, for review) icons don't colorize anymore with button color,
but have a different alpha to blend in (when not active)
- recoded the entire interface_draw.c file...:
- drawing buttons is separated in three parts:
1. main drawing function for text and icons
2. free definable callback for button itself
3. free definable callback for slider
- removed a load of redundant code for this!
- coded a minimal theme, and adjusted Matt's buttons to match new
callback system
- adding new drawing themes is piece of cake now
- for coders, default 'themes' to be aware of:
UI_EMBOSS : the themable drawing style
UI_EMBOSSP: the pulldown menu system (apart from color not themable)
UI_EMBOSSN: draw nothing, only text and/or icon
UI_EMBOSSM: minimal theme, still in use for Logic and Constraintsa
this can be set with uiBlockSetEmboss(block) or in the uiNewBlock() call.
TODO: make UI API call for button alignment
(plus removed another series of warnings from code...)
Plus: fixed bug in Matts commit: he used a 'short' button for an 'int'
2003-10-20 15:40:20 +00:00
block = uiNewBlock ( & curarea - > uiblocks , " view3d_panel_object " , UI_EMBOSS , UI_HELV , curarea - > win ) ;
- The basic layer for Themes in place!
- currently only implemented for 3d window
- create as many themes you like, and name them
- default theme is not editable, and always will be defined at startup
(initTheme)
- saves in .B.blend
- themes for spaces can become local too, so you can set individual
3d windows at theme 'Maya' or so. (to be implemented)
- it uses alpha as well...!
API:
This doesnt use the old method with BFCOLORID blahblah. The API is copied
from OpenGL conventions (naming) as much as possible:
- void BIF_ThemeColor(ScrArea *sa, int colorid)
sets a color... id's are in BIF_resources.h (TH_GRID, TH_WIRE, etc)
- void BIF_ThemeColorShade(ScrArea *sa, int colorid, int offset)
sets a color with offset, no more weird COLORSHADE_LGREY stuff
- void BIF_GetThemeColor3fv(ScrArea *sa, int colorid, float *col)
like opengl, this gives you in *col the three rgb values
- void BIF_GetThemeColor4ubv(ScrArea *sa, int colorid, char *col)
or the one to get 4 bytes
ThemeColor calls for globals (UI etc) can also call NULL for *sa... this
is to be implemented still.
Next step: cleaning up interface.c for all weird colorcalls.
2003-10-17 14:02:08 +00:00
uiPanelControl ( UI_PNL_SOLID | UI_PNL_CLOSE | cntrl ) ;
2003-10-16 00:17:24 +00:00
uiSetPanelHandler ( VIEW3D_HANDLER_OBJECT ) ; // for close and esc
2004-07-16 02:10:29 +00:00
2004-07-31 22:05:46 +00:00
/* (ton) can't use the rename trick for paint... panel names and settings are stored in the files and
used to find previous locations when re - open . This causes flipping */
if ( uiNewPanel ( curarea , block , " Transform Properties " , " View3d " , 10 , 230 , 318 , 204 ) = = 0 ) return ;
2004-07-10 17:40:40 +00:00
if ( ( G . f & ( G_VERTEXPAINT | G_TEXTUREPAINT ) ) = = 0 ) {
2004-08-02 13:06:09 +00:00
uiDefBut ( block , TEX , B_IDNAME , " OB: " , 10 , 180 , 140 , 20 , ob - > id . name + 2 , 0.0 , 19.0 , 0 , 0 , " " ) ;
2004-07-10 17:40:40 +00:00
uiDefIDPoinBut ( block , test_obpoin_but , B_OBJECTPANELPARENT , " Par: " , 160 , 180 , 140 , 20 , & ob - > parent , " Parent Object " ) ;
}
2003-10-15 16:01:08 +00:00
lim = 1000.0 * MAX2 ( 1.0 , G . vd - > grid ) ;
2003-10-18 12:21:41 +00:00
if ( ob = = G . obedit ) {
2003-10-28 16:26:51 +00:00
if ( ob - > type = = OB_ARMATURE ) v3d_editarmature_buts ( block , ob , lim ) ;
2004-05-30 14:12:14 +00:00
if ( ob - > type = = OB_MBALL ) v3d_editmetaball_buts ( block , ob , lim ) ;
2003-10-28 16:26:51 +00:00
else v3d_editvertex_buts ( block , ob , lim ) ;
}
else if ( ob = = G . obpose ) {
v3d_posearmature_buts ( block , ob , lim ) ;
2003-10-18 12:21:41 +00:00
}
2004-07-10 17:40:40 +00:00
else if ( G . f & ( G_VERTEXPAINT | G_TEXTUREPAINT ) ) {
extern VPaint Gvp ; /* from vpaint */
static float hsv [ 3 ] , old [ 3 ] ; // used as temp mem for picker
2004-08-04 06:52:41 +00:00
uiBlockPickerButtons ( block , & Gvp . r , hsv , old , ' f ' ) ; /* 'f' is for floating panel */
2004-07-10 17:40:40 +00:00
}
2003-10-18 12:21:41 +00:00
else {
2003-11-14 15:49:26 +00:00
uiBlockBeginAlign ( block ) ;
2003-12-29 20:12:21 +00:00
uiDefButF ( block , NUM , REDRAWVIEW3D , " LocX: " , 10 , 140 , 140 , 19 , & ( ob - > loc [ 0 ] ) , - lim , lim , 100 , 3 , " " ) ;
uiDefButF ( block , NUM , REDRAWVIEW3D , " LocY: " , 10 , 120 , 140 , 19 , & ( ob - > loc [ 1 ] ) , - lim , lim , 100 , 3 , " " ) ;
uiDefButF ( block , NUM , REDRAWVIEW3D , " LocZ: " , 10 , 100 , 140 , 19 , & ( ob - > loc [ 2 ] ) , - lim , lim , 100 , 3 , " " ) ;
2003-10-15 16:01:08 +00:00
2003-10-18 12:21:41 +00:00
ob_eul [ 0 ] = 180.0 * ob - > rot [ 0 ] / M_PI ;
ob_eul [ 1 ] = 180.0 * ob - > rot [ 1 ] / M_PI ;
ob_eul [ 2 ] = 180.0 * ob - > rot [ 2 ] / M_PI ;
2003-11-14 15:49:26 +00:00
uiBlockBeginAlign ( block ) ;
2003-12-29 20:12:21 +00:00
uiDefButF ( block , NUM , B_OBJECTPANELROT , " RotX: " , 10 , 70 , 140 , 19 , & ( ob_eul [ 0 ] ) , - lim , lim , 1000 , 3 , " " ) ;
uiDefButF ( block , NUM , B_OBJECTPANELROT , " RotY: " , 10 , 50 , 140 , 19 , & ( ob_eul [ 1 ] ) , - lim , lim , 1000 , 3 , " " ) ;
uiDefButF ( block , NUM , B_OBJECTPANELROT , " RotZ: " , 10 , 30 , 140 , 19 , & ( ob_eul [ 2 ] ) , - lim , lim , 1000 , 3 , " " ) ;
2003-11-14 15:49:26 +00:00
uiBlockBeginAlign ( block ) ;
2003-12-29 20:12:21 +00:00
uiDefButF ( block , NUM , REDRAWVIEW3D , " SizeX: " , 160 , 70 , 140 , 19 , & ( ob - > size [ 0 ] ) , - lim , lim , 100 , 3 , " " ) ;
uiDefButF ( block , NUM , REDRAWVIEW3D , " SizeY: " , 160 , 50 , 140 , 19 , & ( ob - > size [ 1 ] ) , - lim , lim , 100 , 3 , " " ) ;
uiDefButF ( block , NUM , REDRAWVIEW3D , " SizeZ: " , 160 , 30 , 140 , 19 , & ( ob - > size [ 2 ] ) , - lim , lim , 100 , 3 , " " ) ;
2003-11-14 00:44:48 +00:00
uiBlockEndAlign ( block ) ;
2003-10-18 12:21:41 +00:00
}
2003-10-16 00:17:24 +00:00
}
2003-10-15 16:01:08 +00:00
2004-06-29 20:34:10 +00:00
static void view3d_panel_background ( short cntrl ) // VIEW3D_HANDLER_BACKGROUND
2003-10-15 12:26:26 +00:00
{
uiBlock * block ;
View3D * vd ;
ID * id ;
char * strp ;
vd = G . vd ;
2003-10-25 22:03:19 +00:00
block = uiNewBlock ( & curarea - > uiblocks , " view3d_panel_background " , UI_EMBOSS , UI_HELV , curarea - > win ) ;
- The basic layer for Themes in place!
- currently only implemented for 3d window
- create as many themes you like, and name them
- default theme is not editable, and always will be defined at startup
(initTheme)
- saves in .B.blend
- themes for spaces can become local too, so you can set individual
3d windows at theme 'Maya' or so. (to be implemented)
- it uses alpha as well...!
API:
This doesnt use the old method with BFCOLORID blahblah. The API is copied
from OpenGL conventions (naming) as much as possible:
- void BIF_ThemeColor(ScrArea *sa, int colorid)
sets a color... id's are in BIF_resources.h (TH_GRID, TH_WIRE, etc)
- void BIF_ThemeColorShade(ScrArea *sa, int colorid, int offset)
sets a color with offset, no more weird COLORSHADE_LGREY stuff
- void BIF_GetThemeColor3fv(ScrArea *sa, int colorid, float *col)
like opengl, this gives you in *col the three rgb values
- void BIF_GetThemeColor4ubv(ScrArea *sa, int colorid, char *col)
or the one to get 4 bytes
ThemeColor calls for globals (UI etc) can also call NULL for *sa... this
is to be implemented still.
Next step: cleaning up interface.c for all weird colorcalls.
2003-10-17 14:02:08 +00:00
uiPanelControl ( UI_PNL_SOLID | UI_PNL_CLOSE | cntrl ) ;
2003-10-16 00:17:24 +00:00
uiSetPanelHandler ( VIEW3D_HANDLER_BACKGROUND ) ; // for close and esc
2004-01-24 05:06:12 +00:00
if ( uiNewPanel ( curarea , block , " Background Image " , " View3d " , 340 , 10 , 318 , 204 ) = = 0 ) return ;
2003-10-15 12:26:26 +00:00
if ( vd - > flag & V3D_DISPBGPIC ) {
if ( vd - > bgpic = = 0 ) {
vd - > bgpic = MEM_callocN ( sizeof ( BGpic ) , " bgpic " ) ;
vd - > bgpic - > size = 5.0 ;
vd - > bgpic - > blend = 0.5 ;
}
}
2004-01-24 05:06:12 +00:00
uiDefButBitS ( block , TOG , V3D_DISPBGPIC , REDRAWVIEW3D , " Use Background Image " , 0 , 162 , 200 , 20 , & vd - > flag , 0 , 0 , 0 , 0 , " Display an image in the background of the 3D View " ) ;
uiDefBut ( block , LABEL , 1 , " " , 206 , 162 , 84 , 20 , NULL , 0.0 , 0.0 , 0 , 0 , " " ) ;
if ( vd - > flag & V3D_DISPBGPIC ) {
/* Background Image */
uiDefBut ( block , LABEL , 1 , " Image: " , 0 , 128 , 76 , 19 , NULL , 0.0 , 0.0 , 0 , 0 , " " ) ;
2003-10-15 12:26:26 +00:00
2004-01-24 05:06:12 +00:00
uiBlockBeginAlign ( block ) ;
uiDefIconBut ( block , BUT , B_LOADBGPIC , ICON_FILESEL , 90 , 128 , 20 , 20 , 0 , 0 , 0 , 0 , 0 , " Open a new background image " ) ;
2003-10-15 12:26:26 +00:00
id = ( ID * ) vd - > bgpic - > ima ;
2003-12-31 13:48:45 +00:00
IDnames_to_pupstring ( & strp , NULL , NULL , & ( G . main - > image ) , id , & ( vd - > menunr ) ) ;
2003-11-22 22:22:16 +00:00
if ( strp [ 0 ] ) {
2004-01-24 05:06:12 +00:00
uiDefButS ( block , MENU , B_BGPICBROWSE , strp , 110 , 128 , 20 , 20 , & ( vd - > menunr ) , 0 , 0 , 0 , 0 , " Select a background image " ) ;
2003-10-15 12:26:26 +00:00
2003-11-22 22:22:16 +00:00
if ( vd - > bgpic - > ima ) {
2004-01-24 05:06:12 +00:00
uiDefBut ( block , TEX , 0 , " BG: " , 130 , 128 , 140 , 20 , & vd - > bgpic - > ima - > name , 0.0 , 100.0 , 0 , 0 , " The currently selected background image " ) ;
uiDefIconBut ( block , BUT , B_BGPICCLEAR , ICON_X , 270 , 128 , 20 , 20 , 0 , 0 , 0 , 0 , 0 , " Remove background image link " ) ;
2003-11-22 22:22:16 +00:00
}
uiBlockEndAlign ( block ) ;
2004-01-24 05:06:12 +00:00
} else {
uiBlockEndAlign ( block ) ;
2003-10-15 12:26:26 +00:00
}
2003-11-22 22:22:16 +00:00
MEM_freeN ( strp ) ;
2003-10-25 22:59:15 +00:00
2004-01-24 05:06:12 +00:00
/* Background texture */
uiDefBut ( block , LABEL , 1 , " Texture: " , 0 , 100 , 76 , 19 , NULL , 0.0 , 0.0 , 0 , 0 , " " ) ;
2003-10-15 12:26:26 +00:00
id = ( ID * ) vd - > bgpic - > tex ;
2003-12-31 13:48:45 +00:00
IDnames_to_pupstring ( & strp , NULL , NULL , & ( G . main - > tex ) , id , & ( vd - > texnr ) ) ;
2004-01-24 05:06:12 +00:00
if ( strp [ 0 ] )
uiBlockBeginAlign ( block ) ;
uiDefButS ( block , MENU , B_BGPICTEX , strp , 90 , 100 , 20 , 20 , & ( vd - > texnr ) , 0 , 0 , 0 , 0 , " Select a texture to use as an animated background image " ) ;
2003-10-15 12:26:26 +00:00
MEM_freeN ( strp ) ;
if ( id ) {
2004-01-24 05:06:12 +00:00
uiDefBut ( block , TEX , B_IDNAME , " TE: " , 110 , 100 , 160 , 20 , id - > name + 2 , 0.0 , 18.0 , 0 , 0 , " " ) ;
uiDefIconBut ( block , BUT , B_BGPICTEXCLEAR , ICON_X , 270 , 100 , 20 , 20 , 0 , 0 , 0 , 0 , 0 , " Remove background texture link " ) ;
uiBlockEndAlign ( block ) ;
} else {
uiBlockEndAlign ( block ) ;
2003-10-15 12:26:26 +00:00
}
2004-01-24 05:06:12 +00:00
uiDefButF ( block , NUMSLI , B_BLENDBGPIC , " Blend: " , 0 , 60 , 290 , 19 , & vd - > bgpic - > blend , 0.0 , 1.0 , 0 , 0 , " Set the transparency of the background image " ) ;
uiDefButF ( block , NUM , REDRAWVIEW3D , " Size: " , 0 , 28 , 140 , 19 , & vd - > bgpic - > size , 0.1 , 250.0 , 100 , 0 , " Set the size (width) of the background image " ) ;
uiDefButF ( block , NUM , REDRAWVIEW3D , " X Offset: " , 0 , 6 , 140 , 19 , & vd - > bgpic - > xof , - 20.0 , 20.0 , 10 , 2 , " Set the horizontal offset of the background image " ) ;
uiDefButF ( block , NUM , REDRAWVIEW3D , " Y Offset: " , 150 , 6 , 140 , 19 , & vd - > bgpic - > yof , - 20.0 , 20.0 , 10 , 2 , " Set the vertical offset of the background image " ) ;
// uiDefButF(block, NUM, REDRAWVIEW3D, "Size:", 160,160,150,20, &vd->bgpic->size, 0.1, 250.0, 100, 0, "Set the size for the width of the BackGroundPic");
// uiDefButF(block, NUMSLI, B_BLENDBGPIC, "Blend:", 120,100,190,20,&vd->bgpic->blend, 0.0,1.0, 0, 0, "Set the BackGroundPic transparency");
// uiDefButF(block, NUM, B_DIFF, "Center X: ", 10,70,140,20,&vd->bgpic->xof, -20.0,20.0, 10, 2, "Set the BackGroundPic X Offset");
// uiDefButF(block, NUM, B_DIFF, "Center Y: ", 160,70,140,20,&vd->bgpic->yof, -20.0,20.0, 10, 2, "Set the BackGroundPic Y Offset");
2003-10-15 12:26:26 +00:00
}
2003-10-25 22:03:19 +00:00
}
2004-06-29 20:34:10 +00:00
static void view3d_panel_properties ( short cntrl ) // VIEW3D_HANDLER_SETTINGS
2003-10-25 22:03:19 +00:00
{
uiBlock * block ;
View3D * vd ;
2004-07-28 13:21:27 +00:00
float * curs ;
2003-10-25 22:03:19 +00:00
vd = G . vd ;
block = uiNewBlock ( & curarea - > uiblocks , " view3d_panel_properties " , UI_EMBOSS , UI_HELV , curarea - > win ) ;
uiPanelControl ( UI_PNL_SOLID | UI_PNL_CLOSE | cntrl ) ;
uiSetPanelHandler ( VIEW3D_HANDLER_PROPERTIES ) ; // for close and esc
2004-01-24 05:06:12 +00:00
if ( uiNewPanel ( curarea , block , " View Properties " , " View3d " , 340 , 10 , 318 , 204 ) = = 0 ) return ;
2003-10-25 22:03:19 +00:00
2004-07-28 13:21:27 +00:00
uiDefBut ( block , LABEL , 1 , " Grid: " , 10 , 180 , 150 , 19 , NULL , 0.0 , 0.0 , 0 , 0 , " " ) ;
uiDefButF ( block , NUM , REDRAWVIEW3D , " Spacing: " , 10 , 160 , 140 , 19 , & vd - > grid , 0.001 , 100.0 , 10 , 0 , " Set the distance between grid lines " ) ;
2004-07-29 02:25:10 +00:00
uiDefButS ( block , NUM , REDRAWVIEW3D , " Lines: " , 10 , 136 , 140 , 19 , & vd - > gridlines , 0.0 , 100.0 , 100 , 0 , " Set the number of grid lines " ) ;
uiDefBut ( block , LABEL , 1 , " 3D Display: " , 160 , 180 , 150 , 19 , NULL , 0.0 , 0.0 , 0 , 0 , " " ) ;
2004-07-28 13:21:27 +00:00
uiDefButBitS ( block , TOG , V3D_SHOW_FLOOR , REDRAWVIEW3D , " Grid Floor " , 160 , 160 , 150 , 19 , & vd - > gridflag , 0 , 0 , 0 , 0 , " Show the grid floor in free camera mode " ) ;
2004-07-29 02:25:10 +00:00
uiDefButBitS ( block , TOG , V3D_SHOW_X , REDRAWVIEW3D , " X Axis " , 160 , 136 , 48 , 19 , & vd - > gridflag , 0 , 0 , 0 , 0 , " Show the X Axis line " ) ;
uiDefButBitS ( block , TOG , V3D_SHOW_Y , REDRAWVIEW3D , " Y Axis " , 212 , 136 , 48 , 19 , & vd - > gridflag , 0 , 0 , 0 , 0 , " Show the Y Axis line " ) ;
uiDefButBitS ( block , TOG , V3D_SHOW_Z , REDRAWVIEW3D , " Z Axis " , 262 , 136 , 48 , 19 , & vd - > gridflag , 0 , 0 , 0 , 0 , " Show the Z Axis line " ) ;
2004-01-24 05:06:12 +00:00
2004-07-28 13:21:27 +00:00
uiDefBut ( block , LABEL , 1 , " View Camera: " , 10 , 110 , 140 , 19 , NULL , 0.0 , 0.0 , 0 , 0 , " " ) ;
2003-10-15 12:26:26 +00:00
2004-07-28 13:21:27 +00:00
uiDefButF ( block , NUM , REDRAWVIEW3D , " Lens: " , 10 , 90 , 140 , 19 , & vd - > lens , 10.0 , 120.0 , 100 , 0 , " The lens angle in perspective view " ) ;
2004-07-29 02:25:10 +00:00
uiBlockBeginAlign ( block ) ;
uiDefButF ( block , NUM , REDRAWVIEW3D , " Clip Start: " , 10 , 66 , 140 , 19 , & vd - > near , vd - > grid / 10.0 , 100.0 , 10 , 0 , " Set the beginning of the range in which 3D objects are displayed (perspective view) " ) ;
uiDefButF ( block , NUM , REDRAWVIEW3D , " Clip End: " , 10 , 46 , 140 , 19 , & vd - > far , 1.0 , 1000.0 * vd - > grid , 100 , 0 , " Set the end of the range in which 3D objects are displayed (perspective view) " ) ;
2004-07-28 13:21:27 +00:00
uiBlockEndAlign ( block ) ;
2003-10-15 12:26:26 +00:00
2004-07-28 13:21:27 +00:00
uiDefBut ( block , LABEL , 1 , " 3D Cursor: " , 160 , 110 , 140 , 19 , NULL , 0.0 , 0.0 , 0 , 0 , " " ) ;
uiBlockBeginAlign ( block ) ;
curs = give_cursor ( ) ;
2004-07-29 02:25:10 +00:00
uiDefButF ( block , NUM , REDRAWVIEW3D , " X: " , 160 , 90 , 150 , 22 , curs , - 1000.0 * vd - > grid , 1000.0 * vd - > grid , 10 , 0 , " X co-ordinate of the 3D cursor " ) ;
uiDefButF ( block , NUM , REDRAWVIEW3D , " Y: " , 160 , 68 , 150 , 22 , curs + 1 , - 1000.0 * vd - > grid , 1000.0 * vd - > grid , 10 , 0 , " Y co-ordinate of the 3D cursor " ) ;
uiDefButF ( block , NUM , REDRAWVIEW3D , " Z: " , 160 , 46 , 150 , 22 , curs + 2 , - 1000.0 * vd - > grid , 1000.0 * vd - > grid , 10 , 0 , " Z co-ordinate of the 3D cursor " ) ;
2004-07-28 13:21:27 +00:00
uiBlockEndAlign ( block ) ;
2004-07-29 02:25:10 +00:00
uiDefButBitS ( block , TOG , V3D_SELECT_OUTLINE , REDRAWVIEW3D , " Outline Selected Objects " , 10 , 10 , 300 , 19 , & vd - > flag , 0 , 0 , 0 , 0 , " Highlight selected objects with an outline, in Solid, Shaded or Textured viewport shading modes " ) ;
2003-10-15 12:26:26 +00:00
}
static void view3d_blockhandlers ( ScrArea * sa )
{
View3D * v3d = sa - > spacedata . first ;
short a ;
2004-06-16 20:25:56 +00:00
/* warning; blocks need to be freed each time, handlers dont remove */
2003-10-16 00:17:24 +00:00
uiFreeBlocksWin ( & sa - > uiblocks , sa - > win ) ;
2003-10-15 16:01:08 +00:00
for ( a = 0 ; a < SPACE_MAXHANDLER ; a + = 2 ) {
2003-10-15 12:26:26 +00:00
switch ( v3d - > blockhandler [ a ] ) {
2003-10-25 22:03:19 +00:00
case VIEW3D_HANDLER_PROPERTIES :
view3d_panel_properties ( v3d - > blockhandler [ a + 1 ] ) ;
2003-10-15 16:01:08 +00:00
break ;
2003-10-25 22:03:19 +00:00
case VIEW3D_HANDLER_BACKGROUND :
view3d_panel_background ( v3d - > blockhandler [ a + 1 ] ) ;
2003-10-15 12:26:26 +00:00
break ;
case VIEW3D_HANDLER_OBJECT :
2003-10-15 16:01:08 +00:00
view3d_panel_object ( v3d - > blockhandler [ a + 1 ] ) ;
2003-10-15 12:26:26 +00:00
break ;
}
2003-10-15 16:01:08 +00:00
/* clear action value for event */
v3d - > blockhandler [ a + 1 ] = 0 ;
2003-10-15 12:26:26 +00:00
}
uiDrawBlocksPanels ( sa , 0 ) ;
}
2003-03-24 01:46:05 +00:00
void drawview3dspace ( ScrArea * sa , void * spacedata )
2002-10-12 11:37:38 +00:00
{
2003-10-23 16:15:05 +00:00
extern void constline_callback ( void ) ; // editobject.c helpline
2002-10-12 11:37:38 +00:00
Base * base ;
Object * ob ;
2003-04-28 14:43:20 +00:00
setwinmatrixview3d ( 0 ) ; /* 0= no pick rect */
2002-10-12 11:37:38 +00:00
setviewmatrixview3d ( ) ;
Mat4MulMat4 ( G . vd - > persmat , G . vd - > viewmat , curarea - > winmat ) ;
Mat4Invert ( G . vd - > persinv , G . vd - > persmat ) ;
Mat4Invert ( G . vd - > viewinv , G . vd - > viewmat ) ;
if ( G . vd - > drawtype > OB_WIRE ) {
G . zbuf = TRUE ;
glEnable ( GL_DEPTH_TEST ) ;
if ( G . f & G_SIMULATION ) {
glClearColor ( 0.0 , 0.0 , 0.0 , 0.0 ) ;
}
else {
- The basic layer for Themes in place!
- currently only implemented for 3d window
- create as many themes you like, and name them
- default theme is not editable, and always will be defined at startup
(initTheme)
- saves in .B.blend
- themes for spaces can become local too, so you can set individual
3d windows at theme 'Maya' or so. (to be implemented)
- it uses alpha as well...!
API:
This doesnt use the old method with BFCOLORID blahblah. The API is copied
from OpenGL conventions (naming) as much as possible:
- void BIF_ThemeColor(ScrArea *sa, int colorid)
sets a color... id's are in BIF_resources.h (TH_GRID, TH_WIRE, etc)
- void BIF_ThemeColorShade(ScrArea *sa, int colorid, int offset)
sets a color with offset, no more weird COLORSHADE_LGREY stuff
- void BIF_GetThemeColor3fv(ScrArea *sa, int colorid, float *col)
like opengl, this gives you in *col the three rgb values
- void BIF_GetThemeColor4ubv(ScrArea *sa, int colorid, char *col)
or the one to get 4 bytes
ThemeColor calls for globals (UI etc) can also call NULL for *sa... this
is to be implemented still.
Next step: cleaning up interface.c for all weird colorcalls.
2003-10-17 14:02:08 +00:00
float col [ 3 ] ;
2003-10-19 09:19:58 +00:00
BIF_GetThemeColor3fv ( TH_BACK , col ) ;
- The basic layer for Themes in place!
- currently only implemented for 3d window
- create as many themes you like, and name them
- default theme is not editable, and always will be defined at startup
(initTheme)
- saves in .B.blend
- themes for spaces can become local too, so you can set individual
3d windows at theme 'Maya' or so. (to be implemented)
- it uses alpha as well...!
API:
This doesnt use the old method with BFCOLORID blahblah. The API is copied
from OpenGL conventions (naming) as much as possible:
- void BIF_ThemeColor(ScrArea *sa, int colorid)
sets a color... id's are in BIF_resources.h (TH_GRID, TH_WIRE, etc)
- void BIF_ThemeColorShade(ScrArea *sa, int colorid, int offset)
sets a color with offset, no more weird COLORSHADE_LGREY stuff
- void BIF_GetThemeColor3fv(ScrArea *sa, int colorid, float *col)
like opengl, this gives you in *col the three rgb values
- void BIF_GetThemeColor4ubv(ScrArea *sa, int colorid, char *col)
or the one to get 4 bytes
ThemeColor calls for globals (UI etc) can also call NULL for *sa... this
is to be implemented still.
Next step: cleaning up interface.c for all weird colorcalls.
2003-10-17 14:02:08 +00:00
glClearColor ( col [ 0 ] , col [ 1 ] , col [ 2 ] , 0.0 ) ;
2002-10-12 11:37:38 +00:00
}
glClear ( GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT ) ;
glLoadIdentity ( ) ;
}
else {
- The basic layer for Themes in place!
- currently only implemented for 3d window
- create as many themes you like, and name them
- default theme is not editable, and always will be defined at startup
(initTheme)
- saves in .B.blend
- themes for spaces can become local too, so you can set individual
3d windows at theme 'Maya' or so. (to be implemented)
- it uses alpha as well...!
API:
This doesnt use the old method with BFCOLORID blahblah. The API is copied
from OpenGL conventions (naming) as much as possible:
- void BIF_ThemeColor(ScrArea *sa, int colorid)
sets a color... id's are in BIF_resources.h (TH_GRID, TH_WIRE, etc)
- void BIF_ThemeColorShade(ScrArea *sa, int colorid, int offset)
sets a color with offset, no more weird COLORSHADE_LGREY stuff
- void BIF_GetThemeColor3fv(ScrArea *sa, int colorid, float *col)
like opengl, this gives you in *col the three rgb values
- void BIF_GetThemeColor4ubv(ScrArea *sa, int colorid, char *col)
or the one to get 4 bytes
ThemeColor calls for globals (UI etc) can also call NULL for *sa... this
is to be implemented still.
Next step: cleaning up interface.c for all weird colorcalls.
2003-10-17 14:02:08 +00:00
float col [ 3 ] ;
2003-10-19 09:19:58 +00:00
BIF_GetThemeColor3fv ( TH_BACK , col ) ;
- The basic layer for Themes in place!
- currently only implemented for 3d window
- create as many themes you like, and name them
- default theme is not editable, and always will be defined at startup
(initTheme)
- saves in .B.blend
- themes for spaces can become local too, so you can set individual
3d windows at theme 'Maya' or so. (to be implemented)
- it uses alpha as well...!
API:
This doesnt use the old method with BFCOLORID blahblah. The API is copied
from OpenGL conventions (naming) as much as possible:
- void BIF_ThemeColor(ScrArea *sa, int colorid)
sets a color... id's are in BIF_resources.h (TH_GRID, TH_WIRE, etc)
- void BIF_ThemeColorShade(ScrArea *sa, int colorid, int offset)
sets a color with offset, no more weird COLORSHADE_LGREY stuff
- void BIF_GetThemeColor3fv(ScrArea *sa, int colorid, float *col)
like opengl, this gives you in *col the three rgb values
- void BIF_GetThemeColor4ubv(ScrArea *sa, int colorid, char *col)
or the one to get 4 bytes
ThemeColor calls for globals (UI etc) can also call NULL for *sa... this
is to be implemented still.
Next step: cleaning up interface.c for all weird colorcalls.
2003-10-17 14:02:08 +00:00
glClearColor ( col [ 0 ] , col [ 1 ] , col [ 2 ] , 0.0 ) ;
2002-10-12 11:37:38 +00:00
glClear ( GL_COLOR_BUFFER_BIT ) ;
}
myloadmatrix ( G . vd - > viewmat ) ;
2003-10-16 09:39:19 +00:00
persp ( PERSP_STORE ) ; // store correct view for persp(PERSP_VIEW) calls
2002-10-12 11:37:38 +00:00
if ( G . vd - > view = = 0 | | G . vd - > persp ! = 0 ) {
2003-10-19 09:19:58 +00:00
drawfloor ( ) ;
2002-10-12 11:37:38 +00:00
if ( G . vd - > persp = = 2 ) {
if ( G . scene - > world ) {
if ( G . scene - > world - > mode & WO_STARS ) RE_make_stars ( star_stuff_init_func ,
star_stuff_vertex_func ,
star_stuff_term_func ) ;
}
if ( G . vd - > flag & V3D_DISPBGPIC ) draw_bgpic ( ) ;
}
}
else {
2003-10-19 09:19:58 +00:00
drawgrid ( ) ;
2002-10-12 11:37:38 +00:00
if ( G . vd - > flag & V3D_DISPBGPIC ) {
draw_bgpic ( ) ;
}
}
2004-01-02 23:29:34 +00:00
#if 0
/* Lets be a little more selective about when and where we do this,
* or else armatures / poses / displists get recalculated all of the
* time
*/
2004-01-27 06:08:37 +00:00
clear_all_constraints ( ) ;
2004-01-02 23:29:34 +00:00
# endif
2002-10-12 11:37:38 +00:00
2003-04-28 14:43:20 +00:00
/* draw set first */
2002-10-12 11:37:38 +00:00
if ( G . scene - > set ) {
2003-04-28 14:43:20 +00:00
/* patch: color remains constant */
2002-10-12 11:37:38 +00:00
G . f | = G_PICKSEL ;
base = G . scene - > set - > base . first ;
while ( base ) {
if ( G . vd - > lay & base - > lay ) {
where_is_object ( base - > object ) ;
cpack ( 0x404040 ) ;
draw_object ( base ) ;
if ( base - > object - > transflag & OB_DUPLI ) {
extern ListBase duplilist ;
Base tbase ;
tbase = * base ;
tbase . flag = OB_FROMDUPLI ;
make_duplilist ( G . scene - > set , base - > object ) ;
ob = duplilist . first ;
while ( ob ) {
tbase . object = ob ;
draw_object ( & tbase ) ;
ob = ob - > id . next ;
}
free_duplilist ( ) ;
}
}
base = base - > next ;
}
G . f & = ~ G_PICKSEL ;
}
2004-04-08 12:00:58 +00:00
/* first calculate positions, we do this in separate loop to make sure displists
( mball , deform , etc ) are recaluclated based on correct object ( parent / children ) positions
*/
base = G . scene - > base . first ;
while ( base ) {
if ( G . vd - > lay & base - > lay ) where_is_object ( base - > object ) ;
base = base - > next ;
}
/* then draw not selected and the duplis */
2002-10-12 11:37:38 +00:00
base = G . scene - > base . first ;
while ( base ) {
if ( G . vd - > lay & base - > lay ) {
2003-04-28 14:43:20 +00:00
/* dupli drawing temporal off here */
2002-10-12 11:37:38 +00:00
if ( FALSE & & base - > object - > transflag & OB_DUPLI ) {
extern ListBase duplilist ;
Base tbase ;
2003-04-28 14:43:20 +00:00
/* draw original always first because of make_displist */
2002-10-12 11:37:38 +00:00
draw_object ( base ) ;
2003-04-28 14:43:20 +00:00
/* patch: color remains constant */
2002-10-12 11:37:38 +00:00
G . f | = G_PICKSEL ;
cpack ( 0x404040 ) ;
tbase . flag = OB_FROMDUPLI ;
make_duplilist ( G . scene , base - > object ) ;
ob = duplilist . first ;
while ( ob ) {
tbase . object = ob ;
draw_object ( & tbase ) ;
ob = ob - > id . next ;
}
free_duplilist ( ) ;
G . f & = ~ G_PICKSEL ;
}
else if ( ( base - > flag & SELECT ) = = 0 ) {
draw_object ( base ) ;
}
}
base = base - > next ;
}
2003-04-28 14:43:20 +00:00
/* draw selected */
2002-10-12 11:37:38 +00:00
base = G . scene - > base . first ;
while ( base ) {
if ( ( ( base ) - > flag & SELECT ) & & ( ( base ) - > lay & G . vd - > lay ) ) {
draw_object ( base ) ;
}
base = base - > next ;
}
2003-10-23 16:15:05 +00:00
if ( G . moving ) constline_callback ( ) ;
2003-04-28 14:43:20 +00:00
/* duplis, draw as last to make sure the displists are ok */
2002-10-12 11:37:38 +00:00
base = G . scene - > base . first ;
while ( base ) {
if ( G . vd - > lay & base - > lay ) {
if ( base - > object - > transflag & OB_DUPLI ) {
extern ListBase duplilist ;
Base tbase ;
2003-04-28 14:43:20 +00:00
/* patch: color remains constant */
2002-10-12 11:37:38 +00:00
G . f | = G_PICKSEL ;
cpack ( 0x404040 ) ;
tbase . flag = OB_FROMDUPLI ;
make_duplilist ( G . scene , base - > object ) ;
ob = duplilist . first ;
while ( ob ) {
tbase . object = ob ;
draw_object ( & tbase ) ;
ob = ob - > id . next ;
}
free_duplilist ( ) ;
G . f & = ~ G_PICKSEL ;
}
}
base = base - > next ;
}
if ( G . scene - > radio ) RAD_drawall ( G . vd - > drawtype > = OB_SOLID ) ;
2003-10-04 20:35:50 +00:00
if ( G . zbuf ) {
G . zbuf = FALSE ;
glDisable ( GL_DEPTH_TEST ) ;
}
2003-10-16 09:39:19 +00:00
persp ( PERSP_WIN ) ; // set ortho
2002-10-12 11:37:38 +00:00
if ( G . vd - > persp > 1 ) drawviewborder ( ) ;
drawcursor ( ) ;
draw_view_icon ( ) ;
2003-04-28 11:17:21 +00:00
ob = OBACT ;
2004-01-13 14:50:45 +00:00
if ( ob ! = 0 & & ( U . uiflag & USER_DRAWVIEWINFO ) ) draw_selected_name ( ob - > id . name + 2 ) ;
2002-10-12 11:37:38 +00:00
2003-10-04 20:35:50 +00:00
draw_area_emboss ( sa ) ;
2003-10-15 12:26:26 +00:00
/* it is important to end a view in a transform compatible with buttons */
bwin_scalematrix ( sa - > win , G . vd - > blockscale , G . vd - > blockscale , G . vd - > blockscale ) ;
view3d_blockhandlers ( sa ) ;
2002-10-12 11:37:38 +00:00
curarea - > win_swap = WIN_BACK_OK ;
if ( G . f & ( G_VERTEXPAINT | G_FACESELECT | G_TEXTUREPAINT | G_WEIGHTPAINT ) ) {
G . vd - > flag | = V3D_NEEDBACKBUFDRAW ;
addafterqueue ( curarea - > win , BACKBUFDRAW , 1 ) ;
}
- Blender: added option 'scriptsdir' to Blender.Get();
- small updates to the docs;
- Object: small fix to getMatrix: check during_script() to avoid undesired loops; added old behavior (pre 2.34) as option: .getMatrix('oldlocal');
- tentative fix for bug #1275: scene REDRAW scriptlinks were not being executed (the call to do so was missing):
http://projects.blender.org/tracker/index.php?func=detail&aid=1275&group_id=9&atid=125
added the call in drawview.c, in drawview3dspace(). This causes the scriptlink to be called for each visible view3d, but that's what happens with object redraw scriptlinks, too. Anyway, this is still a test. The place was chosen based on the idea that a scene redraw scriptlink is like an object redraw one, but for all objs in the scene at once.
- Window.Theme: new submodule, to get/set theme options in Blender;
- Added the script save_theme.py (Help menu for now), to save the current theme in Blender as an executable script (currently shown in the Scripts->Misc menu).
There's more work to do for themes, like defining a proper place for them in the interface, adding documentation (for now the added script and the ones it generates can give a pretty good idea of how to use the new module), probably extending themes to support SpaceScript and so on.
2004-09-21 05:28:17 +00:00
/* scene redraw script link */
if ( G . scene - > scriptlink . totscript & & ! during_script ( ) ) {
BPY_do_pyscript ( ( ID * ) G . scene , SCRIPT_REDRAW ) ;
}
2002-10-12 11:37:38 +00:00
}
/* Called back by rendering system, icky
*/
void drawview3d_render ( struct View3D * v3d )
{
2003-03-24 01:46:05 +00:00
extern void mywindow_build_and_set_renderwin ( void ) ;
2002-10-12 11:37:38 +00:00
extern short v3d_windowmode ;
Base * base ;
Object * ob ;
free_all_realtime_images ( ) ;
mywindow_build_and_set_renderwin ( ) ;
2003-07-05 20:38:31 +00:00
2002-10-12 11:37:38 +00:00
v3d_windowmode = 1 ;
setwinmatrixview3d ( 0 ) ;
v3d_windowmode = 0 ;
glMatrixMode ( GL_PROJECTION ) ;
glLoadMatrixf ( R . winmat ) ;
glMatrixMode ( GL_MODELVIEW ) ;
setviewmatrixview3d ( ) ;
glLoadMatrixf ( v3d - > viewmat ) ;
Mat4MulMat4 ( v3d - > persmat , v3d - > viewmat , R . winmat ) ;
Mat4Invert ( v3d - > persinv , v3d - > persmat ) ;
Mat4Invert ( v3d - > viewinv , v3d - > viewmat ) ;
if ( v3d - > drawtype > OB_WIRE ) {
G . zbuf = TRUE ;
glEnable ( GL_DEPTH_TEST ) ;
}
if ( v3d - > drawtype = = OB_TEXTURE & & G . scene - > world ) {
glClearColor ( G . scene - > world - > horr , G . scene - > world - > horg , G . scene - > world - > horb , 0.0 ) ;
} else {
2003-11-08 23:18:32 +00:00
float col [ 3 ] ;
BIF_GetThemeColor3fv ( TH_BACK , col ) ;
glClearColor ( col [ 0 ] , col [ 1 ] , col [ 2 ] , 0.0 ) ;
2002-10-12 11:37:38 +00:00
}
glClear ( GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT ) ;
glLoadIdentity ( ) ;
glLoadMatrixf ( v3d - > viewmat ) ;
/* abuse! to make sure it doesnt draw the helpstuff */
G . f | = G_SIMULATION ;
2004-01-27 06:08:37 +00:00
clear_all_constraints ( ) ;
2002-10-12 11:37:38 +00:00
do_all_ipos ( ) ;
BPY_do_all_scripts ( SCRIPT_FRAMECHANGED ) ;
do_all_keys ( ) ;
do_all_actions ( ) ;
do_all_ikas ( ) ;
test_all_displists ( ) ;
2003-04-28 14:43:20 +00:00
/* not really nice forcing of calc_ipo and where_is */
2002-10-12 11:37:38 +00:00
ob = G . main - > object . first ;
while ( ob ) {
ob - > ctime = - 123.456 ;
ob = ob - > id . next ;
}
2003-04-28 14:43:20 +00:00
/* first deaw set */
2002-10-12 11:37:38 +00:00
if ( G . scene - > set ) {
2003-04-28 14:43:20 +00:00
/* patch: color remains constant */
2002-10-12 11:37:38 +00:00
G . f | = G_PICKSEL ;
base = G . scene - > set - > base . first ;
while ( base ) {
if ( v3d - > lay & base - > lay ) {
if ELEM3 ( base - > object - > type , OB_LAMP , OB_CAMERA , OB_LATTICE ) ;
else {
where_is_object ( base - > object ) ;
cpack ( 0x404040 ) ;
draw_object ( base ) ;
if ( base - > object - > transflag & OB_DUPLI ) {
extern ListBase duplilist ;
Base tbase ;
tbase . flag = OB_FROMDUPLI ;
make_duplilist ( G . scene - > set , base - > object ) ;
ob = duplilist . first ;
while ( ob ) {
tbase . object = ob ;
draw_object ( & tbase ) ;
ob = ob - > id . next ;
}
free_duplilist ( ) ;
}
}
}
base = base - > next ;
}
G . f & = ~ G_PICKSEL ;
}
2004-01-27 06:08:37 +00:00
clear_all_constraints ( ) ;
2003-04-28 14:43:20 +00:00
/* first not selected and duplis */
2002-10-12 11:37:38 +00:00
base = G . scene - > base . first ;
while ( base ) {
if ( v3d - > lay & base - > lay ) {
if ELEM3 ( base - > object - > type , OB_LAMP , OB_CAMERA , OB_LATTICE ) ;
else {
where_is_object ( base - > object ) ;
if ( base - > object - > transflag & OB_DUPLI ) {
extern ListBase duplilist ;
Base tbase ;
2003-04-28 14:43:20 +00:00
/* always draw original first because of make_displist */
2002-10-12 11:37:38 +00:00
draw_object ( base ) ;
2003-04-28 14:43:20 +00:00
/* patch: color remains constant */
2002-10-12 11:37:38 +00:00
G . f | = G_PICKSEL ;
cpack ( 0x404040 ) ;
tbase . flag = OB_FROMDUPLI ;
make_duplilist ( G . scene , base - > object ) ;
ob = duplilist . first ;
while ( ob ) {
tbase . object = ob ;
draw_object ( & tbase ) ;
ob = ob - > id . next ;
}
free_duplilist ( ) ;
G . f & = ~ G_PICKSEL ;
}
else if ( ( base - > flag & SELECT ) = = 0 ) {
draw_object ( base ) ;
}
}
}
base = base - > next ;
}
2003-04-28 14:43:20 +00:00
/* draw selected */
2002-10-12 11:37:38 +00:00
base = G . scene - > base . first ;
while ( base ) {
if ( ( ( base ) - > flag & SELECT ) & & ( ( base ) - > lay & v3d - > lay ) ) {
if ELEM3 ( base - > object - > type , OB_LAMP , OB_CAMERA , OB_LATTICE ) ;
else draw_object ( base ) ;
}
base = base - > next ;
}
if ( G . scene - > radio ) RAD_drawall ( G . vd - > drawtype > = OB_SOLID ) ;
if ( G . zbuf ) {
G . zbuf = FALSE ;
glDisable ( GL_DEPTH_TEST ) ;
}
G . f & = ~ G_SIMULATION ;
2004-06-16 11:34:45 +00:00
glFlush ( ) ;
2002-10-12 11:37:38 +00:00
glReadPixels ( 0 , 0 , R . rectx , R . recty , GL_RGBA , GL_UNSIGNED_BYTE , R . rectot ) ;
glLoadIdentity ( ) ;
free_all_realtime_images ( ) ;
}
double tottime = 0.0 ;
int update_time ( void )
{
static double ltime ;
double time ;
Commit message and the brunt of the code courtesy of intrr, apologies for the
size of this;
Finally, the Sequencer audio support and global audio/animation sync stuff!
(See http://intrr.org/blender/audiosequencer.html)
Stuff that has been done:
./source/blender/blenloader/intern/writefile.c
./source/blender/blenloader/intern/readfile.c
Added code to make it handle sounds used by audio strips, and to convert
Scene data from older (<2.28) versions to init Scene global audio settings
(Scene->audio) to defaults.
./source/blender/include/BSE_seqaudio.h
./source/blender/src/seqaudio.c
The main audio routines that start/stop/scrub the audio stream at
a certain frame position, provide the frame reference for the current
stream position, mix the audio, convert the audio, mixdown the audio
into a file.
./source/blender/makesdna/DNA_sound_types.h
Introduced new variables in the bSound struct to accomodate the sample
data after converted to the scene's global mixing format (stream, streamlen).
Also added a new flag SOUND_FLAGS_SEQUENCE that gets set if the Sound
belongs to a sequence strip.
./source/blender/makesdna/DNA_scene_types.h
Added AudioData struct, which holds scene-global audio settings.
./source/blender/makesdna/DNA_sequence_types.h
Added support for audio strips. Some variables to hold Panning/Attenuation
information, position information, reference to the sample, and some flags.
./source/blender/makesdna/DNA_userdef_types.h
./source/blender/src/usiblender.c
Added a "Mixing buffer size" userpref. Made the versions stuff initialize
it to a default for versions <2.28.
./source/blender/makesdna/DNA_space_types.h
./source/blender/src/filesel.c
Added a Cyan dot to .WAV files. Any other suggestions on a better color? :)
./source/blender/src/editsound.c
Changes (fixes) to the WAV file loader, re-enabled some gameengine code that
is needed for dealing with bSounds and bSamples.
./source/blender/src/editipo.c
./source/blender/src/drawseq.c
./source/blender/src/editnla.c
./source/blender/src/space.c
./source/blender/src/drawview.c
./source/blender/src/renderwin.c
./source/blender/src/headerbuttons.c
- Created two different wrappers for update_for_newframe(), one which scrubs
the audio, one which doesn't.
- Replaced some of the occurences of update_for_newframe() with
update_for_newframe_muted(), which doesn't scrub the audio.
- In drawview.c: Changed the synchronization scheme to get the current audio
position from the audio engine, and use that as a reference for setting
CFRA. Implements a/v sync and framedrop.
- In editipo.c: Changed handling of Fac IPOs to be usable for audio strips as
volume envelopes.
- In space.c: Added the mixing buffer size Userpref, enabled audio scrubbing
(update_for_newframe()) for moving the sequence editor framebar.
./source/blender/src/editseq.c
Added support for audio strips and a default directory for WAV files which
gets saved from the last Shift-A operation.
./source/blender/src/buttons.c
Added Scene-global audio sequencer settings in Sound buttons.
./source/blender/src/sequence.c
Various stuff that deals with handling audio strips differently than
usual strips.
2003-07-13 20:16:56 +00:00
if ( ( U . mixbufsize ) & & ( audiostream_pos ( ) ! = CFRA ) & & ( G . scene - > audio . flag & AUDIO_SYNC ) ) return 0 ;
2002-10-12 11:37:38 +00:00
time = PIL_check_seconds_timer ( ) ;
tottime + = ( time - ltime ) ;
ltime = time ;
return ( tottime < 0.0 ) ;
}
double speed_to_swaptime ( int speed )
{
switch ( speed ) {
case 1 :
return 1.0 / 60.0 ;
case 2 :
return 1.0 / 50.0 ;
case 3 :
return 1.0 / 30.0 ;
case 4 :
return 1.0 / 25.0 ;
case 5 :
return 1.0 / 20.0 ;
case 6 :
return 1.0 / 15.0 ;
case 7 :
return 1.0 / 12.5 ;
case 8 :
return 1.0 / 10.0 ;
case 9 :
return 1.0 / 6.0 ;
}
return 1.0 / 4.0 ;
}
double key_to_swaptime ( int key )
{
switch ( key ) {
case PAD1 :
G . animspeed = 1 ;
tottime = 0 ;
return speed_to_swaptime ( 1 ) ;
case PAD2 :
G . animspeed = 2 ;
tottime = 0 ;
return speed_to_swaptime ( 2 ) ;
case PAD3 :
G . animspeed = 3 ;
tottime = 0 ;
return speed_to_swaptime ( 3 ) ;
case PAD4 :
G . animspeed = 4 ;
tottime = 0 ;
return speed_to_swaptime ( 4 ) ;
case PAD5 :
G . animspeed = 5 ;
tottime = 0 ;
return speed_to_swaptime ( 5 ) ;
case PAD6 :
G . animspeed = 6 ;
tottime = 0 ;
return speed_to_swaptime ( 6 ) ;
case PAD7 :
G . animspeed = 7 ;
tottime = 0 ;
return speed_to_swaptime ( 7 ) ;
case PAD8 :
G . animspeed = 8 ;
tottime = 0 ;
return speed_to_swaptime ( 8 ) ;
case PAD9 :
G . animspeed = 9 ;
tottime = 0 ;
return speed_to_swaptime ( 9 ) ;
}
return speed_to_swaptime ( G . animspeed ) ;
}
# ifdef NAN_LINEAR_PHYSICS
void sumo_callback ( void * obp )
{
Object * ob = obp ;
SM_Vector3 vec ;
float matf [ 3 ] [ 3 ] ;
int i , j ;
SM_GetMatrixf ( ob - > sumohandle , ob - > obmat [ 0 ] ) ;
VECCOPY ( ob - > loc , ob - > obmat [ 3 ] ) ;
for ( i = 0 ; i < 3 ; + + i ) {
for ( j = 0 ; j < 3 ; + + j ) {
matf [ i ] [ j ] = ob - > obmat [ i ] [ j ] ;
}
}
Mat3ToEul ( matf , ob - > rot ) ;
}
2003-04-28 14:43:20 +00:00
/* for test and fun, i've written the next functions to play with dynamics
using a variant of play - anim . . . was never released nor really tested ( ton ) */
2002-10-12 11:37:38 +00:00
void init_anim_sumo ( void )
{
extern Material defmaterial ;
Base * base ;
Mesh * me ;
Object * ob ;
Material * mat ;
MFace * mface ;
MVert * mvert ;
float centre [ 3 ] , size [ 3 ] ;
int a ;
SM_ShapeHandle shape ;
SM_SceneHandle scene ;
SM_Material material ;
SM_MassProps massprops ;
SM_Vector3 vec ;
SM_Vector3 scaling ;
scene = SM_CreateScene ( ) ;
G . scene - > sumohandle = scene ;
vec [ 0 ] = 0.0 ;
vec [ 1 ] = 0.0 ;
vec [ 2 ] = - 9.8 ;
SM_SetForceField ( scene , vec ) ;
/* ton: cylinders & cones are still Y-axis up, will be Z-axis later */
/* ton: write location/rotation save and restore */
base = FIRSTBASE ;
while ( base ) {
if ( G . vd - > lay & base - > lay ) {
ob = base - > object ;
/* define shape, for now only meshes take part in physics */
get_local_bounds ( ob , centre , size ) ;
if ( ob - > type = = OB_MESH ) {
me = ob - > data ;
if ( ob - > gameflag & OB_DYNAMIC ) {
if ( me - > sumohandle )
shape = me - > sumohandle ;
else {
/* make new handle */
switch ( ob - > boundtype ) {
case OB_BOUND_BOX :
shape = SM_Box ( 2.0 * size [ 0 ] , 2.0 * size [ 1 ] , 2.0 * size [ 2 ] ) ;
break ;
case OB_BOUND_SPHERE :
shape = SM_Sphere ( size [ 0 ] ) ;
break ;
case OB_BOUND_CYLINDER :
shape = SM_Cylinder ( size [ 0 ] , 2.0 * size [ 2 ] ) ;
break ;
case OB_BOUND_CONE :
shape = SM_Cone ( size [ 0 ] , 2.0 * size [ 2 ] ) ;
break ;
}
me - > sumohandle = shape ;
}
/* sumo material properties */
mat = give_current_material ( ob , 0 ) ;
if ( mat = = NULL )
mat = & defmaterial ;
material . restitution = mat - > reflect ;
material . static_friction = mat - > friction ;
material . dynamic_friction = mat - > friction ;
/* sumo mass properties */
massprops . mass = ob - > mass ;
massprops . center [ 0 ] = 0.0 ;
massprops . center [ 1 ] = 0.0 ;
massprops . center [ 2 ] = 0.0 ;
massprops . inertia [ 0 ] = 0.5 * ob - > mass ;
massprops . inertia [ 1 ] = 0.5 * ob - > mass ;
massprops . inertia [ 2 ] = 0.5 * ob - > mass ;
massprops . orientation [ 0 ] = 0.0 ;
massprops . orientation [ 1 ] = 0.0 ;
massprops . orientation [ 2 ] = 0.0 ;
massprops . orientation [ 3 ] = 1.0 ;
ob - > sumohandle = SM_CreateObject ( ob , shape , & material ,
& massprops , sumo_callback ) ;
SM_AddObject ( scene , ob - > sumohandle ) ;
scaling [ 0 ] = ob - > size [ 0 ] ;
scaling [ 1 ] = ob - > size [ 1 ] ;
scaling [ 2 ] = ob - > size [ 2 ] ;
SM_SetMatrixf ( ob - > sumohandle , ob - > obmat [ 0 ] ) ;
SM_SetScaling ( ob - > sumohandle , scaling ) ;
}
else {
if ( me - > sumohandle ) shape = me - > sumohandle ;
else {
/* make new handle */
shape = SM_NewComplexShape ( ) ;
mface = me - > mface ;
mvert = me - > mvert ;
for ( a = 0 ; a < me - > totface ; a + + , mface + + ) {
if ( mface - > v3 ) {
SM_Begin ( ) ;
SM_Vertex ( ( mvert + mface - > v1 ) - > co [ 0 ] , ( mvert + mface - > v1 ) - > co [ 1 ] , ( mvert + mface - > v1 ) - > co [ 2 ] ) ;
SM_Vertex ( ( mvert + mface - > v2 ) - > co [ 0 ] , ( mvert + mface - > v2 ) - > co [ 1 ] , ( mvert + mface - > v2 ) - > co [ 2 ] ) ;
SM_Vertex ( ( mvert + mface - > v3 ) - > co [ 0 ] , ( mvert + mface - > v3 ) - > co [ 1 ] , ( mvert + mface - > v3 ) - > co [ 2 ] ) ;
if ( mface - > v4 )
SM_Vertex ( ( mvert + mface - > v4 ) - > co [ 0 ] , ( mvert + mface - > v4 ) - > co [ 1 ] , ( mvert + mface - > v4 ) - > co [ 2 ] ) ;
SM_End ( ) ;
}
}
SM_EndComplexShape ( ) ;
me - > sumohandle = shape ;
}
/* sumo material properties */
mat = give_current_material ( ob , 0 ) ;
if ( mat = = NULL )
mat = & defmaterial ;
material . restitution = mat - > reflect ;
material . static_friction = mat - > friction ;
material . dynamic_friction = mat - > friction ;
/* sumo mass properties */
massprops . mass = ob - > mass ;
massprops . center [ 0 ] = 0.0 ;
massprops . center [ 1 ] = 0.0 ;
massprops . center [ 2 ] = 0.0 ;
massprops . inertia [ 0 ] = 0.5 * ob - > mass ;
massprops . inertia [ 1 ] = 0.5 * ob - > mass ;
massprops . inertia [ 2 ] = 0.5 * ob - > mass ;
massprops . orientation [ 0 ] = 0.0 ;
massprops . orientation [ 1 ] = 0.0 ;
massprops . orientation [ 2 ] = 0.0 ;
massprops . orientation [ 3 ] = 1.0 ;
ob - > sumohandle = SM_CreateObject ( ob , shape , & material , NULL , NULL ) ;
SM_AddObject ( scene , ob - > sumohandle ) ;
scaling [ 0 ] = ob - > size [ 0 ] ;
scaling [ 1 ] = ob - > size [ 1 ] ;
scaling [ 2 ] = ob - > size [ 2 ] ;
SM_SetMatrixf ( ob - > sumohandle , ob - > obmat [ 0 ] ) ;
SM_SetScaling ( ob - > sumohandle , scaling ) ;
}
}
}
base = base - > next ;
}
}
/* update animated objects */
void update_anim_sumo ( void )
{
SM_Vector3 scaling ;
Base * base ;
Object * ob ;
Mesh * me ;
base = FIRSTBASE ;
while ( base ) {
if ( G . vd - > lay & base - > lay ) {
ob = base - > object ;
if ( ob - > sumohandle ) {
if ( ( ob - > gameflag & OB_DYNAMIC ) = = 0 ) {
2003-04-28 14:43:20 +00:00
/* maybe: optimise, check for anim */
2002-10-12 11:37:38 +00:00
scaling [ 0 ] = ob - > size [ 0 ] ;
scaling [ 1 ] = ob - > size [ 1 ] ;
scaling [ 2 ] = ob - > size [ 2 ] ;
SM_SetMatrixf ( ob - > sumohandle , ob - > obmat [ 0 ] ) ;
SM_SetScaling ( ob - > sumohandle , scaling ) ;
}
}
}
base = base - > next ;
}
}
void end_anim_sumo ( void )
{
Base * base ;
Object * ob ;
Mesh * me ;
base = FIRSTBASE ;
while ( base ) {
if ( G . vd - > lay & base - > lay ) {
ob = base - > object ;
if ( ob - > type = = OB_MESH ) {
if ( ob - > sumohandle ) {
SM_RemoveObject ( G . scene - > sumohandle , ob - > sumohandle ) ;
SM_DeleteObject ( ob - > sumohandle ) ;
ob - > sumohandle = NULL ;
}
me = ob - > data ;
if ( me - > sumohandle ) {
SM_DeleteShape ( me - > sumohandle ) ;
me - > sumohandle = NULL ;
}
}
}
base = base - > next ;
}
if ( G . scene - > sumohandle ) {
SM_DeleteScene ( G . scene - > sumohandle ) ;
G . scene - > sumohandle = NULL ;
}
}
# endif
void inner_play_anim_loop ( int init , int mode )
{
ScrArea * sa ;
static ScrArea * oldsa ;
static double swaptime ;
static int curmode ;
2004-01-02 23:29:34 +00:00
2002-10-12 11:37:38 +00:00
/* init */
if ( init ) {
oldsa = curarea ;
swaptime = speed_to_swaptime ( G . animspeed ) ;
tottime = 0.0 ;
curmode = mode ;
# ifdef NAN_LINEAR_PHYSICS
init_anim_sumo ( ) ;
# endif
return ;
}
set_timecursor ( CFRA ) ;
2004-01-02 23:29:34 +00:00
2004-01-27 06:08:37 +00:00
clear_all_constraints ( ) ;
2002-10-12 11:37:38 +00:00
do_all_ipos ( ) ;
BPY_do_all_scripts ( SCRIPT_FRAMECHANGED ) ;
do_all_keys ( ) ;
do_all_actions ( ) ;
do_all_ikas ( ) ;
test_all_displists ( ) ;
# ifdef NAN_LINEAR_PHYSICS
update_anim_sumo ( ) ;
SM_Proceed ( G . scene - > sumohandle , swaptime , 40 , NULL ) ;
# endif
sa = G . curscreen - > areabase . first ;
while ( sa ) {
if ( sa = = oldsa ) {
scrarea_do_windraw ( sa ) ;
}
New scripts:
- hotkeys, obdatacopier and renameobjectbyblock, all from Jean-Michel Soler (jms);
- bevel_center by Loic Berthe, suggested for inclusion by jms;
- doc_browser, by Daniel Dunbar (Zr)
Thanks to them for the new contributions!
(I included doc_browser at 'Misc' because only users interested in script writing would actually use it, but it could also be under 'Help'. Opinions?)
BPython related:
- Added scriptlink methods to object, lamp, camera and world.
- Object: added object.makeTrack and object.clearTrack (old track method).
- sys: made sys.exists(path) return 0 for not found; 1 for file, 2 for dir and -1 for neither.
- doc updates and fixes.
- made ONLOAD event work. G.f's SCENESCRIPT bit was being zeroed in set_app_data.
- Blender: updated functions Load and Save to support the builtin importers and exporters besides .blend (dxf, videoscape, vrml 1.0, stl, ...)
- Draw: added mouse wheel events.
- Scene: added scene.play to play back animations (like ALT+A and SHIFT+ALT+A). Makes a good counter, too, when the 'win' attribute is set to a space that doesn't "animate".
The scene.play() addition and the fix to ONLOAD scriptlinks is part of the work for a Blender demo mode. It already works, but I'll still add support for Radiosity calculations and fix a thing in main(): it executes onload scripts too early (BIF_Init), giving funny results in alt+a animations and renderings when firing up Blender. Loading after the program is up has no such problems. When I finish I'll post examples of demo mode scripts.
2004-07-03 05:17:04 +00:00
else if ( curmode & 1 ) { /* catch modes 1 and 3 */
2002-10-12 11:37:38 +00:00
if ELEM ( sa - > spacetype , SPACE_VIEW3D , SPACE_SEQ ) {
scrarea_do_windraw ( sa ) ;
}
}
sa = sa - > next ;
}
2003-04-28 14:43:20 +00:00
/* make sure that swaptime passed by */
2002-10-12 11:37:38 +00:00
tottime - = swaptime ;
while ( update_time ( ) ) PIL_sleep_ms ( 1 ) ;
Commit message and the brunt of the code courtesy of intrr, apologies for the
size of this;
Finally, the Sequencer audio support and global audio/animation sync stuff!
(See http://intrr.org/blender/audiosequencer.html)
Stuff that has been done:
./source/blender/blenloader/intern/writefile.c
./source/blender/blenloader/intern/readfile.c
Added code to make it handle sounds used by audio strips, and to convert
Scene data from older (<2.28) versions to init Scene global audio settings
(Scene->audio) to defaults.
./source/blender/include/BSE_seqaudio.h
./source/blender/src/seqaudio.c
The main audio routines that start/stop/scrub the audio stream at
a certain frame position, provide the frame reference for the current
stream position, mix the audio, convert the audio, mixdown the audio
into a file.
./source/blender/makesdna/DNA_sound_types.h
Introduced new variables in the bSound struct to accomodate the sample
data after converted to the scene's global mixing format (stream, streamlen).
Also added a new flag SOUND_FLAGS_SEQUENCE that gets set if the Sound
belongs to a sequence strip.
./source/blender/makesdna/DNA_scene_types.h
Added AudioData struct, which holds scene-global audio settings.
./source/blender/makesdna/DNA_sequence_types.h
Added support for audio strips. Some variables to hold Panning/Attenuation
information, position information, reference to the sample, and some flags.
./source/blender/makesdna/DNA_userdef_types.h
./source/blender/src/usiblender.c
Added a "Mixing buffer size" userpref. Made the versions stuff initialize
it to a default for versions <2.28.
./source/blender/makesdna/DNA_space_types.h
./source/blender/src/filesel.c
Added a Cyan dot to .WAV files. Any other suggestions on a better color? :)
./source/blender/src/editsound.c
Changes (fixes) to the WAV file loader, re-enabled some gameengine code that
is needed for dealing with bSounds and bSamples.
./source/blender/src/editipo.c
./source/blender/src/drawseq.c
./source/blender/src/editnla.c
./source/blender/src/space.c
./source/blender/src/drawview.c
./source/blender/src/renderwin.c
./source/blender/src/headerbuttons.c
- Created two different wrappers for update_for_newframe(), one which scrubs
the audio, one which doesn't.
- Replaced some of the occurences of update_for_newframe() with
update_for_newframe_muted(), which doesn't scrub the audio.
- In drawview.c: Changed the synchronization scheme to get the current audio
position from the audio engine, and use that as a reference for setting
CFRA. Implements a/v sync and framedrop.
- In editipo.c: Changed handling of Fac IPOs to be usable for audio strips as
volume envelopes.
- In space.c: Added the mixing buffer size Userpref, enabled audio scrubbing
(update_for_newframe()) for moving the sequence editor framebar.
./source/blender/src/editseq.c
Added support for audio strips and a default directory for WAV files which
gets saved from the last Shift-A operation.
./source/blender/src/buttons.c
Added Scene-global audio sequencer settings in Sound buttons.
./source/blender/src/sequence.c
Various stuff that deals with handling audio strips differently than
usual strips.
2003-07-13 20:16:56 +00:00
if ( CFRA > = EFRA ) {
2002-10-12 11:37:38 +00:00
if ( tottime > 0.0 ) tottime = 0.0 ;
CFRA = SFRA ;
Commit message and the brunt of the code courtesy of intrr, apologies for the
size of this;
Finally, the Sequencer audio support and global audio/animation sync stuff!
(See http://intrr.org/blender/audiosequencer.html)
Stuff that has been done:
./source/blender/blenloader/intern/writefile.c
./source/blender/blenloader/intern/readfile.c
Added code to make it handle sounds used by audio strips, and to convert
Scene data from older (<2.28) versions to init Scene global audio settings
(Scene->audio) to defaults.
./source/blender/include/BSE_seqaudio.h
./source/blender/src/seqaudio.c
The main audio routines that start/stop/scrub the audio stream at
a certain frame position, provide the frame reference for the current
stream position, mix the audio, convert the audio, mixdown the audio
into a file.
./source/blender/makesdna/DNA_sound_types.h
Introduced new variables in the bSound struct to accomodate the sample
data after converted to the scene's global mixing format (stream, streamlen).
Also added a new flag SOUND_FLAGS_SEQUENCE that gets set if the Sound
belongs to a sequence strip.
./source/blender/makesdna/DNA_scene_types.h
Added AudioData struct, which holds scene-global audio settings.
./source/blender/makesdna/DNA_sequence_types.h
Added support for audio strips. Some variables to hold Panning/Attenuation
information, position information, reference to the sample, and some flags.
./source/blender/makesdna/DNA_userdef_types.h
./source/blender/src/usiblender.c
Added a "Mixing buffer size" userpref. Made the versions stuff initialize
it to a default for versions <2.28.
./source/blender/makesdna/DNA_space_types.h
./source/blender/src/filesel.c
Added a Cyan dot to .WAV files. Any other suggestions on a better color? :)
./source/blender/src/editsound.c
Changes (fixes) to the WAV file loader, re-enabled some gameengine code that
is needed for dealing with bSounds and bSamples.
./source/blender/src/editipo.c
./source/blender/src/drawseq.c
./source/blender/src/editnla.c
./source/blender/src/space.c
./source/blender/src/drawview.c
./source/blender/src/renderwin.c
./source/blender/src/headerbuttons.c
- Created two different wrappers for update_for_newframe(), one which scrubs
the audio, one which doesn't.
- Replaced some of the occurences of update_for_newframe() with
update_for_newframe_muted(), which doesn't scrub the audio.
- In drawview.c: Changed the synchronization scheme to get the current audio
position from the audio engine, and use that as a reference for setting
CFRA. Implements a/v sync and framedrop.
- In editipo.c: Changed handling of Fac IPOs to be usable for audio strips as
volume envelopes.
- In space.c: Added the mixing buffer size Userpref, enabled audio scrubbing
(update_for_newframe()) for moving the sequence editor framebar.
./source/blender/src/editseq.c
Added support for audio strips and a default directory for WAV files which
gets saved from the last Shift-A operation.
./source/blender/src/buttons.c
Added Scene-global audio sequencer settings in Sound buttons.
./source/blender/src/sequence.c
Various stuff that deals with handling audio strips differently than
usual strips.
2003-07-13 20:16:56 +00:00
audiostream_stop ( ) ;
audiostream_start ( CFRA ) ;
2002-10-12 11:37:38 +00:00
}
2003-11-06 14:13:49 +00:00
else {
Commit message and the brunt of the code courtesy of intrr, apologies for the
size of this;
Finally, the Sequencer audio support and global audio/animation sync stuff!
(See http://intrr.org/blender/audiosequencer.html)
Stuff that has been done:
./source/blender/blenloader/intern/writefile.c
./source/blender/blenloader/intern/readfile.c
Added code to make it handle sounds used by audio strips, and to convert
Scene data from older (<2.28) versions to init Scene global audio settings
(Scene->audio) to defaults.
./source/blender/include/BSE_seqaudio.h
./source/blender/src/seqaudio.c
The main audio routines that start/stop/scrub the audio stream at
a certain frame position, provide the frame reference for the current
stream position, mix the audio, convert the audio, mixdown the audio
into a file.
./source/blender/makesdna/DNA_sound_types.h
Introduced new variables in the bSound struct to accomodate the sample
data after converted to the scene's global mixing format (stream, streamlen).
Also added a new flag SOUND_FLAGS_SEQUENCE that gets set if the Sound
belongs to a sequence strip.
./source/blender/makesdna/DNA_scene_types.h
Added AudioData struct, which holds scene-global audio settings.
./source/blender/makesdna/DNA_sequence_types.h
Added support for audio strips. Some variables to hold Panning/Attenuation
information, position information, reference to the sample, and some flags.
./source/blender/makesdna/DNA_userdef_types.h
./source/blender/src/usiblender.c
Added a "Mixing buffer size" userpref. Made the versions stuff initialize
it to a default for versions <2.28.
./source/blender/makesdna/DNA_space_types.h
./source/blender/src/filesel.c
Added a Cyan dot to .WAV files. Any other suggestions on a better color? :)
./source/blender/src/editsound.c
Changes (fixes) to the WAV file loader, re-enabled some gameengine code that
is needed for dealing with bSounds and bSamples.
./source/blender/src/editipo.c
./source/blender/src/drawseq.c
./source/blender/src/editnla.c
./source/blender/src/space.c
./source/blender/src/drawview.c
./source/blender/src/renderwin.c
./source/blender/src/headerbuttons.c
- Created two different wrappers for update_for_newframe(), one which scrubs
the audio, one which doesn't.
- Replaced some of the occurences of update_for_newframe() with
update_for_newframe_muted(), which doesn't scrub the audio.
- In drawview.c: Changed the synchronization scheme to get the current audio
position from the audio engine, and use that as a reference for setting
CFRA. Implements a/v sync and framedrop.
- In editipo.c: Changed handling of Fac IPOs to be usable for audio strips as
volume envelopes.
- In space.c: Added the mixing buffer size Userpref, enabled audio scrubbing
(update_for_newframe()) for moving the sequence editor framebar.
./source/blender/src/editseq.c
Added support for audio strips and a default directory for WAV files which
gets saved from the last Shift-A operation.
./source/blender/src/buttons.c
Added Scene-global audio sequencer settings in Sound buttons.
./source/blender/src/sequence.c
Various stuff that deals with handling audio strips differently than
usual strips.
2003-07-13 20:16:56 +00:00
if ( U . mixbufsize & & ( G . scene - > audio . flag & AUDIO_SYNC ) ) CFRA = audiostream_pos ( ) ;
else CFRA + + ;
2003-11-06 14:13:49 +00:00
}
2002-10-12 11:37:38 +00:00
}
New scripts:
- hotkeys, obdatacopier and renameobjectbyblock, all from Jean-Michel Soler (jms);
- bevel_center by Loic Berthe, suggested for inclusion by jms;
- doc_browser, by Daniel Dunbar (Zr)
Thanks to them for the new contributions!
(I included doc_browser at 'Misc' because only users interested in script writing would actually use it, but it could also be under 'Help'. Opinions?)
BPython related:
- Added scriptlink methods to object, lamp, camera and world.
- Object: added object.makeTrack and object.clearTrack (old track method).
- sys: made sys.exists(path) return 0 for not found; 1 for file, 2 for dir and -1 for neither.
- doc updates and fixes.
- made ONLOAD event work. G.f's SCENESCRIPT bit was being zeroed in set_app_data.
- Blender: updated functions Load and Save to support the builtin importers and exporters besides .blend (dxf, videoscape, vrml 1.0, stl, ...)
- Draw: added mouse wheel events.
- Scene: added scene.play to play back animations (like ALT+A and SHIFT+ALT+A). Makes a good counter, too, when the 'win' attribute is set to a space that doesn't "animate".
The scene.play() addition and the fix to ONLOAD scriptlinks is part of the work for a Blender demo mode. It already works, but I'll still add support for Radiosity calculations and fix a thing in main(): it executes onload scripts too early (BIF_Init), giving funny results in alt+a animations and renderings when firing up Blender. Loading after the program is up has no such problems. When I finish I'll post examples of demo mode scripts.
2004-07-03 05:17:04 +00:00
/* play_anim: 'mode' defines where to play and if repeat is on:
* - 0 : current area
* - 1 : all view3d and seq areas
* - 2 : current area , no replay
* - 3 : all view3d and seq areas , no replay */
2002-10-12 11:37:38 +00:00
int play_anim ( int mode )
{
ScrArea * sa , * oldsa ;
int cfraont ;
unsigned short event = 0 ;
short val ;
2004-01-02 23:29:34 +00:00
2003-04-28 14:43:20 +00:00
/* patch for very very old scenes */
2002-10-12 11:37:38 +00:00
if ( SFRA = = 0 ) SFRA = 1 ;
if ( EFRA = = 0 ) EFRA = 250 ;
2004-06-26 18:18:11 +00:00
2002-10-12 11:37:38 +00:00
if ( SFRA > EFRA ) return 0 ;
update_time ( ) ;
/* waitcursor(1); */
2003-04-28 14:43:20 +00:00
G . f | = G_PLAYANIM ; /* in sequence.c and view.c this is handled */
2002-10-12 11:37:38 +00:00
cfraont = CFRA ;
oldsa = curarea ;
Commit message and the brunt of the code courtesy of intrr, apologies for the
size of this;
Finally, the Sequencer audio support and global audio/animation sync stuff!
(See http://intrr.org/blender/audiosequencer.html)
Stuff that has been done:
./source/blender/blenloader/intern/writefile.c
./source/blender/blenloader/intern/readfile.c
Added code to make it handle sounds used by audio strips, and to convert
Scene data from older (<2.28) versions to init Scene global audio settings
(Scene->audio) to defaults.
./source/blender/include/BSE_seqaudio.h
./source/blender/src/seqaudio.c
The main audio routines that start/stop/scrub the audio stream at
a certain frame position, provide the frame reference for the current
stream position, mix the audio, convert the audio, mixdown the audio
into a file.
./source/blender/makesdna/DNA_sound_types.h
Introduced new variables in the bSound struct to accomodate the sample
data after converted to the scene's global mixing format (stream, streamlen).
Also added a new flag SOUND_FLAGS_SEQUENCE that gets set if the Sound
belongs to a sequence strip.
./source/blender/makesdna/DNA_scene_types.h
Added AudioData struct, which holds scene-global audio settings.
./source/blender/makesdna/DNA_sequence_types.h
Added support for audio strips. Some variables to hold Panning/Attenuation
information, position information, reference to the sample, and some flags.
./source/blender/makesdna/DNA_userdef_types.h
./source/blender/src/usiblender.c
Added a "Mixing buffer size" userpref. Made the versions stuff initialize
it to a default for versions <2.28.
./source/blender/makesdna/DNA_space_types.h
./source/blender/src/filesel.c
Added a Cyan dot to .WAV files. Any other suggestions on a better color? :)
./source/blender/src/editsound.c
Changes (fixes) to the WAV file loader, re-enabled some gameengine code that
is needed for dealing with bSounds and bSamples.
./source/blender/src/editipo.c
./source/blender/src/drawseq.c
./source/blender/src/editnla.c
./source/blender/src/space.c
./source/blender/src/drawview.c
./source/blender/src/renderwin.c
./source/blender/src/headerbuttons.c
- Created two different wrappers for update_for_newframe(), one which scrubs
the audio, one which doesn't.
- Replaced some of the occurences of update_for_newframe() with
update_for_newframe_muted(), which doesn't scrub the audio.
- In drawview.c: Changed the synchronization scheme to get the current audio
position from the audio engine, and use that as a reference for setting
CFRA. Implements a/v sync and framedrop.
- In editipo.c: Changed handling of Fac IPOs to be usable for audio strips as
volume envelopes.
- In space.c: Added the mixing buffer size Userpref, enabled audio scrubbing
(update_for_newframe()) for moving the sequence editor framebar.
./source/blender/src/editseq.c
Added support for audio strips and a default directory for WAV files which
gets saved from the last Shift-A operation.
./source/blender/src/buttons.c
Added Scene-global audio sequencer settings in Sound buttons.
./source/blender/src/sequence.c
Various stuff that deals with handling audio strips differently than
usual strips.
2003-07-13 20:16:56 +00:00
audiostream_start ( CFRA ) ;
2002-10-12 11:37:38 +00:00
inner_play_anim_loop ( 1 , mode ) ; /* 1==init */
2004-05-07 11:59:41 +00:00
/* forces all buffers to be OK for current frame (otherwise other windows get redrawn with CFRA+1) */
curarea - > win_swap = WIN_BACK_OK ;
screen_swapbuffers ( ) ;
2002-10-12 11:37:38 +00:00
while ( TRUE ) {
inner_play_anim_loop ( 0 , 0 ) ;
screen_swapbuffers ( ) ;
while ( qtest ( ) ) {
event = extern_qread ( & val ) ;
if ( event = = ESCKEY ) break ;
else if ( event = = MIDDLEMOUSE ) {
2004-01-13 14:50:45 +00:00
if ( U . flag & USER_VIEWMOVE ) {
2002-10-12 11:37:38 +00:00
if ( G . qual & LR_SHIFTKEY ) viewmove ( 0 ) ;
else if ( G . qual & LR_CTRLKEY ) viewmove ( 2 ) ;
else viewmove ( 1 ) ;
}
else {
if ( G . qual & LR_SHIFTKEY ) viewmove ( 1 ) ;
else if ( G . qual & LR_CTRLKEY ) viewmove ( 2 ) ;
else viewmove ( 0 ) ;
}
}
}
if ( event = = ESCKEY | | event = = SPACEKEY ) break ;
New scripts:
- hotkeys, obdatacopier and renameobjectbyblock, all from Jean-Michel Soler (jms);
- bevel_center by Loic Berthe, suggested for inclusion by jms;
- doc_browser, by Daniel Dunbar (Zr)
Thanks to them for the new contributions!
(I included doc_browser at 'Misc' because only users interested in script writing would actually use it, but it could also be under 'Help'. Opinions?)
BPython related:
- Added scriptlink methods to object, lamp, camera and world.
- Object: added object.makeTrack and object.clearTrack (old track method).
- sys: made sys.exists(path) return 0 for not found; 1 for file, 2 for dir and -1 for neither.
- doc updates and fixes.
- made ONLOAD event work. G.f's SCENESCRIPT bit was being zeroed in set_app_data.
- Blender: updated functions Load and Save to support the builtin importers and exporters besides .blend (dxf, videoscape, vrml 1.0, stl, ...)
- Draw: added mouse wheel events.
- Scene: added scene.play to play back animations (like ALT+A and SHIFT+ALT+A). Makes a good counter, too, when the 'win' attribute is set to a space that doesn't "animate".
The scene.play() addition and the fix to ONLOAD scriptlinks is part of the work for a Blender demo mode. It already works, but I'll still add support for Radiosity calculations and fix a thing in main(): it executes onload scripts too early (BIF_Init), giving funny results in alt+a animations and renderings when firing up Blender. Loading after the program is up has no such problems. When I finish I'll post examples of demo mode scripts.
2004-07-03 05:17:04 +00:00
if ( ( mode > 1 ) & & CFRA = = EFRA ) break ; /* no replay */
2002-10-12 11:37:38 +00:00
}
if ( event = = SPACEKEY ) ;
else CFRA = cfraont ;
2004-01-02 23:29:34 +00:00
2004-01-27 06:08:37 +00:00
clear_all_constraints ( ) ;
2002-10-12 11:37:38 +00:00
do_all_ipos ( ) ;
do_all_keys ( ) ;
do_all_actions ( ) ;
do_all_ikas ( ) ;
2004-04-08 12:00:58 +00:00
test_all_displists ( ) ;
Commit message and the brunt of the code courtesy of intrr, apologies for the
size of this;
Finally, the Sequencer audio support and global audio/animation sync stuff!
(See http://intrr.org/blender/audiosequencer.html)
Stuff that has been done:
./source/blender/blenloader/intern/writefile.c
./source/blender/blenloader/intern/readfile.c
Added code to make it handle sounds used by audio strips, and to convert
Scene data from older (<2.28) versions to init Scene global audio settings
(Scene->audio) to defaults.
./source/blender/include/BSE_seqaudio.h
./source/blender/src/seqaudio.c
The main audio routines that start/stop/scrub the audio stream at
a certain frame position, provide the frame reference for the current
stream position, mix the audio, convert the audio, mixdown the audio
into a file.
./source/blender/makesdna/DNA_sound_types.h
Introduced new variables in the bSound struct to accomodate the sample
data after converted to the scene's global mixing format (stream, streamlen).
Also added a new flag SOUND_FLAGS_SEQUENCE that gets set if the Sound
belongs to a sequence strip.
./source/blender/makesdna/DNA_scene_types.h
Added AudioData struct, which holds scene-global audio settings.
./source/blender/makesdna/DNA_sequence_types.h
Added support for audio strips. Some variables to hold Panning/Attenuation
information, position information, reference to the sample, and some flags.
./source/blender/makesdna/DNA_userdef_types.h
./source/blender/src/usiblender.c
Added a "Mixing buffer size" userpref. Made the versions stuff initialize
it to a default for versions <2.28.
./source/blender/makesdna/DNA_space_types.h
./source/blender/src/filesel.c
Added a Cyan dot to .WAV files. Any other suggestions on a better color? :)
./source/blender/src/editsound.c
Changes (fixes) to the WAV file loader, re-enabled some gameengine code that
is needed for dealing with bSounds and bSamples.
./source/blender/src/editipo.c
./source/blender/src/drawseq.c
./source/blender/src/editnla.c
./source/blender/src/space.c
./source/blender/src/drawview.c
./source/blender/src/renderwin.c
./source/blender/src/headerbuttons.c
- Created two different wrappers for update_for_newframe(), one which scrubs
the audio, one which doesn't.
- Replaced some of the occurences of update_for_newframe() with
update_for_newframe_muted(), which doesn't scrub the audio.
- In drawview.c: Changed the synchronization scheme to get the current audio
position from the audio engine, and use that as a reference for setting
CFRA. Implements a/v sync and framedrop.
- In editipo.c: Changed handling of Fac IPOs to be usable for audio strips as
volume envelopes.
- In space.c: Added the mixing buffer size Userpref, enabled audio scrubbing
(update_for_newframe()) for moving the sequence editor framebar.
./source/blender/src/editseq.c
Added support for audio strips and a default directory for WAV files which
gets saved from the last Shift-A operation.
./source/blender/src/buttons.c
Added Scene-global audio sequencer settings in Sound buttons.
./source/blender/src/sequence.c
Various stuff that deals with handling audio strips differently than
usual strips.
2003-07-13 20:16:56 +00:00
audiostream_stop ( ) ;
2002-10-12 11:37:38 +00:00
if ( oldsa ! = curarea ) areawinset ( oldsa - > win ) ;
/* restore all areas */
sa = G . curscreen - > areabase . first ;
while ( sa ) {
if ( ( mode & & sa - > spacetype = = SPACE_VIEW3D ) | | sa = = curarea ) addqueue ( sa - > win , REDRAW , 1 ) ;
sa = sa - > next ;
}
/* speed button */
2003-10-07 18:24:02 +00:00
// allqueue(REDRAWBUTSOBJECT, 0);
2002-10-12 11:37:38 +00:00
/* groups could have changed ipo */
allspace ( REMAKEIPO , 0 ) ;
allqueue ( REDRAWIPO , 0 ) ;
allqueue ( REDRAWNLA , 0 ) ;
allqueue ( REDRAWACTION , 0 ) ;
2003-04-28 14:43:20 +00:00
/* for the time being */
Commit message and the brunt of the code courtesy of intrr, apologies for the
size of this;
Finally, the Sequencer audio support and global audio/animation sync stuff!
(See http://intrr.org/blender/audiosequencer.html)
Stuff that has been done:
./source/blender/blenloader/intern/writefile.c
./source/blender/blenloader/intern/readfile.c
Added code to make it handle sounds used by audio strips, and to convert
Scene data from older (<2.28) versions to init Scene global audio settings
(Scene->audio) to defaults.
./source/blender/include/BSE_seqaudio.h
./source/blender/src/seqaudio.c
The main audio routines that start/stop/scrub the audio stream at
a certain frame position, provide the frame reference for the current
stream position, mix the audio, convert the audio, mixdown the audio
into a file.
./source/blender/makesdna/DNA_sound_types.h
Introduced new variables in the bSound struct to accomodate the sample
data after converted to the scene's global mixing format (stream, streamlen).
Also added a new flag SOUND_FLAGS_SEQUENCE that gets set if the Sound
belongs to a sequence strip.
./source/blender/makesdna/DNA_scene_types.h
Added AudioData struct, which holds scene-global audio settings.
./source/blender/makesdna/DNA_sequence_types.h
Added support for audio strips. Some variables to hold Panning/Attenuation
information, position information, reference to the sample, and some flags.
./source/blender/makesdna/DNA_userdef_types.h
./source/blender/src/usiblender.c
Added a "Mixing buffer size" userpref. Made the versions stuff initialize
it to a default for versions <2.28.
./source/blender/makesdna/DNA_space_types.h
./source/blender/src/filesel.c
Added a Cyan dot to .WAV files. Any other suggestions on a better color? :)
./source/blender/src/editsound.c
Changes (fixes) to the WAV file loader, re-enabled some gameengine code that
is needed for dealing with bSounds and bSamples.
./source/blender/src/editipo.c
./source/blender/src/drawseq.c
./source/blender/src/editnla.c
./source/blender/src/space.c
./source/blender/src/drawview.c
./source/blender/src/renderwin.c
./source/blender/src/headerbuttons.c
- Created two different wrappers for update_for_newframe(), one which scrubs
the audio, one which doesn't.
- Replaced some of the occurences of update_for_newframe() with
update_for_newframe_muted(), which doesn't scrub the audio.
- In drawview.c: Changed the synchronization scheme to get the current audio
position from the audio engine, and use that as a reference for setting
CFRA. Implements a/v sync and framedrop.
- In editipo.c: Changed handling of Fac IPOs to be usable for audio strips as
volume envelopes.
- In space.c: Added the mixing buffer size Userpref, enabled audio scrubbing
(update_for_newframe()) for moving the sequence editor framebar.
./source/blender/src/editseq.c
Added support for audio strips and a default directory for WAV files which
gets saved from the last Shift-A operation.
./source/blender/src/buttons.c
Added Scene-global audio sequencer settings in Sound buttons.
./source/blender/src/sequence.c
Various stuff that deals with handling audio strips differently than
usual strips.
2003-07-13 20:16:56 +00:00
update_for_newframe_muted ( ) ;
2002-10-12 11:37:38 +00:00
# ifdef NAN_LINEAR_PHYSICS
end_anim_sumo ( ) ;
# endif
waitcursor ( 0 ) ;
G . f & = ~ G_PLAYANIM ;
if ( event = = ESCKEY | | event = = SPACEKEY ) return 1 ;
else return 0 ;
}