- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我无法使用 visual studio 2012 甚至代码块编译程序,我遇到了这些错误:
error C2664: 'glutTimerFunc' : impossible to convert parameter 2 of 'GLvoid (__cdecl >*)(void)' into 'void (__cdecl *)(int)'
in both lignes 132, 240, 267
error C2146: syntaxe error : absence of';' before identifier 'qobj' in ligne 274
代码如下:
/*****************************************************************************
File: TD5-avatar-modele.c
Informatique Graphique IG1
Master d'informatique
Christian Jacquemin, Université Paris 11
Copyright (C) 2004 University Paris 11
This file is provided without support, instruction, or implied
warranty of any kind. University Paris 11 makes no guarantee of its
fitness for a particular purpose and is not liable under any
circumstances for any damages or loss whatsoever arising from the use
or inability to use this file or items derived from it.
******************************************************************************/
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#include <GL/glut.h>
#include <tiff/tiffio.h> /* Sam Leffler's libtiff library. */
int writetiff(char *filename, char *description,
int x, int y, int width, int height, int compression);
#define windowWidth 300
#define windowHeight 300
#define RED 0
#define GREEN 0
#define BLUE 0
#define ALPHA 1
#define true 1
#define false 0
#define KEY_ESC 27
#define PI 3.1415926535898
#define position_Ini -60.0
float t = 0.f;
float delta = 10.f;
float k = 0.001f;
float K = 0.002f;
int IdleRunning = true;
int TraceEcran = false;
int RangFichierStockage = 0;
float position = position_Ini;
int Ma_Tete;
int Mon_Tronc;
int Mon_Bras;
int Mon_AvantBras;
int Ma_Cuisse;
int Mon_Mollet;
int Mon_Repere;
enum lateralite{ Gauche = 0, Droit };
float angle_Bras[2];
float angle_AvantBras[2];
float angle_Cuisse[2];
float angle_Mollet[2];
float angle_Bras_Ini[2] = {-30.0, 15.0};
float angle_AvantBras_Ini[2] = {0.0, 15.0};
float angle_Cuisse_Ini[2] = {20.0, -20.0};
float angle_Mollet_Ini[2] = {0.0, -20.0};
float amplitude_Bras;
float amplitude_AvantBras;
float amplitude_Cuisse;
float amplitude_Mollet;
float med_Bras;
float med_AvantBras;
float med_Cuisse;
float med_Mollet;
static GLfloat mat_specular[] = { 1.0 , 1.0 , 1.0 , 1.0 };
static GLfloat mat_ambientanddiffuse[] = { 0.4, 0.4 , 0.0 , 1.0 };
static GLfloat mat_shininess[] = { 20.0};
static GLfloat light_position0[] = { 15.0 , 15.0 , 15.0 , 0.0 };
static GLfloat light_position1[] = { 15.0 , 15.0 , -15.0 , 0.0 };
static GLfloat ambient_light0[] = { 0.0 , 0.0 , 0.0 , 0.0 };
static GLfloat diffuse_light0[] = { 0.7 , 0.7 , 0.7 , 1.0 };
static GLfloat specular_light0[] = { 0.1 , 0.1 , 0.1 , 0.1 };
static GLfloat ambient_light1[] = { 0.50 , 0.50 , 0.50 , 1.0 };
static GLfloat diffuse_light1[] = { 0.5 , 1.0 , 1.0 , 1.0 };
static GLfloat specular_light1[] = { 0.5 , 1.0 , 1.0 , 1.0 };
int Step = 0;
int latence =4;
void init_scene();
void render_scene();
void init_angles();
GLvoid initGL();
GLvoid window_display();
GLvoid window_reshape(GLsizei width, GLsizei height);
GLvoid window_key(unsigned char key, int x, int y);
GLvoid window_timer();
void Faire_Composantes();
void Dessine_Repere();
int main(int argc, char **argv)
{
// initialisation des paramètres de GLUT en fonction
// des arguments sur la ligne de commande
glutInit(&argc, argv);
glutInitDisplayMode(GLUT_RGBA | GLUT_DOUBLE | GLUT_DEPTH);
// définition et création de la fenêtre graphique
glutInitWindowSize(windowWidth,windowHeight);
glutInitWindowPosition(0, 0);
glutCreateWindow("Avatar animé");
// initialisation de OpenGL et de la scène
initGL();
init_scene();
// choix des procédures de callback pour
// le tracé graphique
glutDisplayFunc(&window_display);
// le redimensionnement de la fenêtre
glutReshapeFunc(&window_reshape);
// la gestion des événements clavier
glutKeyboardFunc(&window_key);
// fonction appelée régulièrement entre deux gestions d´événements
glutTimerFunc(latence,&window_timer,Step);
// la boucle prinicipale de gestion des événements utilisateur
glutMainLoop();
return 1;
}
// initialisation du fond de la fenêtre graphique : noir opaque
GLvoid initGL()
{
// initialisation de l´éclairement
// définition de deux source lumineuses
glLightfv(GL_LIGHT0, GL_AMBIENT, ambient_light0);
glLightfv(GL_LIGHT0, GL_DIFFUSE, diffuse_light0);
glLightfv(GL_LIGHT0, GL_SPECULAR, specular_light0);
glLightfv(GL_LIGHT1, GL_AMBIENT, ambient_light1);
glLightfv(GL_LIGHT1, GL_DIFFUSE, diffuse_light1);
glLightfv(GL_LIGHT1, GL_SPECULAR, specular_light1);
glLightfv(GL_LIGHT0, GL_POSITION, light_position0);
glLightfv(GL_LIGHT1, GL_POSITION, light_position1);
// activation de l´éclairement
glEnable(GL_LIGHTING);
glEnable(GL_LIGHT0);
glEnable(GL_LIGHT1);
// propriétés matérielles des objets
// glMaterialfv(GL_FRONT, GL_AMBIENT_AND_DIFFUSE, mat_ambientanddiffuse);
// glMaterialfv(GL_FRONT, GL_SPECULAR, mat_specular);
// glMaterialfv(GL_FRONT, GL_SHININESS, mat_shininess);
glShadeModel( GL_SMOOTH );
glEnable(GL_COLOR_MATERIAL);
// initialisation du fond
glClearColor(RED, GREEN, BLUE, ALPHA);
// z-buffer
glEnable(GL_DEPTH_TEST);
}
void init_scene()
{
// initialise des display lists des composantes cylindriques du corps
Faire_Composantes();
amplitude_Bras
= .5 * (angle_Bras_Ini[ Droit ] - angle_Bras_Ini[ Gauche ]);
amplitude_AvantBras
= .5 * (angle_AvantBras_Ini[ Droit ] - angle_AvantBras_Ini[ Gauche ]);
amplitude_Cuisse
= .5 * (angle_Cuisse_Ini[ Droit ] - angle_Cuisse_Ini[ Gauche ]);
amplitude_Mollet
= .5 * (angle_Mollet_Ini[ Droit ] - angle_Mollet_Ini[ Gauche ]);
med_Bras
= .5 * (angle_Bras_Ini[ Droit ] + angle_Bras_Ini[ Gauche ]);
med_AvantBras
= .5 * (angle_AvantBras_Ini[ Droit ] + angle_AvantBras_Ini[ Gauche ]);
med_Cuisse
= .5 * (angle_Cuisse_Ini[ Droit ] + angle_Cuisse_Ini[ Gauche ]);
med_Mollet
= .5 * (angle_Mollet_Ini[ Droit ] + angle_Mollet_Ini[ Gauche ]);
}
// fonction de call-back pour l´affichage dans la fenêtre
GLvoid window_display()
{
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
glLoadIdentity();
render_scene();
// trace la scène grapnique qui vient juste d'être définie
glFlush();
}
// fonction de call-back pour le redimensionnement de la fenêtre
GLvoid window_reshape(GLsizei width, GLsizei height)
{
glViewport(0, 0, width, height);
glMatrixMode(GL_PROJECTION);
glLoadIdentity();
glOrtho(-20, 20, -20, 20, -1000, 1000);
// glFrustum(-20, 20, -20, 20, 10, 1000);
// glScalef(10, 10, 10);
// toutes les transformations suivantes s´appliquent au modèle de vue
glMatrixMode(GL_MODELVIEW);
}
// fonction de call-back pour la gestion des événements clavier
GLvoid window_key(unsigned char key, int x, int y)
{
switch (key) {
case KEY_ESC:
exit(1);
break;
case ' ':
if (IdleRunning) {
glutTimerFunc(latence,NULL,Step);
IdleRunning = false;
}
else {
glutTimerFunc(latence,&window_timer,Step);
IdleRunning = true;
}
break;
case '+':
delta *= 1.01;
break;
case '-':
delta /= 1.01;
break;
default:
printf ("La touche %d n´est pas active.\n", key);
break;
}
}
// fonction de call-back appelée régulièrement
GLvoid window_timer()
{
// On effecture une variation des angles de chaque membre
// de l'amplitude associée et de la position médiane
// ********* A FAIRE **************
// On déplace la position de l'avatar pour qu'il avance
// ********* A FAIRE **************
glutTimerFunc(latence,&window_timer,++Step);
glutPostRedisplay();
}
// un cylindre
void Faire_Composantes() {
GLUquadricObj* GLAPIENTRY qobj;
// attribution des indentificateurs de display lists
Ma_Tete = glGenLists(6);
Mon_Tronc = Ma_Tete + 1;
Mon_Bras = Ma_Tete + 2;
Mon_AvantBras = Ma_Tete + 3;
Ma_Cuisse = Ma_Tete + 4;
Mon_Mollet = Ma_Tete + 5;
// compilation de la display list de la sphère
// ********* A FAIRE **************
// allocation d´une description de quadrique
qobj = gluNewQuadric();
// la quadrique est pleine
gluQuadricDrawStyle(qobj, GLU_FILL);
// les ombrages, s´il y en a, sont doux
gluQuadricNormals(qobj, GLU_SMOOTH);
// compilation des display lists des cylindres
// ********* A FAIRE **************
}
void Dessine_Repere() {
glNewList(Mon_Repere, GL_COMPILE);
glBegin(GL_LINES);
glColor3f(1.0, 0.0, 0.0);
glVertex3f(-10 , 0 , 0);
glVertex3f(10 , 0 , 0);
glEnd();
glBegin(GL_LINES);
glColor3f(0.0, 1.0, 0.0);
glVertex3f(0 , -10 , 0);
glVertex3f(0 , 10 , 0);
glEnd();
glPointSize( 10.0 );
glBegin(GL_POINTS);
glColor3f(1.0, 1.0, 1.0);
glVertex3f(10.0 , 0 , 0);
glEnd();
glBegin(GL_POINTS);
glColor3f(1.0, 1.0, 1.0);
glVertex3f(0 , 10.0 , 0);
glEnd();
glEndList();
}
void render_scene()
{
// rotation de 90 degres autour de Ox pour mettre l'axe Oz
// vertical comme sur la figure
glRotatef(-90, 1, 0, 0);
// rotation de 160 degres autour de l'axe Oz pour faire
// avancer l'avatar vers le spectateur
glRotatef(-160, 0, 0, 1);
// rotation de 25 degres autour de la bissectrice de $Oy$ pour
// voir la figure en perspective
// glRotatef(25, 0, 1, 0);
// déplacement horizontal selon l´axe Oy pour donner
// une impression de déplacement horizontal accompagnant
// la marche
glTranslatef( 0, position, 0);
// tracé du tronc, aucune transformation n´est
// requise
glColor3f(1.0, 1.0, 1.0);
glCallList(Mon_Tronc);
// tracé de la tête avec une translation positive
// selon Oz pour la placer au-dessus du tronc
// les appels à glPushMatrix et glPopMatrix servent
// à sauvegarder et restaurer le contexte graphique
// ********* A FAIRE **************
// tracé de la cuisse droite avec une translation vers
// la droite et une rotation de 180° autour de Ox
// pour l´orienter vers le bas
// ********* A FAIRE **************
// pour tracer le mollet, on reste dans le même
// contexte graphique et on translate de
// +5 selon Oz afin de mettre le repère au niveau
// du genou
// ********* A FAIRE **************
// cuisse et mollet gauches
// seule la translation initiale change
// ********* A FAIRE **************
// tracé du bras droit avec une translation vers
// la droite et vers le haut composée avec une
// rotation de 180° autour de Ox pour l´orienter
// vers le bas
// ********* A FAIRE **************
// pour tracer l´avant-bras, on reste dans le même
// contexte graphique et on translate de
// +5 selon Oz afin de mettre le repère au niveau
// du coude
// ********* A FAIRE **************
// bras et avant-bras gauches
// seule la translation initiale change
// ********* A FAIRE **************
// permutation des buffers lorsque le tracé est achevé
glutSwapBuffers();
}
最佳答案
这个错误与 glutTimerFunc
的第二个参数想要一个指向签名函数的指针 void funct(int)
而代码传递一个函数有关没有争论。
应该是这样的
GLvoid window_timer(int msec) {
}
glutTimerFunc(latence,&window_timer,Step);
关于c++ - 从 'GLvoid (*)() {aka void (*)()}' 到 'void (__attribute__((__cdecl__)) *)(int)' 的无效转换,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24082436/
我正在尝试将一个字符串逐个字符地复制到另一个字符串中。目的不是复制整个字符串,而是复制其中的一部分(我稍后会为此做一些条件......) 但我不知道如何使用迭代器。 你能帮帮我吗? std::stri
我想将 void 指针转换为结构引用。 结构的最小示例: #include "Interface.h" class Foo { public: Foo() : mAddress((uint
这有点烦人:我有一个 div,它从窗口的左上角开始过渡,即使它位于文档的其他任何位置。我试过 usign -webkit-transform-origin 但没有成功,也许我用错了。有人可以帮助我吗?
假设,如果将 CSS3 转换/转换/动画分配给 DOM 元素,我是否可以检测到该过程的状态? 我想这样做的原因是因为我正在寻找类似过渡链的东西,例如,在前一个过渡之后运行一个过渡。 最佳答案 我在 h
最近我遇到了“不稳定”屏幕,这很可能是由 CSS 转换引起的。事实上,它只发生在 Chrome 浏览器 上(可能还有 Safari,因为一些人也报告了它)。知道如何让它看起来光滑吗?此外,您可能会注意
我正在开发一个简单的 slider ,它使用 CSS 过渡来为幻灯片设置动画。我用一些基本样式和一些 javascript 创建了一支笔 here .注意:由于 Codepen 使用 Prefixfr
我正在使用以下代码返回 IList: public IList FindCodesByCountry(string country) { var query =
如何设计像这样的操作: 计算 转化 翻译 例如:从“EUR”转换为“CNY”金额“100”。 这是 /convert?from=EUR&to=CNY&amount=100 RESTful 吗? 最佳答
我使用 jquery 组合了一个图像滚动器,如下所示 function rotateImages(whichHolder, start) { var images = $('#' +which
如何使用 CSS (-moz-transform) 更改一个如下所示的 div: 最佳答案 你可以看看Mozilla Developer Center .甚至还有例子。 但是,在我看来,您的具体示例不
我需要帮助我正在尝试在选中和未选中的汉堡菜单上实现动画。我能够为菜单设置动画,但我不知道如何在转换为 0 时为左菜单动画设置动画 &__menu { transform: translateX(
我正在为字典格式之间的转换而苦苦挣扎:我正在尝试将下面的项目数组转换为下面的结果数组。本质上是通过在项目第一个元素中查找重复项,然后仅在第一个参数不同时才将文件添加到结果集中。 var items:[
如果我有两个定义相同的结构,那么在它们之间进行转换的最佳方式是什么? struct A { int i; float f; }; struct B { int i; float f; }; void
我编写了一个 javascript 代码,可以将视口(viewport)从一个链接滑动到另一个链接。基本上一切正常,你怎么能在那里看到http://jsfiddle.net/DruwJ/8/ 我现在的
我需要将文件上传到 meteor ,对其进行一些图像处理(必要时进行图像转换,从图像生成缩略图),然后将其存储在外部图像存储服务器(s3)中。这应该尽可能快。 您对 nodejs 图像处理库有什么建议
刚开始接触KDB+,有一些问题很难从Q for Mortals中得到。 说,这里 http://code.kx.com/wiki/JB:QforMortals2/casting_and_enumera
我在这里的一个项目中使用 JSF 1.2 和 IceFaces 1.8。 我有一个页面,它基本上是一大堆浮点数字段的大编辑网格。这是通过 inputText 实现的页面上的字段指向具有原始值的值对象
ScnMatrix4 是一个 4x4 矩阵。我的问题是什么矩阵行对应于位置(ScnVector3),旋转(ScnVector4),比例(ScnVector3)。第 4 行是空的吗? 编辑: 我玩弄了
恐怕我是 Scala 新手: 我正在尝试根据一些简单的逻辑将 Map 转换为新 Map: val postVals = Map("test" -> "testing1", "test2" -> "te
输入: This is sample 1 This is sample 2 输出: ~COLOR~[Green]This is sample 1~COLOR~[Red]This is sam
我是一名优秀的程序员,十分优秀!