这个类是球体,也就是一会要显示的球体了。这个类继承于Geometrics类,并实现了自己的碰撞检测,碰撞原理,书上也说的很清楚了啊,大家多看。然后对照代码就明白了。

类定义:

#pragma once
#ifndef __SPHERE_HEADER__
#define __SPHERE_HEADER__ #include "../geometics.h" class Sphere :public Geometrics {
public:
Sphere();
~Sphere();
Sphere(const Point3& center, ldouble radius);
Sphere(const Sphere& sp);
virtual Geometrics* clone() const;
virtual bool hit(const Ray& ray, ldouble& tmin, ShadeRec& sr) const;
Sphere& operator=(const Sphere& sp);
void set_center(const Point3& p);
Point3 get_center() const;
void set_radius(const ldouble rd);
ldouble get_radius() const;
private:
Point3 c;
ldouble r;
};
#endif

类实现:

#include "pch.h"
#include "sphere.h" Sphere::Sphere() :Geometrics(), c(), r(0) {} Sphere::~Sphere() {} Sphere::Sphere(const Point3& center, ldouble radius) : Geometrics(), c(center), r(radius) {} Sphere::Sphere(const Sphere& sp) : Geometrics(sp), c(sp.c), r(sp.r) {} Geometrics* Sphere::clone() const {
return new Sphere(*this);
} bool Sphere::hit(const Ray& ray, ldouble& tmin, ShadeRec& sr) const {
ldouble t;
Vector3 oc = ray.o - c;
ldouble a = ray.d * ray.d,
b = 2.0 * oc * ray.d,
c = oc * oc - r * r,
disc = b * b - 4.0 * a * c;
if (disc >= 0) {
t = (-b - std::sqrt(disc)) / (2.0 * a);
if (t > 0) {
tmin = t;
sr.normal = (oc + t * ray.d) / r;
sr.local_hit_point = ray.o + t * ray.d;
return true;
}
t = (-b + std::sqrt(disc)) / (2.0 * a);
if (t > 0) {
tmin = t;
sr.normal = (oc + t * ray.d) / r;
sr.local_hit_point = ray.o + t * ray.d;
return true;
}
}
return false;
} Sphere& Sphere::operator=(const Sphere& sp) {
if (this == &sp)
return *this;
Geometrics::operator=(sp);
c = sp.c;
r = sp.r;
return *this;
} void Sphere::set_center(const Point3& p) {
c = p;
} Point3 Sphere::get_center() const {
return c;
} void Sphere::set_radius(const ldouble rd) {
r = rd;
} ldouble Sphere::get_radius() const {
return r;
}

  

