我公开以下图片的源代码,,是ppm格式的,,自己找到能打开的工具..

(非原创,我加工的代码,可直接执行运行输出,缩略图能看到效果)
 这是原博客 http://news.cnblogs.com/n/501488/
 
本人测试可在Visual Studio 2012 中运行

请教高手一个问题,,
就是如何 调用动态方面名,,方面名均为后缀+数字,
希望可以根据动态方面名来调用不同的方法...
我觉得就是太多重复的代码了..我想用C++类泛型,,应该可以调用相应的方法.

 

以下是 C++ 的代码,,,

#include "stdafx.h"

#include <iostream>
#include <cmath>
#include <cstdlib>
#include<Windows.h> #pragma warning(disable:4996) //全部关掉
#pragma warning(disable:4244) #define DIM 1024
#define DM1 (DIM-1)
#define _sq(x) ((x)*(x)) // square
#define _cb(x) abs ((x)*(x)*(x)) // absolute value of cube
#define _cr(x) (unsigned char)(pow ((x),1.0/3.0)) // cube root unsigned char GR (int ,int);
unsigned char BL (int ,int); unsigned char RD1 (int i,int j){
float x=0,y=0;
int k;
for(k=0;k++<256;)
{
float a=x*x-y*y+ (i-768.0)/512;
y=2*x*y+ (j-512.0)/512;
x=a;
if(x*x+y*y>4)
break;
}
return log (k)*47;
} unsigned char GR1 (int i,int j){
float x=0,y=0;
int k;
for(k=0;k++<256;)
{
float a=x*x-y*y+ (i-768.0)/512;y=2*x*y+ (j-512.0)/512;
x=a;
if(x*x+y*y>4)
break;
}
return log (k)*47;
} unsigned char BL1 (int i,int j){
float x=0,y=0;
int k;
for(k=0;k++<256;)
{
float a=x*x-y*y+ (i-768.0)/512;
y=2*x*y+ (j-512.0)/512;
x=a;
if(x*x+y*y>4)
break;
}
return 128-log (k)*23;
} unsigned char RD (int i,int j)
{
#define r(n) (rand ()%n)
static char c[1024][1024];
return !c[i][j]?c[i][j]=!r(999)?r(256):RD ((i+r(2))%1024,(j+r(2))%1024):c[i][j];
} unsigned char GR (int i,int j)
{
static char c[1024][1024];
return!c[i][j]?c[i][j]=!r(999)?r(256):GR ((i+r(2))%1024,(j+r(2))%1024):c[i][j];
} unsigned char BL (int i,int j)
{
static char c[1024][1024];
return!c[i][j]?c[i][j]=!r(999)?r(256):BL ((i+r(2))%1024,(j+r(2))%1024):c[i][j];
} unsigned char RD2 (int i,int j){
double a=0,b=0,c,d,n=0;
while((c=a*a)+(d=b*b)<4&&n++<880)
{b=2*a*b+j*8e-9-.645411;a=c-d+i*8e-9+.356888;}
return 255*pow ((n-80)/800,3.);
} unsigned char GR2 (int i,int j){
double a=0,b=0,c,d,n=0;
while((c=a*a)+(d=b*b)<4&&n++<880)
{b=2*a*b+j*8e-9-.645411;a=c-d+i*8e-9+.356888;}
return 255*pow ((n-80)/800,.7);
} unsigned char BL2 (int i,int j){
double a=0,b=0,c,d,n=0;
while((c=a*a)+(d=b*b)<4&&n++<880)
{b=2*a*b+j*8e-9-.645411;a=c-d+i*8e-9+.356888;}
return 255*pow ((n-80)/800,.5);
} unsigned char RD3 (int i,int j){
static double k;k+=rand ()/1./RAND_MAX;int l=k;l%=512;return l>255?511-l:l;
} unsigned char GR3 (int i,int j){
static double k;k+=rand ()/1./RAND_MAX;int l=k;l%=512;return l>255?511-l:l;
} unsigned char BL3 (int i,int j){
static double k;k+=rand ()/1./RAND_MAX;int l=k;l%=512;return l>255?511-l:l;
} unsigned char RD4 (int i,int j){
float s=3./(j+99);
float y=(j+sin ((i*i+_sq (j-700)*5)/100./DIM)*35)*s;
return (int((i+DIM)*s+y)%2+int((DIM*2-i)*s+y)%2)*127;
} unsigned char GR4 (int i,int j){
float s=3./(j+99);
float y=(j+sin ((i*i+_sq (j-700)*5)/100./DIM)*35)*s;
return (int(5*((i+DIM)*s+y))%2+int(5*((DIM*2-i)*s+y))%2)*127;
} unsigned char BL4 (int i,int j){
float s=3./(j+99);
float y=(j+sin ((i*i+_sq (j-700)*5)/100./DIM)*35)*s;
return (int(29*((i+DIM)*s+y))%2+int(29*((DIM*2-i)*s+y))%2)*127;
} void pixel_write (int,int);
FILE *fp; void pixel_write1(int i, int j)
{
static unsigned char color[3];
color[0] = RD1 (i,j)&255;
color[1] = GR1 (i,j)&255;
color[2] = BL1 (i,j)&255;
fwrite (color, 1, 3, fp);
} void pixel_write2 (int i, int j)
{
static unsigned char color[3];
color[0] = RD2 (i,j)&255;
color[1] = GR2 (i,j)&255;
color[2] = BL2 (i,j)&255;
fwrite (color, 1, 3, fp);
} void pixel_write3(int i, int j)
{
static unsigned char color[3];
color[0] = RD3 (i,j)&255;
color[1] = GR3 (i,j)&255;
color[2] = BL3 (i,j)&255;
fwrite (color, 1, 3, fp);
} void pixel_write4(int i, int j)
{
static unsigned char color[3];
color[0] = RD4 (i,j)&255;
color[1] = GR4 (i,j)&255;
color[2] = BL4 (i,j)&255;
fwrite (color, 1, 3, fp);
} int main ()
{
char t[256];
char printfHistory[2048]="正写入文件请稍等";
printf_s("printfHistory");
int num=0;
for(int a=1;a<6;a++)
{
sprintf_s(t,"MathPic%d.ppm",a);
fp = fopen (t,"wb");
fprintf (fp, "P6\n%d %d\n255\n", DIM, DIM);
for(int j=0;j<DIM;j++)
{
for(int i=0;i<DIM;i++)
{
switch (a)
{
case 1:
pixel_write(i,j);
case 2:
pixel_write1(i,j);
case 3:
pixel_write2(i,j);
case 4:
pixel_write3(i,j);
case 5:
pixel_write4(i,j);
default:
break;
}
}
}
printf_s("第 %d 张图片 写入成功!\n",a);
}
printf_s("所有图片已全部输出,请打开程序目录查看!");
fclose (fp);
return 0;
} void pixel_write (int i, int j)
{
static unsigned char color[3];
color[0] = RD (i,j)&255;
color[1] = GR (i,j)&255;
color[2] = BL (i,j)&255;
fwrite (color, 1, 3, fp);
}

  

