相关资料:

http://blog.csdn.net/tokimemo/article/details/18702689

http://www.myexception.cn/delphi/215402.html

http://bbs.csdn.net/topics/390627275

结果总结:

1.生成的环中间会少一部分颜色,颜色会小于16581375。

2.手动选择颜色不准,手容易抖,要支持用户输入准确的数值。

代码实例:

 unit Unit1;

 interface

 uses
Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics,
Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.StdCtrls, Vcl.ExtCtrls; type
TForm1 = class(TForm)
Button1: TButton;
Image1: TImage;
CheckBox1: TCheckBox;
Label1: TLabel;
Label2: TLabel;
Label3: TLabel;
Label4: TLabel;
Label5: TLabel;
Label6: TLabel;
procedure Button1Click(Sender: TObject);
procedure Image1MouseMove(Sender: TObject; Shift: TShiftState; X,
Y: Integer);
private
{ Private declarations }
public
{ Public declarations }
end; var
Form1: TForm1; implementation {$R *.dfm} //生成RGB色环的代码绘制
//传入图片的大小
function CreateColorCircle(const size: integer): TBitmap;
var
i,j,x,y: Integer;
radius: integer;
perimeter,arc,degree,step: double;
R,G,B: byte;
color: TColor;
begin
radius := round(size / );
RESULT := TBitmap.Create;
R:=;
G:=;
B:=;
with RESULT do
begin
width := size;
height:= size;
pixelFormat := pf24bit;
Canvas.Brush.Color := RGB(R,G,B);
x := size + ;
y := round(radius) + ;
Canvas.FillRect(Rect(size,round(radius),x,y));
for j := to size do
begin
perimeter := (size - j) * PI + ;
arc := perimeter / ;
step := ( * ) / perimeter ; //颜色渐变步长
for i := to round(perimeter) - do
begin
degree := / perimeter * i;
x := round(cos(degree * PI / ) * (size - j + ) / ) + radius;//数学公式,最后加上的是圆心点
y := round(sin(degree * PI / ) * (size - j + ) / ) + radius; if (degree > ) and (degree <= ) then
begin
R := ;
G := ;
B := round(step * i);
end;
if (degree > ) and (degree <= ) then
begin
if perimeter / / * (degree - ) > 1.0 then
R := - round(step * (i - arc))
else
R := - round(step * ABS(i - arc));
G := ;
B := ;
end;
if (degree > ) and (degree <= ) then
begin
R := ;
if perimeter / / * (degree - ) > 1.0 then
G := round(step * (i - * arc))
else
G := round(step * ABS(i - * arc));
B := ;
end;
if (degree > ) and (degree <= ) then
begin
R := ;
G := ;
if perimeter / / * (degree - ) > 1.0 then
B := - round(step * (i - perimeter / ))
else
B := - round(step * ABS(i - perimeter / ));
end;
if (degree > ) and (degree <= ) then
begin
if perimeter / / * (degree - ) > 1.0 then
R := round(step * (i - * arc))
else
R := round(step * ABS(i - * arc)) ;
G := ;
B := ;
end;
if (degree > ) and (degree <= ) then
begin
R := ;
if perimeter / / * (degree - ) > 1.0 then
G := - round(step * (i - * arc))
else
G := - round(step * ABS(i - * arc));
B := ;
end;
color := RGB( ROUND(R + ( - R)/size * j),ROUND(G + ( - G) / size * j),ROUND(B + ( - B) / size * j));
Canvas.Brush.Color := color;
//为了绘制出来的圆好看,分成四个部分进行绘制
if (degree >= ) and (degree <= ) then
Canvas.FillRect(Rect(x,y,x-,y-));
if (degree > ) and (degree <= ) then
Canvas.FillRect(Rect(x,y,x-,y-));
if (degree > ) and (degree <= ) then
Canvas.FillRect(Rect(x,y,x+,y+));
if (degree > ) and (degree <= ) then
Canvas.FillRect(Rect(x,y,x+,y+));
if (degree > ) and (degree <= ) then
Canvas.FillRect(Rect(x,y,x-,y-));
end;
end;
end;
end; //扣出中心的黑色圆
//输入图片与中心圆的半径
procedure BuckleHole(ABitmap: TBitmap; ARadius: Integer);
var
oBmp :TBitmap;
oRgn :HRGN;
begin
// oBmp := TBitmap.Create; //为了代码整齐就不写try了
// oBmp.PixelFormat := ABitmap.PixelFormat;
// oBmp.Width := ABitmap.Width;
// oBmp.Height := ABitmap.Height;
// BitBlt(oBmp.Canvas.Handle, 0, 0, oBmp.Width, oBmp.Height, ABitmap.Canvas.Handle, 80, 80, SRCCOPY); //要拷贝的位图
// oRgn := CreateEllipticRgn(0, 0, 100, 100); //创建圆形区域
// SelectClipRgn(ABitmap.Canvas.Handle, oRgn); //选择剪切区域
// ABitmap.Canvas.Draw(0, 0, oBmp); //位图位于区域内的部分加载
// oBmp.Free;
// DeleteObject(oRgn);
ABitmap.Canvas.Pen.Color := clBlack;
ABitmap.Canvas.Brush.Style := bsClear;
ABitmap.Canvas.Brush.Color := clBlack;
ABitmap.Canvas.Ellipse(Trunc(ABitmap.Width/)-ARadius, Trunc(ABitmap.Height/)-ARadius,
Trunc(ABitmap.Width/)+ARadius, Trunc(ABitmap.Height/)+ARadius);
end; //把中心圆做成透明的
procedure MyDraw(ABitmap: TBitmap; ARadius: Integer);
var
bf: BLENDFUNCTION;
desBmp, srcBmp: TBitmap;
rgn: HRGN;
begin
with bf do
begin
BlendOp := AC_SRC_OVER;
BlendFlags := ;
AlphaFormat := ;
SourceConstantAlpha := ; // 透明度,0~255
end; desBmp := TBitmap.Create;
srcBmp := TBitmap.Create; try
srcBmp.Assign(ABitmap); desBmp.Width := srcBmp.Width;
desBmp.Height := srcBmp.Height; Winapi.Windows.AlphaBlend(desBmp.Canvas.Handle, , ,
desBmp.Width, desBmp.Height, srcBmp.Canvas.Handle,
, , srcBmp.Width, srcBmp.Height, bf); rgn := CreateEllipticRgn(Trunc(ABitmap.Width/)-ARadius, Trunc(ABitmap.Height/)-ARadius,
Trunc(ABitmap.Width/)+ARadius, Trunc(ABitmap.Height/)+ARadius); // 创建一个圆形区域
SelectClipRgn(srcBmp.Canvas.Handle, rgn);
srcBmp.Canvas.Draw(, , desBmp); ABitmap.Assign(nil);
ABitmap.Assign(srcBmp);
finally
desBmp.Free;
srcBmp.Free;
end
end; procedure TForm1.Button1Click(Sender: TObject);
var
oBitmap: TBitmap;
rgn: HRGN;
begin
oBitmap := CreateColorCircle(Image1.Width);
if CheckBox1.Checked then //要不要代中心圆选项
// BuckleHole(oBitmap, 100);
MyDraw(oBitmap, );
Image1.Picture.Graphic := oBitmap;
oBitmap.Free;
end; procedure TForm1.Image1MouseMove(Sender: TObject; Shift: TShiftState; X,
Y: Integer);
var
oColor: TColor;
begin
//鼠标移动时提取颜色RGB的值
with Image1 do
oColor := GetPixel(GetDC(Parent.Handle), X + left,Y + Top);
Label4.Caption := IntToStr(oColor and $FF);
Label5.Caption := IntToStr((oColor and $FF00) shr );
Label6.Caption := IntToStr((oColor and $FF0000) shr );
end; end.

