cad2015+版本可以使用TrayItem气泡显示消息

   static TrayItem trayItem = new TrayItem();
public static void testtrayitem()
{
try
{ //新建一个气泡通知窗口
TrayItemBubbleWindow window = new TrayItemBubbleWindow();
window.Title = "气泡标题";
window.HyperText = "气泡内容连接";
window.Text = "气泡内容";
window.IconType = IconType.Information; Autodesk.AutoCAD.ApplicationServices.Application.StatusBar.TrayItems.Add(trayItem);
trayItem.ShowBubbleWindow(window);
Autodesk.AutoCAD.ApplicationServices.Application.StatusBar.Update();
//气泡窗口关闭事件
//window.Closed += (sender, e) =>
//{
// if (e.CloseReason == TrayItemBubbleWindowCloseReason.HyperlinkClicked)
// {
// System.Windows.MessageBox.Show("关闭气泡消息"); // }
// //气泡窗口关闭后,将托盘从状态栏删除
// //Autodesk.AutoCAD.ApplicationServices.Application.StatusBar.TrayItems.Remove(trayItem);
// //Autodesk.AutoCAD.ApplicationServices.Application.StatusBar.Update();
//};
System.Timers.Timer t = new System.Timers.Timer(10000);
t.Elapsed += new System.Timers.ElapsedEventHandler(Timer_ChangePos);//到达时间的时候执行事件;
t.AutoReset = false;//设置是执行一次(false)还是一直执行(true);
t.Enabled = true;//是否执行System.Timers.Timer.Elapsed事件;
}
catch (System.Exception ex)
{
trayItem.CloseBubbleWindows();
} }
private static void Timer_ChangePos(object sender, System.Timers.ElapsedEventArgs e)
{
trayItem.CloseBubbleWindows();
}

  cad2010+mq+dotnetbar的 DevComponents.DotNetBar.Balloon窗体:

IExtensionApplication接口下:

//为了能及时接收消息
RabbitMQClient mq = new RabbitMQClient();

  public  class RabbitMQClient
{
private string exchangeName = "topic_logs"; //
private string exchangeType = ExchangeType.Topic;//交换机类型
Action<string, Form> SetText;
public RabbitMQClient()
{
if (CommandFun.frmmsg==null)
{
CommandFun.frmmsg = new FrmMsg();
}
ReceiveMsg(CommandFun.frmmsg);
SetText += CommandFun.ShowLoadAlert;
}
public void ReceiveMsg(Form frm)
{
var factory = new ConnectionFactory()
{
HostName = "iporlocalhost",
Port = 端口,
UserName = "administrator",
Password = "密码"
};
try
{ var connection = factory.CreateConnection();
var channel = connection.CreateModel(); channel.ExchangeDeclare(exchangeName, exchangeType);
var queueName = channel.QueueDeclare().QueueName; channel.QueueBind(queueName, exchangeName, "*.*.two");
channel.QueueBind(queueName, exchangeName, "two.#"); var consumer = new EventingBasicConsumer(channel);
consumer.Received += (model, ea) =>
{
var msg = Encoding.UTF8.GetString(ea.Body);
if (msg!=null && msg.ToString().Length>)
{
if (frm == null)
{
frm =CommandFun.frmmsg;
}
frm.Invoke(SetText, msg, frm);
}
};
channel.BasicConsume(queueName, true, consumer);
}
catch (System.Exception ex)
{ }
}
}
接收到消息时调用方法show出窗体:
   public class CommandFun
{
public static FrmMsg frmmsg;//接收到消息
//弹出右下角消息窗口
public static void ShowLoadAlert(string msg, System.Windows.Forms.Form frmmsg)
{
FrmMsg m_AlertOnLoad = new FrmMsg();
Rectangle r = System.Windows.Forms.Screen.PrimaryScreen.WorkingArea;// GetWorkingArea(this);
m_AlertOnLoad.Location = new Point(r.Right - m_AlertOnLoad.Width, r.Bottom - m_AlertOnLoad.Height);
m_AlertOnLoad.AutoClose = true;
m_AlertOnLoad.AutoCloseTimeOut = ;
m_AlertOnLoad.AlertAnimation = eAlertAnimation.BottomToTop;
m_AlertOnLoad.AlertAnimationDuration = ;
m_AlertOnLoad.SetLableText(msg);
m_AlertOnLoad.Show(false);
} }

CommandFun

窗体:

  public partial class FrmMsg : DevComponents.DotNetBar.Balloon
{
public FrmMsg()
{
CheckForIllegalCrossThreadCalls = false;
InitializeComponent();
} public void SetLableText(string msg)
{
lbl_msg.Text = string.Format("{0}\r\n", msg);
}
}

FrmMsg

