- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我已经能够创建一个 PHP-Imagick 脚本来生成像上面那样的图像。现在我想为这些圆圈添加渐变。下面是一个理想结果的示例。
我希望给这些圆圈一种三维的感觉。希望我能够控制这个径向渐变的 x 和 y 坐标(以便它保持在圆圈内),以及羽化程度。
我知道使用 newPseudoImage()
方法在 Canvas 上创建径向渐变的方法。
$canvas->newPseudoImage(600,300,'radial-gradient:#999999-#333333');
但这在这种情况下无济于事,因为我希望在通过 ellipse() method 创建的圆圈内创建它.这是帮助我创建示例图像的代码的精简版本。当我努力实现这一目标时,我将非常感谢任何可能让我走上正确道路或解决方案的想法和建议。
$canvas = new Imagick();
$canvas->newImage(700,400,new ImagickPixel('#333333'));
$circle = new ImagickDraw();
$circle->setFillColor('#000000'); // transparent
$circle->ellipse( 350, 200, 150, 150, 0, 360);
$canvas->drawImage($circle);
$canvas->setImageFormat( "png" ); // set the image format to png
header("Content-Type: image/png"); // Output the image
echo $canvas;
更新:所以我意识到,也许这基本上是在圆圈内创建子圆圈的问题(然后另外控制 x-y 坐标,使其保持在母圆圈内)。在圆圈中创建一个圆圈相当容易。下面的示例图片。
这是帮助实现上图的更新代码。
$canvas = new Imagick();
$canvas->newImage(700,400,new ImagickPixel('#333333'));
$circle = new ImagickDraw();
$circle->setFillColor('#000000'); // transparent
$circle->ellipse( 350, 200, 150, 150, 0, 360);
$circle->setFillColor('#FFFFFF'); // transparent
$circle->ellipse( 300, 150, 50, 50, 0, 360);
$canvas->drawImage($circle);
$canvas->setImageFormat( "png" ); // set the image format to png
header("Content-Type: image/png"); // Output the image
echo $canvas;
在这个阶段我正在寻找一种方法来羽化内圈的边缘。这个相关article at imagemagick看起来像我需要的,但它是一个命令行代码。有人能帮我把代码转换成 imagick/php 语法吗?或者也许建议自己的解决方案。谢谢。
最终更新:从@emcconville 的回答中得到提示,我终于能够创建一个圆圈,我认为这是一个很好的羽化。示例如下。
最佳答案
我不相信 MVG 的渐变方法是由 ImagickDraw 类处理的,至少据我所知是这样。但是,ImagickDraw->push
和 ImagickDraw-pop
可用于创建 DIY 渐变和羽化。
$background = new Imagick();
$background->newImage(700,400,new ImagickPixel('#333333'));
$orb = new ImagickDraw();
$orb->ellipse( 350, 200, 150, 150, 0, 360);
for($i=50; $i>0; $i--) {
$orb->push();
$color = 'gray' . (25 - (int)($i/2));
$orb->setFillColor(new ImagickPixel($color));
$orb->ellipse( 295, 120, $i, $i, 0, 360);
$orb->pop();
}
$background->drawImage($orb);
或者...
$color = 'gray' . (20 - (int)($i/3));
甚至...
$color = $i > 29 ? 'gray'.(50-$i) : 'grey20';
颜色理论有帮助,因为上面的例子只使用了灰色颜色空间,但一般的想法是迭代高光特征的光强度。
使用 ATop compose可能是最简单的方法,但需要在绘制图形后操作图像实例。
$background = new Imagick();
$background->newImage(700,400,new ImagickPixel('#333333'));
$orb = new ImagickDraw();
$orb->ellipse( 350, 200, 150, 150, 0, 360);
$background->drawImage($orb);
$highlight = new Imagick();
$highlight->newImage(700,400,new ImagickPixel('transparent'));
$orb = new ImagickDraw();
$orb->ellipse( 350, 200, 35, 35, 0, 360);
$highlight->drawImage($orb);
$highlight->negateImage(TRUE);
$highlight->blurImage(0,32);
$background->compositeImage($highlight, Imagick::COMPOSITE_ATOP, -50, -60);
关于php - 在圆上创建径向渐变以提供 3D 感觉,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33235538/
我正在尝试快速创建一个径向 CAGradientLayer。普通 CAGradientLayers(默认类型 axial)没有问题。它们在模拟器中的快照和运行时呈现良好。 当我拍摄我创建的 UIVie
我想用 CSS 制作一个径向进度指示器,它的中间圆圈是透明的。看这里:http://codepen.io/geedmo/pen/InFfd – 这是我想要做的事情的完美示例,但中间 (.overlay
我已经编写了用于生成网络图的 UI、服务器和 global.r。它适用于一种布局(layout.fruchterman.reingold)。我想要一个用于列出布局的单选按钮(径向、对角线网络和 den
我正在使用 jqwidgets。在那些小部件中,我使用的是径向量规。对于那个径向仪表,我想给出径向背景色。我有一个类似这样的代码,用于更改径向仪表中的背景颜色。 $('#gauge').jqxGaug
有谁知道我可以用来为 iOS 应用程序创建饼图(径向)菜单的库(开源或其他)? 看来现在应该有人想到了这一点,如果没有必要,我不愿意自己动手。 最佳答案 我不久前发现的一个。 http://www
我正在使用 this code为我的数据获取径向 TreeMap 。但是,我想修改它以避免弯曲链接。相反,我对线性直接连接感兴趣。弯曲的链接使插图不那么复杂,特别是当我们的子节点数量较少时。例如,您可
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 8 年前。 Improve this qu
我正在使用 chrome 18.0.1025.162 并尝试进行径向渐变 -webkit-radial-gradient(circle, rgba(100, 100, 100, 0.2), rgba(
我想呈现漂亮的径向树布局,但有点被弯曲的边缘绊倒了。问题是源点和目标点之间的角度不同,边缘的绘制方式也不同。提供的图片来自单个图表,因此您可以看到它们在不同边缘方向上有何不同。我认为关键在于 beiz
我希望我的工具栏使用 Material 设计径向 react 编排指南改变颜色 我想将其实现为 Angular 2 过渡,但我不知 Prop 体该怎么做: 看起来像这样.. @Component({
我目前正在使用以下代码绘制形状; GLfloat vertex = // vertex points glLineWidth(2); glEnableClientState(GL_VERTEX_ARR
我是一名优秀的程序员,十分优秀!