Delphi实现RGB色环的代码绘制(XE10.2+WIN764)的更多相关文章

  1. Delphi汉字简繁体转换代码(分为D7和D2010版本)

    //delphi 7 Delphi汉字简繁体转换代码unit ChineseCharactersConvert; interface uses   Classes, Windows; type   T ...

  2. delphi 常用属性+方法+事件+代码+函数

    内容居中(属性) alignment->tacenter mome控件 禁用最大化(属性) 窗体-> BorderIcons属性-> biMaximize-> False 让鼠 ...

  3. Delphi图像处理 -- RGB与HSV转换

    阅读提示:     <Delphi图像处理>系列以效率为侧重点,一般代码为PASCAL,核心代码采用BASM.     <C++图像处理>系列以代码清晰,可读性为主,全部使用C ...

  4. Delphi图像处理 -- RGB与HSL转换

    阅读提示:     <Delphi图像处理>系列以效率为侧重点,一般代码为PASCAL,核心代码采用BASM.     <C++图像处理>系列以代码清晰,可读性为主,全部使用C ...

  5. Delphi语言最好的JSON代码库 mORMot学习笔记1

    mORMot没有控件安装,直接添加到lib路径,工程中直接添加syncommons,syndb等到uses里 --------------------------------------------- ...

  6. delphi 微信(WeChat)多开源代码

    在网上看到一个C++代码示例: 原文地址:http://bbs.pediy.com/thread-217610.htm 觉得这是一个很好的调用 windows api 的示例,故将其转换成了 delp ...

  7. Delphi如何在Form的标题栏绘制自定义文字

    Delphi中Form窗体的标题被设计成绘制在系统菜单的旁边,如果你想要在标题栏绘制自定义文本又不想改变Caption属性,你需要处理特定的Windows消息:WM_NCPAINT.. WM_NCPA ...

  8. Delphi调用JAVA的WebService上传XML文件(XE10.2+WIN764)

    相关资料:1.http://blog.csdn.net/luojianfeng/article/details/512198902.http://blog.csdn.net/avsuper/artic ...

  9. Delphi语言最好的JSON代码库 mORMot学习笔记1(无数评论)

    mORMot没有控件安装,直接添加到lib路径,工程中直接添加syncommons,syndb等到uses里 --------------------------------------------- ...

