ViewVC Help
View File | Revision Log | Show Annotations | Download File | Root Listing
root/radiance/ray/src/rt/rv2.c
(Generate patch)

Comparing ray/src/rt/rv2.c (file contents):
Revision 2.46 by greg, Thu Apr 14 04:42:33 2005 UTC vs.
Revision 2.50 by greg, Mon Jun 13 20:07:56 2005 UTC

# Line 305 | Line 305 | getfocus(                              /* set focus distance */
305                          error(COMMAND, "not on image");
306                          return;
307                  }
308 <                rayorigin(&thisray, NULL, PRIMARY, 1.0);
308 >                rayorigin(&thisray, PRIMARY, NULL, NULL);
309                  if (!localhit(&thisray, &thescene)) {
310                          error(COMMAND, "not a local object");
311                          return;
# Line 522 | Line 522 | setparam(                              /* get/set program parameter */
522          
523          if (s[0] == '\0') {
524                  (*dev->comout)(
525 <                "aa ab ad ar as av aw b dc dv dj ds dt i lr lw me ma mg ms ps pt sj st bv: ");
525 >                "aa ab ad ar as av aw b dc dv dj ds dt i lr lw me ma mg ms ps pt R sj st bv: ");
526                  (*dev->comin)(buf, NULL);
527                  s = buf;
528          }
529          switch (s[0]) {
530 +        case 'R':                       /* random sampling */
531 +                getparam(s+1, "random sampling", 'b',
532 +                                (void *)&rand_samp);
533 +                break;
534          case 'l':                       /* limit */
535                  switch (s[1]) {
536                  case 'w':                       /* weight */
# Line 719 | Line 723 | char  *s;
723                  return;
724          }
725  
726 <        rayorigin(&thisray, NULL, PRIMARY, 1.0);
726 >        rayorigin(&thisray, PRIMARY, NULL, NULL);
727          
728          rayvalue(&thisray);
729  
730          if (thisray.ro == NULL)
731                  (*dev->comout)("ray hit nothing");
732          else {
733 <                OBJREC  *mat = findmaterial(thisray.ro);
734 <                sprintf(buf, "ray hit %s%s %s \"%s\"",
735 <                                thisray.rod < 0.0 ? "back of " : "",
736 <                                mat==NULL ? VOIDID : mat->oname,
733 >                OBJREC  *mat = NULL;
734 >                OBJREC  *mod = NULL;;
735 >                char    matspec[256];
736 >                matspec[0] = '\0';
737 >                if (thisray.ro->omod != OVOID) {
738 >                        mod = objptr(thisray.ro->omod);
739 >                        mat = findmaterial(mod);
740 >                }
741 >                if (thisray.rod < 0.0)
742 >                        strcpy(matspec, "back of ");
743 >                if (mod != NULL) {
744 >                        strcat(matspec, mod->oname);
745 >                        if (mat != mod && mat != NULL)
746 >                                sprintf(matspec+strlen(matspec),
747 >                                        " (%s)", mat->oname);
748 >                } else
749 >                        strcat(matspec, VOIDID);
750 >                sprintf(buf, "ray hit %s %s \"%s\"", matspec,
751                                  ofun[thisray.ro->otype].funame,
752                                  thisray.ro->oname);
753                  if ((ino = objptr(thisray.robj)) != thisray.ro)

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines