super ellipse [fltk]

Bjarne Stroustrup “Programming Principles and Practice Using C++”
Chapter 12 Exercise 12
Using GUI library called FLTK (Fast Light Tool Kit, “full tick”).

Output: n = 2

Output: n = 1/2

Output: n = 3/2

Output: n = 4

//  Philipp Siedler
//  Bjarne Stroustrup's PP
//  Chapter 12 Exercise 12

#define _USE_MATH_DEFINES
#include "Simple_window.h"
#include "Graph.h"
#include <cmath>
using namespace Graph_lib;

int main()
try
{
	Point tl(100, 100);
	Simple_window win(tl, 600, 400, "Regular Polygons");

	Point center(win.x_max() / 2, win.y_max() / 2);
	Graph_lib::Closed_polyline supEllipse;
	supEllipse.set_color(Color::black);
	
	double a = 100;
	double y;
	double b = 100;
	double n; // 1/2; 3/2; 2; 4;
	n = 4.0;

	for (int x = - 100; x < 100; x++) {
		y = b * pow(1 - pow(abs(x / a), n), 1 / n);
		supEllipse.add(Point(x + center.x, y + center.y));
	}

	for (int x = 100; x > -100; x--) {
		y = b * pow(1 - pow(abs(x / a), n), 1 / n);
		y = -y;
		supEllipse.add(Point(x + center.x, y + center.y));
	}	

	win.attach(supEllipse);
	win.wait_for_button();
}
catch (exception& e) {
	cout << e.what() << endl;
	return 1;
}
catch (...) {
	cout << "Exiting" << endl;
	return 2;
}

Leave a Reply

Fill in your details below or click an icon to log in:

WordPress.com Logo

You are commenting using your WordPress.com account. Log Out /  Change )

Google+ photo

You are commenting using your Google+ account. Log Out /  Change )

Twitter picture

You are commenting using your Twitter account. Log Out /  Change )

Facebook photo

You are commenting using your Facebook account. Log Out /  Change )

w

Connecting to %s

This site uses Akismet to reduce spam. Learn how your comment data is processed.