随机推荐

  1. 进阶之路(基础篇) - 012 Arduino IDE 添加DHT11传感器第三方库的方法

    由于Arduino本身没有DHT 11温湿度传感器的的头文件,单有第三方的库可以给我门使用.方法如下: Step 1:下载地址:https://pan.baidu.com/s/1qYfdBJ2#lis ...

  2. Python学习笔记(十一)—— 函数式编程

    一.函数式编程理念 函数式编程就是一种抽象程度很高的编程范式,纯粹的函数式编程语言编写的函数没有变量,因此,任意一个函数,只要输入是确定的,输出就是确定的,这种纯函数我们称之为没有副作用.而允许使用变 ...

  3. log4j(六)——log4j.properties简单配置样例说明

    一:测试环境与log4j(一)——为什么要使用log4j?一样,这里不再重述 二:老规矩,先来个栗子,然后再聊聊感受 (1)使用配文件的方式,是不是感觉非常的清爽,如果不在程序中读取配置文件就更加的清 ...

  4. mysql常用查询语句

    一.查询指定schema下表的个数 select count(TABLE_NAME) from information_schema.tables where table_schema="d ...

  5. Android之内存泄露、内存溢出、内存抖动分析

      内存   JAVA是在JVM所虚拟出的内存环境中运行的,内存分为三个区:堆.栈和方法区.栈(stack):是简单的数据结构,程序运行时系统自动分配,使用完毕后自动释放.优点:速度快.堆(heap) ...

  6. 利用 PowerShell 分析SharePoint WebApplication 体系结构

    之前一篇文章<两张图看清SharePoint 2013 Farm 逻辑体系结构>谈到Web Application,Content Database,Site Collection的关系. ...

  7. react-创建组件

    //定义组件class InputControlES6 extends React.Component{ render (){ return (<View style="{sty.co ...

  8. hdu 2680 Choose the best route (dijkstra算法)

    题目:http://acm.hdu.edu.cn/showproblem.php?pid=2680 /************************************************* ...

  9. FFmpeg(1)-创建支持FFmpeg的AS项目

    一.新建Android Studio项目 注意点: 1.在“Create Android Project”栏目时,须勾选“Include C++ support” 复选框: 2.在“Customize ...

  10. CAS无锁实现原理以及ABA问题

    CAS(比较与交换,Compare and swap) 是一种有名的无锁算法.无锁编程,即不使用锁的情况下实现多线程之间的变量同步,也就是在没有线程被阻塞的情况下实现变量的同步,所以也叫非阻塞同步(N ...