用RD,GR,BL三个方法内代码生成一张图片(非原创,我只是完整了代码)的更多相关文章

  1. HTML5结合CSS的三种方法+结合JS的三种方法

    HTML5+CSS: HTML中应用CSS的三种方法 一.内联 内联样式通过style属性直接套进HTML中去. 示例代码 <pstylepstyle="color:red" ...

  2. Java方法内联

    一.概念 方法内联就是把调用方函数代码"复制"到调用方函数中,减少因函数调用开销的技术   函数调用过程 1.首先会有个执行栈,存储它们的局部变量.方法名.动态连接 2.当一个方法 ...

  3. 是否可从一个static方法内发出对非static方法的调用?

    不可以.因为非static方法是要与对象关联在一起的,必须创建一个对象后,才可以在该对象上进行方法调用,而static方法调用时不需要创建对象,可以直接调用.也就是说,当一个static方法被调用时, ...

  4. {Django基础十之Form和ModelForm组件}一 Form介绍 二 Form常用字段和插件 三 From所有内置字段 四 字段校验 五 Hook钩子方法 六 进阶补充 七 ModelForm

    Django基础十之Form和ModelForm组件 本节目录 一 Form介绍 二 Form常用字段和插件 三 From所有内置字段 四 字段校验 五 Hook钩子方法 六 进阶补充 七 Model ...

  5. (PASS)JAVA数组去重 三种方法 (不用集合)

    第一种方法(只学到数组的看): 定义一个新的数组长度和旧数组的长度一样,存储除去重复数据的旧数组的数据和0, package demo01; import java.sql.Array; import ...

  6. dedecms在首页或列表调取文章内容body的三个方法

    有时需要在网站首页或栏目封面上显示几篇文章的内页作为导语或其他什么的,但acrlist标签是不能直接调取body的,这时我们就需要使用以下方法来调取body. 方法一:arcticle 标签 加上ch ...

  7. Quartz2D之生成圆形头像、打水印、截图三种方法的封装

    我给UIImage类添加了一个类目,用于封装三个方法,每个方法都没有难度,做这个主要为了练习一下封装: 首先在类目.h文件中声明三个方法:以及创建了一个枚举.用于水印方法中设定水印位置:方法说明和参数 ...

  8. 深入理解为什么Java中方法内定义的内部类可以访问方法中的局部变量

    好文转载:http://blog.csdn.net/zhangjg_blog/article/details/19996629 开篇 在我的上一篇博客 深入理解Java中为什么内部类可以访问外部类的成 ...

  9. Linux系统下修改环境变量PATH路径的三种方法

    这里介绍Linux的知识,比如把/etc/apache/bin目录添加到PATH中有三种方法,看完之后你将学会Linux系统下如何修改环境变量PATH路径,需要的朋友可以参考下 电脑中必不可少的就是操 ...

