- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我得到了使用数据中的 x、y、z 坐标生成 2D 图像的代码,我想修改此代码以创建 3D 图像。 (代码来源:https://physiology.arizona.edu/people/secomb/netflow)
下面的代码创建一个 2D 图像,使用数据中的 x y z 坐标我想修改代码以创建 3D 图像
例如:转这个https://www.researchgate.net/figure/A-2D-meshed-model-of-the-flow-network-in-GAMBIT_fig12_266171604
这是C++代码,我在visual studio 2019中使用它
/**********************************************************
picturenetwork.cpp - project network on z = 0 plane
Labels nodes with nodvar and segments with segvar (must be float)
Colors segments according to segvar
Generates a postscript file
Version for NetFlowV1, TWS Oct. 2012
***********************************************************/
#define _CRT_SECURE_NO_DEPRECATE
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <math.h>
#include "nrutil.h"
void picturenetwork(float *nodvar, float *segvar, const char fname[])
{
extern int nseg,nnod;
extern int *segtyp,*ista,*iend;
extern float *diam,**cnode;
int k,iseg,inod,ilevel,nlevel = 100;
float xmin,xmax,ymin,ymax,xs,ys,zs,picfac,red,green,blue,xz,xzmin,xzmax, zzmin, zzmax;
float diamfac = 1.,zcoord,zbottom,ztop,zmin,zmax;
FILE *ofp;
//Determine range of x,y,z values
xmin = 1.e6;
xmax = -1.e6;
ymin = 1.e6;
ymax = -1.e6;
zmin = 1.e6;
zmax = -1.e6;
for(inod=1; inod<=nnod; inod++){
xmin = FMIN(xmin,cnode[1][inod]);
xmax = FMAX(xmax,cnode[1][inod]);
ymin = FMIN(ymin,cnode[2][inod]);
ymax = FMAX(ymax,cnode[2][inod]);
zmin = FMIN(zmin,cnode[3][inod]);
zmax = FMAX(zmax,cnode[3][inod]);
}
zmin -= 1.; //make sure everything is included
zmax += 1.;
picfac = FMIN(500./(xmax - xmin),700./(ymax - ymin));
ofp = fopen(fname, "w");
fprintf(ofp, "%%!PS-Adobe-2.0\n");
fprintf(ofp, "%%%%Pages: 1\n");
fprintf(ofp, "%%%%EndComments\n");
fprintf(ofp, "%%%%Page: 1 1\n");
fprintf(ofp, "/mx {%g sub %g mul 50 add} def\n",xmin,picfac);
fprintf(ofp, "/my {%g sub %g mul 50 add} def\n",ymin,picfac);
fprintf(ofp, "/cf {closepath fill} def\n");
fprintf(ofp, "/cs {closepath stroke} def\n");
fprintf(ofp, "/m {moveto} def\n");
fprintf(ofp, "/n {newpath} def\n");
fprintf(ofp, "/l {lineto} def\n");
fprintf(ofp, "/sl {setlinewidth} def\n");
fprintf(ofp, "/sc {setrgbcolor} def\n");
fprintf(ofp, "/s {stroke} def\n");
fprintf(ofp, "/Times-Roman findfont\n");
fprintf(ofp, "8 scalefont\n");
fprintf(ofp, "setfont\n");
fprintf(ofp, "newpath\n");
fprintf(ofp, "%g mx %g my m\n",xmin,ymin);
fprintf(ofp, "%g mx %g my l\n",xmax,ymin);
fprintf(ofp, "%g mx %g my l\n",xmax,ymax);
fprintf(ofp, "%g mx %g my l\n",xmin,ymax);
fprintf(ofp, "closepath\n");
fprintf(ofp, "stroke\n");
fprintf(ofp, "/Times-Roman findfont\n");
fprintf(ofp, "4 scalefont\n");
fprintf(ofp, "setfont\n");
//plot vessels colored according to segvar, in order from bottom to top according to z-coordinate
xzmin = 1.e6;
xzmax = -1.e6;
for(iseg=1; iseg<=nseg; iseg++) if(segtyp[iseg] == 4 || segtyp[iseg] == 5){
xzmin = FMIN(xzmin,segvar[iseg]);
xzmax = FMAX(xzmax,segvar[iseg]);
}
for(ilevel=1; ilevel<=nlevel; ilevel++){
zbottom = zmin + (ilevel-1)*(zmax - zmin)/nlevel;
ztop = zmin + ilevel*(zmax - zmin)/nlevel;
for(iseg=1; iseg<=nseg; iseg++) if(segtyp[iseg] == 4 || segtyp[iseg] == 5){
zcoord = (cnode[3][ista[iseg]] + cnode[3][iend[iseg]])/2.;
if(zcoord >= zbottom && zcoord < ztop){
if(xzmin != xzmax) xz = (segvar[iseg] - xzmin)/(xzmax - xzmin);
else xz = 0.75;
blue = FMIN(FMAX(1.5-4.*fabs(xz-0.25), 0.), 1.);//Set up colors using Matlab 'jet' scheme
green= FMIN(FMAX(1.5-4.*fabs(xz-0.5), 0.), 1.);
red = FMIN(FMAX(1.5-4.*fabs(xz-0.75), 0.), 1.);
fprintf(ofp,"%f %f %f sc\n",red,green,blue);
fprintf(ofp,"%g sl\n",picfac*diam[iseg]*diamfac);//line widths scaled up by diamfac
fprintf(ofp, "%g mx %g my m ", cnode[1][ista[iseg]],cnode[2][ista[iseg]],cnode[3][ista[iseg]]);
fprintf(ofp, "%g mx %g my l s \n", cnode[1][iend[iseg]],cnode[2][iend[iseg]],cnode[3][iend[iseg]]);
}
}
}
创建的图片是.ps文件,目前没有错误。 主要问题是生成的图像是 2D 而不是 3D。该图像是不同颜色的容器。
最佳答案
使用此代码无法创建 3D 模型。此代码正在输出不支持 3D 图形的 .ps 文件。
关于c++ - 如何使用 x y z 坐标创建 3D 图像,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56152442/
我在一个C++程序中找到了一段代码,好像每隔for()循环两次。在这个程序中循环,但为什么在这样的预处理器定义中需要第三个 for 呢? #define for for(int z=0;z<2;++z
我正在尝试分割其中有一个小写字母后跟一个大写字母的文本。 假设文本是: “Įvairių rūšiųSkinti kardeliai” 我想在“ųS”处拆分它,但是以下正则表达式“[ą-ž][Ą-Ž]
这个问题在这里已经有了答案: Reference - What does this regex mean? (1 个回答) 关闭 2 年前。 下面的正则表达式有什么区别。对我来说,它们都是一样的 [
我正在尝试用 Java 编写一个正则表达式: "/[A-Z]{6}-[A-Z]{4}-[A-Z]{4}/" 但是它不起作用。例如 "AASAAA-AAAA-AAAA".matches("/[A-Z]{
我需要确定一个字符串是否是一个变量标识符。 即(a-z,A-Z,,$) 后跟 (a-z,A-Z,0-9,,$) 我知道我可以使用手动配置的 reg exp 来完成它,但必须有一个更紧凑的内置函数我可以
早上好,我是新来的,我带来了一个小问题。我无法针对以下问题开发有效的算法:我需要找到三个正数 x、y 和 z 的组合,以便 x + y、x - y、y + z、y - z、x + z 和 x - z
这个问题已经有答案了: How does the ternary operator work? (12 个回答) 已关闭 6 年前。 我发现了一种不同的返回值的方式,并且很兴奋。它到底是什么意思? 如
我需要以下正则表达式,允许 [a-zA-Z]+ 或 [a-zA-Z]+[ \\-]{0,1}[a-zA-Z]+ 所以我想在 a-zA-Z 字符之间允许无限的减号和空格 示例: sdfsdfdsf-sf
我正在编写一个代码,它以“代码”(编码理论)作为输入,并且我已经计算了它的权重枚举器。我想使用 MacWilliams Identity 找到双代码的权重枚举器. 我有W(z) ,代码的权重枚举器,我
我已经编写了一个 child 文字游戏,现在我正在尝试优化性能。游戏以一种特殊的方式从数据库中挑选关键词,我想做得更好。 给定一个按字母数字排序的 MySQL 关键字字段: keyword s
假设一个字符串是abc/xyz/IMPORTANT/DATA/@#!%@!%,我只想要IMPORTANT/DATA/!%#@%!#% 我对正则表达式很烂,而且真的还没学过 JavaScript API
JS代码: ? 1
大家晚上好我想知道有没有更快的方法来生成以下形式的列表? [a,b,c,…,z] → [[z], [y,z], [x,y,z], … , [a,b,…,y,z]] 我知道切片是最好的方法之一,但没有更
我在 Firefox 和其他浏览器上遇到嵌套 z-index 的问题,我有一个 div,z-index 为 30000,位于 label 下方> zindex 为 9000。我认为这是由 z-inde
我正在尝试制作一个灯泡。这是代码 JSfiddle HTML 查询 $('.button').click(function() { $('#add').show();
在您想将嵌套模块导入命名空间的情况下,我总是这样写: from concurrent import futures 不过,我最近意识到这也可以使用“as”语法来表达。请参阅以下内容: import c
我正在尝试创建一个基本上复制 matlab 命令的函数:[z;-z] 其中 z = randn(m,n) 返回一个 m -by-n 随机条目矩阵。我能够在 C++ 中为下面的 randn 函数创建一个
好吧,我迷失在这些指针中,有人能准确地告诉我 char * x,y,z; 和 char* x,y,z 之间的区别是什么; 和 char (*)x,y,z; ?如果可以,请为您的答案或其他内容提供资源。
这是一道函数依赖题。 我知道当 x->yz 然后 x->y 和 x->z 时。但是上面的依赖关系可能吗? 最佳答案 If xy determines z can x determine z and y
我有一个列表列表 nLedgers - 一个 3D 点云: [nodeID, X, Y, Z] 多行。一些节点将具有相同的 X 和 Y 坐标以及不同的 Z 坐标。 我想首先确定具有相同 X 和 Y 坐
我是一名优秀的程序员,十分优秀!