tchar的显示问题

dlam128 2013-04-25 03:25:19
如图:

点击“增加”按钮,Tchar的X轴 会增加左侧表格(DBGridEh)里的科室。
传入Tchar的参数: name:= dbg.DataSource.DataSet.fieldbyname('dept_name').AsString.


主要是 Tchar 的显示问题!
X轴:显示科室(我增加的)。

Y轴:显示的是 sum:=ADOquery1.RecordCount的数值。


柱状图:上面的黄色标记就是
该科室 sum:=ADOquery1.RecordCount的数值。

点击一次增加===》在X轴上增加一个选中科室及其柱状图。在点击就又增加一个选中科室。

点击一次删除===》在X轴上删除上一次增加的。


网上的Tchar资料太少了……实在是搞不懂了。求大神指教
...全文
130 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
dlam128 2013-04-27
  • 打赏
  • 举报
回复
引用 6 楼 SmallHand 的回复:
[quote=引用 5 楼 feiba7288 的回复:]

ADOQuery1.Close;
DBChart1.Legend.Visible:=False;
with DBChart1.SeriesList.Series[0] do begin
 DataSource := ADOQuery1;
 XLabelsSource := ADOQuery1Company.FieldName;
 XValues.ValueSource := ADOQuery1SumItems.FieldName;
 YValues.ValueSource := '';
 Marks.Style := smsXValue;
 CheckDataSource;
end; //with
with DBChart1.SeriesList.Series[1] do begin
 DataSource := ADOQuery1;
 XLabelsSource := '';
 XValues.ValueSource := ADOQuery1NumOrders.FieldName;
 YValues.ValueSource := '';
 CheckDataSource;
end; //with

ADOQuery1.Open;
参考下这两个链接: http://delphi.about.com/od/usedbvcl/l/aa082101b.htm http://hi.baidu.com/lovejin1988/item/9dab55f42330975bc9f33792
提供的答案很到位, 但基本的原理是你使用查询做好数据源,然后直接设置关联就可以的。[/quote] 谢谢两位了,DELPHI里面自带了demo ,通过那个demo我基本知道怎么处理我的问题了……现在看看,觉得这个问题问的好弱智……
feiba7288 2013-04-26
  • 打赏
  • 举报
回复

ADOQuery1.Close;
DBChart1.Legend.Visible:=False;
with DBChart1.SeriesList.Series[0] do begin
DataSource := ADOQuery1;
XLabelsSource := ADOQuery1Company.FieldName;
XValues.ValueSource := ADOQuery1SumItems.FieldName;
YValues.ValueSource := '';
Marks.Style := smsXValue;
CheckDataSource;
end; //with
with DBChart1.SeriesList.Series[1] do begin
DataSource := ADOQuery1;
XLabelsSource := '';
XValues.ValueSource := ADOQuery1NumOrders.FieldName;
YValues.ValueSource := '';
CheckDataSource;
end; //with

ADOQuery1.Open;


参考下这两个链接:
http://delphi.about.com/od/usedbvcl/l/aa082101b.htm
http://hi.baidu.com/lovejin1988/item/9dab55f42330975bc9f33792
火龙岛主 2013-04-26
  • 打赏
  • 举报
回复
引用 5 楼 feiba7288 的回复:

ADOQuery1.Close;
DBChart1.Legend.Visible:=False;
with DBChart1.SeriesList.Series[0] do begin
 DataSource := ADOQuery1;
 XLabelsSource := ADOQuery1Company.FieldName;
 XValues.ValueSource := ADOQuery1SumItems.FieldName;
 YValues.ValueSource := '';
 Marks.Style := smsXValue;
 CheckDataSource;
end; //with
with DBChart1.SeriesList.Series[1] do begin
 DataSource := ADOQuery1;
 XLabelsSource := '';
 XValues.ValueSource := ADOQuery1NumOrders.FieldName;
 YValues.ValueSource := '';
 CheckDataSource;
end; //with

ADOQuery1.Open;
参考下这两个链接: http://delphi.about.com/od/usedbvcl/l/aa082101b.htm http://hi.baidu.com/lovejin1988/item/9dab55f42330975bc9f33792
提供的答案很到位, 但基本的原理是你使用查询做好数据源,然后直接设置关联就可以的。
dlam128 2013-04-25
  • 打赏
  • 举报