随机推荐

  1. Nginx 反向代理功能-实现Nginx tcp负载均衡

    Nginx 反向代理功能-实现Nginx tcp负载均衡 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任.

  2. django model content_type 使用

    一.关于content_type 使用 1.引入模块在models from django.db import models from django.contrib.contenttypes.mode ...

  3. C#中Equals 与== 的区别

    这个问题听说是大公司面试都会问的问题,以前不怎么了解,好奇心勾引我来研究一下 首先从值类型分析,先写几句简单的代码供测试用,二行语句输出的都是true, 说明==与Equals功能是相同的, 判断的都 ...

  4. Module build failed: Error: Cannot find module 'node-sass'

    安装npm 遇到 Module build failed: Error: Cannot find module 'node-sass' 这次通过重装 npm 完成 先卸载npm npm uninsta ...

  5. 图的遍历 | 1034 map处理输入数据,连通块判断

    这题写得比较痛苦.首先有点不在状态,其次题目比较难读懂. “Gang”成立的两个条件:①成员数大于两个  ②边权总和大于阈值K 首先,在录数据的时候通过map或者字符串哈希建立string到int的映 ...

  6. centos6中安装新版 Elasticsearch 7.x

    es出新版了,虽然公司里还是用的老版本,但是本地还是有必要自己安装了玩玩 下载地址:https://www.elastic.co/cn/downloads/elasticsearch 那么一般来说还是 ...

  7. Linux中fork()函数详解(转载)

    linux中fork()函数详解 一.fork入门知识 一个进程,包括代码.数据和分配给进程的资源.fork()函数通过系统调用创建一个与原来进程几乎完全相同的进程,也就是两个进程可以做完全相同的事, ...

  8. C语言博客作业2019-04--数组

    0.展示PTA总分(0----2) 展示3张关于"数组题目集"分数截图. 1.本章学习总结(2分) 1.1 学习内容总结 整理数组这章学习主要知识点,必须包含内容有: 数组中如何查 ...

  9. python 文件读写模式区别,以及如何边写入边保存flush()

    如表: 模式 可做操作 若文件不存在 是否覆盖 r 只能读 报错 - r+ 可读可写 报错 是 w 只能写 创建 是 w+ 可读可写 创建 是 a 只能写 创建 否,追加写 a+ 可读可写 创建 否, ...

  10. Java集合详解6:这次,从头到尾带你解读Java中的红黑树

    <Java集合详解系列>是我在完成夯实Java基础篇的系列博客后准备开始写的新系列. 这些文章将整理到我在GitHub上的<Java面试指南>仓库,更多精彩内容请到我的仓库里查 ...