简单的实现QQ通信功能(五)

第五部分:聊天界面的设计及代码

一:效果图及界面设计

1. 效果图:

2. 界面设计:

(1)左上角显示朋友的头像和“某某正在和某某聊天”。

(2)中间的聊天窗口用了一个ListView,视图用详细信息Details,设置了一列用来显示主项,只用了其中的主项(里面加载头像和需要显示的信息及消息内容),没有设置子项信息。

(3)TextBox用来写消息。

(4)一个发送的Button。

(5)界面用Dock布局。

(6)imageList1里面放用户的ico图标,imageList2放用户头像,时钟timer1来查询显示聊天消息内容。

3. 用到的各个控件的名称:

聊天内容显示窗口chatwindow,写信息文本框senderword,发送按钮btnsender

二:代码设计:

       private string _Friendname;

        public string Friendname
        {
            get { return _Friendname; }
            set { _Friendname = value; }
        }
        private string _Mename;

        public string Mename
        {
            get { return _Mename; }
            set { _Mename = value; }
        }
        public Chat()
        {
            InitializeComponent();
        }
        //构造函数重载
        public Chat(string friendname,string mename)
            : this()
        {
            _Friendname = friendname;
            _Mename = mename;
        }
        //加载
        private void Chat_Load(object sender, EventArgs e)
        {
            //加载左上角的ico及显示文字
            UsersTableAdapter adp = new UsersTableAdapter();
            qqdata.UsersDataTable table = adp.GetDataByUsername(_Friendname);
            Bitmap a = (Bitmap)imageList1.Images[table[0].PhotoCode-1];

            this.Icon = System.Drawing.Icon.FromHandle(a.GetHicon());

            this.Text = getmemoname(_Mename) + "正在和" + getmemoname(_Friendname) + "聊天";
        }
        //根据用户名获取昵称的方法
        private string getmemoname(string name)
        {
            UsersTableAdapter adp1 = new UsersTableAdapter();
            qqdata.UsersDataTable tab = new qqdata.UsersDataTable();
            tab = adp1.GetDataByUsername(name);

            return tab[0].Memo;
        }

        //按下发送键
        private void btnsender_Click(object sender, EventArgs e)
        {
            string nr = senderword.Text;
            DateTime sj = DateTime.Now;

            //将自己发送的聊天内容,时间传到数据库
            new ChatTableAdapter().InsertChat(_Mename,_Friendname,nr,sj,0);
            senderword.Text = "";

            //将自己发送的内容直接显示出来,添加显示(非绑定)
            qqdata.UsersDataTable tab = new UsersTableAdapter().GetDataByUsername(_Mename);
            //造主项
            ListViewItem item = new ListViewItem();
            //设置主项信息
            item.Text = getmemoname(_Mename) + sj.ToString() + "说:" + nr;
            item.ImageIndex = tab[0].PhotoCode - 1;
            chatwindow.Items.Add(item);
        }

        //时间控件循环查
        private void timer1_Tick(object sender, EventArgs e)
        {
            //数据库内查找此朋友发来的未读消息,添加显示出来,显示完设置已读
            qqdata.ChatDataTable tab2 = new ChatTableAdapter().GetDataBySenderAndReceiver(_Friendname,_Mename,0);

            foreach (qqdata.ChatRow row in tab2.Rows)
            {
                qqdata.UsersDataTable tab = new UsersTableAdapter().GetDataByUsername(row.Sender);
                //造主项
                ListViewItem item = new ListViewItem();
                //设置主项信息
                item.Text = getmemoname(row.Sender) + row.Time.ToString() + "说:" + row.Content;
                item.ImageIndex = tab[0].PhotoCode - 1;
                //标记为已读
                if (row.Sender == _Friendname)
                {
                    new ChatTableAdapter().UpdateState(1, row.Ids);
                }

                chatwindow.Items.Add(item);
            }

        }
        //窗体关闭的时候给N赋值为0,控制自定义控件头像在聊天关闭后来消息提醒
        private void Chat_FormClosed(object sender, FormClosedEventArgs e)
        {
            Friendsmode.N = 0;
        }
时间: 2024-12-17 15:05:27

简单的实现QQ通信功能(五)的相关文章

简单的实现QQ通信功能(二)

第二部分:功能需求以及大体思路 一:功能需求: 1. 角色:登录用户. 2. 登录: (1)检查用户名和密码是否正确,正确登录成功,否则提醒用户名或密码错误. (2)登录时可以选择登录状态,送入数据库. (3)记录登录时间,送入数据库. 3. 登录成功之后显示所有的好友信息: (1)分类列出所有好友的信息(带头像). (2)如果有未读的信息,则给提示. (3)来新消息提醒. 4. 主界面功能: (1)显示登录者自己的信息. (2)可以修改自己的状态. (3)最小化之后在右下角显示小图标,双击小图

简单的实现QQ通信功能(三)