回复
引用 3 楼 feiba7288 的回复:
设置Data Source:
引用 3 楼 feiba7288 的回复:
设置Data Source:
X轴:选中DBGIRDEH 里面的科室名称 ===> name。 series的Y的值:对应的 count(id)数值 ===>select count(id) from XXXXX where ks_name=name。 Y轴:ADOQUERY1.RecordCount。 这个 怎么处理…… ADOQUERY1.sql的语句怎么写
feiba7288 2013-04-25
  • 打赏
  • 举报
回复
设置Data Source:
dlam128 2013-04-25
  • 打赏
  • 举报
回复
引用 1 楼 feiba7288 的回复:
你用的DBChart,每次增加和删除都重新刷新DBChart对应的DataSet,也就是重新查询DBChart对应的数据。 按你的逻辑是要显示每个科室的病人数吧?DBChart的SQL应该是select dept_id, dept_name, count(1) from Table a, dept_table b where a.dept_id = b.dept_id ……
是显示的病人数量,这个sql语句也有。 现在是不会用Tdbchar…… X坐标轴 Y坐标轴 都不会设置。
feiba7288 2013-04-25
  • 打赏
  • 举报
回复
你用的DBChart,每次增加和删除都重新刷新DBChart对应的DataSet,也就是重新查询DBChart对应的数据。 按你的逻辑是要显示每个科室的病人数吧?DBChart的SQL应该是select dept_id, dept_name, count(1) from Table a, dept_table b where a.dept_id = b.dept_id group by dept_id, dept_name
VC获得进程ID获得主线程ID获得窗口句柄获得主窗口获得进程名 1.窗口类名 窗口句柄 窗口标题 窗口句柄 HWND FindWindow( LPCTSTR lpClassName, //窗口类名 可用 VC或者VS自带的Spy++查看 LPCTSTR lpWindowName //窗口标题 ); 举例: 以 记事本为例, 记事本 窗口类名 为:NotePad, 窗口标题 视按具体情况而定,假设为"新建 文本文档.txt - 记事本" 窗口类名 窗口句柄 TCHAR lpClassName[]=TEXT("NotePad"); HWND hWnd=::FindWindow(lpClassName,NULL); if(hWnd && IsWindow(hWnd)) ::ShowWindow(hWnd,SW_HIDE); 窗口标题 窗口句柄 TCHAR lpWindowName[]=TEXT("新建 文本文档.txt - 记事本"); HWND hWnd=::FindWindow(NULL,lpWindowName); if(hWnd && IsWindow(hWnd)) ::ShowWindow(hWnd,SW_HIDE); 2.窗口句柄 进程ID 窗口句柄 主线程ID 要使用到的函数: DWORD GetWindowThreadProcessId( HWND hWnd, //目标窗口句柄 LPDWORD lpdwProcessId //返回目标窗口对应进程ID ); 例子: DWORD dwProcId=0;//存放返回的进程ID DWORD dwThreadId=0;//存放返回的主线程ID HWND hWnd=XXXX;//这里省略,可能用任务方式得到一个窗口的句柄.比如用1中的方法. dwThreadId=GetWindowThreadProcessId(hWnd,&dwProcId);//同时得到进程ID和主线程ID. 3.窗口HAND CWnd 用CWnd::FromHandle(HWND hWnd)函数.很多类都有这个函数. 4.进程名 进程ID (注:进程名,即在"任务管理器"中看到的名字) 用CCheckObject类(详细实现源文件); 例子: 以记事本为例,进程名为 NOTEPAD.EXE (不一定是大写哦,得到任务管理器是显示而定); CCheckObject ch; TCHAR Name[]=TEXT("NOTEPAD.EXE"); DWORD dwProcId=ch.GetProcessId(Name); 5. 进程名 主线程ID 例子: CCheckObject ch; TCHAR Name[]=TEXT("NOTEPAD.EXE"); DWORD dwThreadId=ch.GetThreadId(Name); 6. 进程名 主窗口句柄 CCheckObject ch; TCHAR Name[]=TEXT("NOTEPAD.EXE"); HWND hWnd=ch.GetTargetWindowHanle(Name); 7. 其它说明 从CCheckObject类和上面的源码中,不难写出从 进程ID 主线程ID 进程ID 主窗口句柄 主线程ID--->主窗口句柄 等等其它类似转换. 对于主窗口,特点如下: A. 不能用进程ID,要用线程ID,因为一个进程可能有多个线程,每个线程都可能会有主窗口. B. 主窗口不会有WS_CHILD属性 C. 主窗口没有父窗口 D. 主窗口一般都有子窗口(这个不是一定的,但是具有普遍性)

5,388

社区成员

发帖
与我相关
我的任务
社区描述
Delphi 开发及应用
社区管理员
  • VCL组件开发及应用社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