Sphere类定义的更多相关文章

  1. Python笔记——类定义

    Python笔记——类定义 一.类定义: class <类名>: <语句> 类实例化后,可以使用其属性,实际上,创建一个类之后,可以通过类名访问其属性 如果直接使用类名修改其属 ...

  2. 几种常用的JS类定义方法

    几种常用的JS类定义方法   // 方法1 对象直接量var obj1 = {    v1 : "",    get_v1 : function() {        return ...

  3. Js 类定义的几种方式

    提起面向对象我们就能想到类,对象,封装,继承,多态.在<javaScript高级程序设计>(人民邮电出版社,曹力.张欣译.英文名字是:Professional JavaScript for ...

  4. 为什么C++类定义中,数据成员不能被指定为自身类型,但可以是指向自身类型的指针或引用?为什么在类体内可以定义将静态成员声明为其所属类的类型呢 ?

    static的成员变量,不是存储在Bar实例之中的,因而不会有递归定义的问题. 类声明: class Screen: //Screen类的声明 1 类定义: class Screen{ //Scree ...

  5. C++学了这么多年,你也许不知道为什么类定义要放在.h文件,类实现放在cpp文件。它们如何关联?

    原文  http://blog.csdn.net/ithzhang/article/details/8119286 主题 C++  C++学了这么多年你知道为什么定义类时,类的定义放在.h文件中,而类 ...

  6. YTU 2602: 熟悉题型——类设计( 矩形类定义【C++】)

    2602: 熟悉题型--类设计( 矩形类定义[C++]) 时间限制: 1 Sec  内存限制: 128 MB 提交: 183  解决: 119 题目描述 定义一个矩形类,数据成员包括左下角和右上角坐标 ...

  7. Objective-c 类接口 (@interface) (类定义)

    在Objective-c中如何定义一个类呢?我们可以使用下面的格式进行表示: @interface 类名:父类名{ 变量定义; } 方法定义: @end; 下面给出一个实例: @interface P ...

  8. 只能从脚本中调用在类定义上有[ScriptService]属性的Web服务问题的解决方案

    ajax调用webservice中的接口时, 会出现[只能从脚本中调用在类定义上有[ScriptService]属性的...]的异常. 这是因为, 在.net3.5中, 访问web服务, 要对web服 ...

  9. 开涛spring3(12.4) - 零配置 之 12.4 基于Java类定义Bean配置元数据

    12.4  基于Java类定义Bean配置元数据 12.4.1  概述 基于Java类定义Bean配置元数据,其实就是通过Java类定义Spring配置元数据,且直接消除XML配置文件. 基于Java ...

随机推荐

  1. Map和WeakMap的方法和区别

    Map Map是一组键值对的结构,具有极快的查找速度. 一.构造函数不同 let map = new Map(); let weakmap = new WeakMap(); 二.内置函数不同 Map的 ...

  2. while和for循环的补充与数据类型的内置方法(int, float, str)

    目录 while与for循环的补充 while + else 死循环 while的嵌套 for补充 range函数 break与continue与else for循环的嵌套 数据类型的内置方法 int ...

  3. CoaXPress 线缆和接插件的设计要求

    本文的原理部分内容不仅适用于CoaXPress 协议,也同样适用于其它高速信号传输情形.在高速.低干扰信号传输时,线缆和接插件的选取是非常讲究的,我们在实际应用中经常会遇到线缆原因.阻抗匹配原因导致的 ...

  4. 「Java分享客栈」Nacos配置中心称王称霸,我Apollo一生也不弱于人!

    前言 Apollo又称阿波罗配置中心,在前两年还是挺火的,但阿里SpringCloud套件席卷国内之后,nacos就成为了最被亲睐的分布式配置中心,nacos是配置中心和注册中心二合一的产品,单纯功能 ...

  5. python求最大公约数和最小公倍数

    1 def gcd(x,y): 2 while(y): 3 t=x%y 4 x=y 5 y=t 6 #print("最小公倍数是:",x*y/x)#最小公倍数是两数之积除以最大公约 ...

  6. mysql复制表的两种方式

    mysql复制表的两种方式. 第一.只复制表结构到新表 create table 新表 select * from 旧表 where 1=2 或者 create table 新表 like 旧表 第二 ...

  7. R数据分析:临床预测模型中校准曲线和DCA曲线的意义与做法

    之前给大家写过一个临床预测模型:R数据分析:跟随top期刊手把手教你做一个临床预测模型,里面其实都是比较基础的模型判别能力discrimination的一些指标,那么今天就再进一步,给大家分享一些和临 ...

  8. 一张图进阶 RocketMQ - 整体架构

    前 言 三此君看了好几本书,看了很多遍源码整理的 一张图进阶 RocketMQ 图片链接,关于 RocketMQ 你只需要记住这张图!如果你第一次看到这个系列,墙裂建议你打开链接.觉得不错的话,记得点 ...

  9. Gitlab + Gitlab runner + Window powershell

    需求说明 根据领导要求,要把python 项目移到Gitlab 进行管理,并利用Gitlab CI/CD 进行自动化测试,打包,部署.(听起来很简单吧) 比较头大,完全没有经验,python 也是刚上 ...

  10. ServletContext 对象

    概念:代表整个Web应用 可以和程序的容器通信 (服务器) 获取 通过request对象获取  request.getServletContext(); 通过HTTPServlet获取  this.g ...