QT应用编程: 保存指定控件的数据到剪切板和本地文件

举报
DS小龙哥 发表于 2021/12/09 23:09:24 2021/12/09
【摘要】 一、环境介绍 操作系统介绍:win10 64位 QT版本: 5.12.6 二、保存指定控件的数据到剪切板和本地文件 #include <QMenu>#include <QApplication>#include <QClipboard> Widget::Widget(QWidget *pare...

一、环境介绍

操作系统介绍:win10 64位

QT版本: 5.12.6

二、保存指定控件的数据到剪切板和本地文件


      #include <QMenu>
      #include <QApplication>
      #include <QClipboard>
      Widget::Widget(QWidget *parent)
          : QWidget(parent)
          , ui(new Ui::Widget)
      {
          .....................................
         //添加菜单
          image_menu=new QMenu;
          QAction* action_save_buff; //QAction 可以同时出现在菜单和工具条上的抽象用户界面操作
          action_save_buff=image_menu->addAction("保存到剪切板");
         //关联点击信号
         connect(action_save_buff,SIGNAL(triggered(bool)),this,SLOT(SaveImageToClipboard(bool)));
          action_save_buff=image_menu->addAction("保存到文件");
         //关联点击信号
         connect(action_save_buff,SIGNAL(triggered(bool)),this,SLOT(SaveImageToFile(bool)));
          ui->toolButton_save_image->setMenu(image_menu);
         /*当按下工具按钮时,将毫不延迟地显示菜单。在这种模式下,按钮本身的动作不会被触发.*/
          ui->toolButton_save_image->setPopupMode(QToolButton::InstantPopup);
      }
      Widget::~Widget()
      {
         delete ui;
      }
      /**
       * @brief Widget::SaveImageToFile
       * 保存图片到文件
       */
      void Widget::SaveImageToFile(bool flag)
      {
         qDebug()<<"保存图片到文件";
          QString filename=QFileDialog::getSaveFileName(this,"保存到文件","C:/imagefile.jpg",tr("*.bmp *.jpg *.png *.*"));
         if(filename.isEmpty())return;
         //获取窗口图像数据保存为图片文件
          QPixmap pix=ui->widget_VideoDisplay->grab();
          pix.save(filename);
      }
      /**
       * @brief Widget::SaveImageToClipboard
       * 保存图片到剪切板
       */
      void Widget::SaveImageToClipboard(bool flag)
      {
         //获取widget控件的数据
          QPixmap pix = ui->widget_VideoDisplay->grab();
         //保存到剪切板
          QApplication::clipboard()->setPixmap(pix);
      }
  
 

 

 

 

文章来源: xiaolong.blog.csdn.net,作者:DS小龙哥,版权归原作者所有,如需转载,请联系作者。

原文链接:xiaolong.blog.csdn.net/article/details/110858995

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。