第三部分:登陆界面的设计及代码 一:效果图及界面设计 1. 效果图: 2. 界面设计: (1)仿照QQ的登陆界面,右上角放了三个Label,用来做关闭.最小化和设置,使用了它们的Click事件当做按钮用. (2)上面是一个pictureBox放一个图片. (3)下面用tableLayoutPanel布局. (4)tableLayoutPanel左侧图片和图片右下角的在线图放在一个Panel里,这个Panel占3行. (5)用户名用ComboBox,密码框用TextBox,登陆用了个Button.

简单的实现QQ通信功能(四)

第四部分:主界面的设计及代码 一:效果图及界面设计 1. 效果图: 2. 界面设计: (1)上面显示自己信息用一个PictureBox和两个Label,用来显示自己的头像和昵称备注名. (2)下面用了一个FlowLayoutPanel来显示好友列表,FlowDirection设置为TopDown,从上到下流式布局. (3)下面一个ComboBox用来选择自己的状态. (4)一个imageList3存放用户头像,根据登录者的头像代号进来选择需要的头像. (5)一个notifyIcon1来设置任务栏

简单的实现QQ通信功能(一)

第一部分:数据库的设计,数据集的建立 一:数据库的设计: 1.用户表:包含用户名.密码.昵称.性别.备注.状态.头像代号和最后登录时间. 2.朋友关系表:自增长列为主键列,用户名和好友名,还有朋友的状态. 3.聊天内容表:自增长列为主键列,发送者和接收者,中间有聊天内容和发送时间,还有一个标记未读已读的状态. 4. 用户状态表:用户状态表主要是有用户状态和状态名字. 5. SQL数据库内用用查询建立这几个表: use mydb go create table Users ( UserName v

经测试稳定可用的蓝牙链接通信Demo,记录过程中遇到的问题的思考和解决办法,并整理后给出一个Utils类可以简单调用来实现蓝牙功能

说明:这是本人在蓝牙开发过程中遇到过的问题记录和分析,以及解决办法. 在研究过程中,许多的前人给出的解决方案和思路指导对我相当有帮助,但并非都是可采取的解决方法, 经过本人对这些方法的测试和使用过后,给出自己的理解和解决方案,不一定是正确的,但这些方法的确可以解决问题. 如果有人遇到同样的问题,并且看到我的文章解决,那是我的荣幸. !!!!!!但特别需要说明的是,看的越多,不明白的越多,我的看法可能是完全错误的,这些方法只是暂时解决了我的问题, !!!!!!如果有人发现了我的错误,请私信或评论告

Android借用QQ开放平台,简单实现联系客服功能

公司做的电商APP,现在要加入联系客服功能,起初想的是做一个即时聊天系统,以前没做过,这两天开始恶补,后来需求变了,改成调用QQ开放平台,做一个临时会话就行了,这就省了不少力气,也不需要再去组件服务端了. 步骤: 1.引用QQ SDK源码文件. 创建一个工程,并把open-sdk.jar文件和mta_sdk_x.x.x.jar文件拷贝到libs(或lib)目录下,如下图所示: 选中open-sdk.jar和mta_sdk_x.x.x.ja,右键菜单中选择Build Path, 选择Add to 

QQ 通信原理分析(转)

之前写过一个简单的IM,当时遇到过各种令人崩溃的问题:事后也没有做很好的总结,现在看到这篇文章,感慨良多,特此转摘过来,以做备忘. 出处:http://blog.csdn.net/lxnkobe/article/details/7521331 下面有4个基本的问答: 问题一:为什么只要可以连上互联网的计算机都可以用QQ相互建立通信,而不需要固定IP?也就是这个QQ用户端是怎样找到另一个QQ用户的,而用户在每次使用时他可能用的是不同的计算机,有着不同的IP地址.服务器端不会以qq用户端的ip作为唯

jsp+servlet+mysql 实现简单的银行登录转账功能

jsp+servlet+mysql 实现简单的银行登录转账功能 [前期的准备] html(登录界面),servlet(处理业务逻辑),jsp(主要实现界面),mysql(实现与数据库的简单的交互)先从一个登录页面开始(利用表单提交,action="jsp实现页面")第一步:在(mysql)数据库中建表:建立一个用户的基本信息表(用户姓名,密码,账户余额),用户转账(用户名,转账金额)的操作表第二步:登录页面:输入用户名和密码对数据库中的用户信息(login.jsp)进行验证(qq浏览器

Android UI之自定义——最简单的仿QQ音乐歌词颜色渐变

Android UI之自定义--最简单的仿QQ音乐歌词颜色渐变 记得刚开始做android的时候,就发现QQ音乐歌词颜色渐变的效果,就在网上搜索过,但是就是没有找到满意的.今天突然用QQ音乐听歌的时候,看到歌词颜色渐变,决定来分析看看,没想到实现原来如此简单.这篇只是将最简单的歌词颜色渐变功能,不包括歌词滚动等效果. 首先来看下QQ音乐歌词界面 实现步骤 从界面上可以看出,是通过不同颜色的文本叠加所形成的视觉效果.那么android文本一般使用TextView实现,那就来试试用TextView在