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. 纯粹的python绑定

    目前很多学习资料这样解释赋值与绑定,当是一个简单变量时,是赋值,当是复合变量时,是绑定. 注:赋值是重新复制变量到新变量中,赋值前后两个变量之间无联系.例C语言中: int a=6: int b: b ...

  2. 【Linux】comm指令

    语法 comm [-123][--help][--version][第1个文件][第2个文件] 参数 -1 不显示只在第1个文件里出现过的列 -2 不显示只在第2个文件里出现过的列 -3 不显示只在第 ...

  3. SpringBoot实现跨域

    一.什么是跨域请求? 跨域请求,就是说浏览器在执行脚本文件的ajax请求时,脚本文件所在的服务地址和请求的服务地址不一样.说白了就是ip.网络协议.端口都一样的时候,就是同一个域,否则就是跨域.这是由 ...

  4. 游戏 & Github Page

    1. snakewizard.github.io 贪吃蛇小游戏 2. mattbasile.github.io 龙珠 DragonballZ-Battle 3. nathandhyou.github. ...

  5. 装了anaconda之后如何设置anaconda、python环境变量

    装了anaconda之后如何设置anaconda.python环境变量 1.装了anaconda之后如何设置anaconda环境变量 参考 https://www.cnblogs.com/avivi/ ...

  6. 实验十 ZStack 网状网络实验

    实验十 ZStack 网状网络实验[实验目的]1. 了解 ZigBee 网状网络结构2. 掌握构建网状网络的方法[实验设备]1. 装有 IAR 开发工具的 PC 机一台2. 实验箱一台3. CCDeb ...

  7. 兄弟连学python---网络简介

    网络简介 1.什么是网络 网络是辅助双方能够连接在一起的工具 使用网络的目的 为了联通多方然后进行通讯,能够让软件在不同的电脑上运行,相互传输数据 网络的发展 网络协议 什么是协议 约定俗成的,没有理 ...

  8. 6. Vulnerability scanners (漏洞扫描器 11个)

    Nessus是最流行和最有能力的漏洞扫描程序之一,特别为UNIX系统. 它最初是免费的和开源的,但是他们在2005年关闭了源代码,并在2008年删除了免费的“注册Feed”版本.现在要每年花费2,19 ...

  9. C++跨平台集成websocketpp

    之前给公司写了一个用于消息交互的服务器,移植到Linux上之后发现H5-Websocket模块经常出问题,而该模块是另一位已经离职同事编写的,所以修改和维护都存在一定的困难,索性就直接把这个模块替换掉 ...

  10. java单例设计模式总结及举例

    * 设计模式:前人总结出来的经验,被后人直接拿来使用. * 单例设计模式:一个类只允许有一个对象,将这个对象作为一个全局的访问点,提供出去供大家使用. * 分析: * 1.用户只能有一个对象 * 2. ...