c#+cad2010+MQ接收消息的更多相关文章

  1. springboot整合mq接收消息队列

    继上篇springboot整合mq发送消息队列 本篇主要在上篇基础上进行activiemq消息队列的接收springboot整合mq发送消息队列 第一步:新建marven项目,配置pom文件 < ...

  2. RocketMQ源码 — 三、 Consumer 接收消息过程

    Consumer pull message 订阅 在Consumer启动之前先将自己放到一个本地的集合中,再以后获取消费者的时候会用到,同时会将自己订阅的信息告诉broker 接收消息 consume ...

  3. MQ(队列消息的入门)

    消息中间件利用高效可靠的消息传递机制进行平台无关的数据交流,并基于数据通信来进行分布式系统的集成,通过提供消息传递和消息排队模型,它可以在分布式环境下拓展进程间的通信,对于消息中间件,常见的角色大致也 ...

  4. RocketMQ源码 — 四、 Consumer 接收消息过程

    Consumer consumer pull message 订阅 在Consumer启动之前先将自己放到一个本地的集合中,再以后获取消费者的时候会用到,同时会将自己订阅的信息告诉broker 接收消 ...

  5. 架构设计:系统间通信(20)——MQ:消息协议(下)

    (接上文<架构设计:系统间通信(19)--MQ:消息协议(上)>) 上篇文章中我们重点讨论了"协议"的重要性.并为各位读者介绍了Stomp协议和XMPP协议. 这两种协 ...

  6. JMS 之 Active MQ 的消息传输

    本文使用Active MQ5.6 一.消息协商器(Message Broker) broke:消息的交换器,就是对消息进行管理的容器.ActiveMQ 可以创建多个 Broker,客户端与Active ...

  7. MQ中将消息发送至远程队列的配置

    MQ中将消息发送至远程队列的配置 摘自MQ资源管理器帮助文档V7 在开始学习本教程之前,您需要从系统管理员处了解标识网络上接收机器的名称:IP地址.MQ的端口号.队列管理器.接收(远程机器)或者是发送 ...

  8. 聊聊mq中消息消费的几种方式

    mq系列文章 对mq了解不是很多的,可以看一下下面两篇文章: 聊聊mq的使用场景 聊聊业务系统中投递消息到mq的几种方式 聊聊消息消费的几种方式 如何确保消息至少消费一次 如何保证消息消费的幂等性 本 ...

  9. ActiveMQ 发送和接收消息

    一.添加 jar 包 <dependency> <groupId>org.apache.activemq</groupId> <artifactId>a ...

随机推荐

  1. vue使用vue-video-player在直播中的应用

    文档地址:https://github.com/savokiss/vue-videojs-demo live demo地址:https://github.com/savokiss/vue-videoj ...

  2. python中shutil模块的使用

    可以操作权限的处理文件模块:shutil # 基于路径的文件复制 import shutil shutil.copyfile("oldfile_path","newfil ...

  3. 8th week blog

    1.indexof() indexOf()的用法:返回字符中indexof(string)中字串string在父串中首次出现的位置,从0开始,没有返回-1:方便判断和截取字符串!indexOf()定义 ...

  4. 剑指offer7~10题

    斐波那契数列 大家都知道斐波那契数列,现在要求输入一个整数n,请你输出斐波那契数列的第n项. n<=39 思路:此题用递归会超内存,故直接循环. 代码: class Solution { pub ...

  5. Linux 系统的用户和组

    目录 1. 用户及组相关文件 2. 用户相关查询 2.1 直接通过cat文件查看用户及组文件内容 2.2 使用下面查询命令查看 3. 使用操作命令修改用户及组相关文件 3.1 专有编辑命令(仅限高级用 ...

  6. 继续写java和socket

    上回书说道,java中通过socket链接的两台计算机可以通过两端的两个Socket对象来读取和发送来自流的信息所以对于客户端和服务端只需要封装一个相同的收发信息的窗口就好 代码如下 package ...

  7. 【mysql-server】遇到的坑

    一.前提 最近因为工作原因,不得不用windows电脑,发现windows装mysql真的坑太多 23333: 二.环境 windows 环境 mysql 5.7(不建议用5.8坑更多) 三.步骤 3 ...

  8. [双系统linux] ----双系统切换导致系统时间错误

    安装了linux双系统以后,发现每次双系统切换以后系统时间总会错误. 原因:Linux和win7(win10)双系统时间错误问题 时间相差8小时 MAC/linux 将系统硬件时间看待为UTC, 即U ...

  9. dataframe基础

    1 df[i]   其中i是0,1,2,3,...  此时选中的是dataframe的第i列 2 dataframe查看每一列是否有缺失值 temp = data.isnull().any() #列中 ...

  10. flagr a/b 测试特性开关&&微服务动态配置工具

    flagr a/b 测试特性开关&&微服务动态配置工具 简单运行 docker docker run -it -p 18000:18000 checkr/flagr 运行界面 说明 参 ...