(已解决) Github无法显示图像问题

Github无法显示图像的问题

问题描述

今天打开github,创建了一个仓库,想从本地把一些最近做的东西传上来(git add . => git commit -m “xxx” => git push),结果发现东西是成功传上来了,但是图片没有显示出来,如下图所示:
在这里插入图片描述

这就让我很迷惑,于是有了以下初步尝试

初次尝试

首先我寻思着可能是路径错了?,然后分别尝试了相对路径和绝对路径,结果发现并么有什么用,然后我说打开控制台(F12)看看会不会有什么报错,结果你猜怎么着:
在这里插入图片描述
真就是报错了,然后经过我一系列度娘大法——
参考一:【小技巧】(超详细!)解决Github无法显示图片以及README无法显示图片
参考二:解决Github上网页图片显示失败的问题
参考三:github上的图片看不了,教你解决

最终解决

综合了上面三篇参考的博客,我把解决步骤简单的总结为了以下三步:
1、使用ipaddress查询raw.githubusercontent.com当前的ip地址(注意:这个ip是会变化的,需要根据查询结果自行选择)
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
任选其一即可

2、然后将其复制在电脑的hosts注册表中:我的文件在——C:\Windows\System32\drivers\etc下(Notepad++管理员打开),添加内容为两行,分别是:


185.199.108.133 githubusercontent.com
185.199.108.133 raw.githubusercontent.com

在这里插入图片描述

3、然后刷新ip映射 => cmd => 输入 ipconfig/flush
在这里插入图片描述
最后打开github,大功告成!!!
在这里插入图片描述

  • 3
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
好的,我将尽力帮助你完成这个项目。首先,我们需要了解一些基础知识。 Qt是一个跨平台的C++图形用户界面应用程序开发框架,它提供了一套完整的GUI编程解决方案。在本项目中,我们将使用Qt来创建一个图像绘制器。 功能概述: 1.输入函数表达式:用户可以在输入框中输入函数表达式。 2.确认键:点击后生成此时函数输入框中的函数的图像在widget中,图像可以叠加,如果输入的函数格式不对,将不会生成图像。 3.图像显示图像显示在widget控件内,要有坐标轴,大小合适。 4.清除键:点击后可以清除widget生成的所有函数图像。 5.保存键:点击后可以保存此时widget上的图像为jpg格式,并且可以自行选择保存地址。 6.按钮:设置几个按钮,这些按钮代表一些常见的函数符号比如sin,cos,tan,log,ln等,点击这些按钮可以在函数输入框中添加这些符号。 步骤: 1.创建一个Qt Widgets Application,并命名为“FunctionGraphDrawer”。 2.在Qt Creator的菜单栏中,选择“File”->“New File or Project”->“C++”->“C++ Source File”,命名为“functionparser.cpp”。 3.在functionparser.cpp中编写一个函数解析器,用于将字符串转换为可计算的函数。我们可以使用第三方库“ExprTk”来帮助我们完成这个任务。ExprTk是一个快速的C++数学表达式解析库,具有高度可定制性和灵活性。你可以在此处下载ExprTk库:https://github.com/ArashPartow/exprtk。将库文件解压缩后,将其复制到FunctionGraphDrawer文件夹中。然后,在Qt Creator的“Projects”面板中,为项目添加ExprTk库,方法是右键单击项目,选择“Add library”,然后选择“External Library”,并选择ExprTk库的路径。 4.在FunctionGraphDrawer的mainwindow.cpp文件中,添加一个QLineEdit组件,并为其添加一个QValidator,以确保用户输入的函数表达式是有效的。代码如下: ```cpp #include "mainwindow.h" #include "ui_mainwindow.h" #include "functionparser.h" // 引入functionparser头文件 #include <QLineEdit> #include <QRegExpValidator> MainWindow::MainWindow(QWidget *parent) : QMainWindow(parent) , ui(new Ui::MainWindow) { ui->setupUi(this); // 创建 QLineEdit 组件 QLineEdit* functionEdit = new QLineEdit(this); functionEdit->setPlaceholderText("Input a function here"); // 为 QLineEdit 组件添加 QRegExpValidator QRegExpValidator* validator = new QRegExpValidator(QRegExp("^[a-zA-Z0-9+\\-*/()\\^\\. ]*$"), functionEdit); functionEdit->setValidator(validator); // 将 QLineEdit 组件添加到 UI 中 ui->verticalLayout->addWidget(functionEdit); } ``` 5.在FunctionGraphDrawer的mainwindow.ui文件中,将QLineEdit组件放置在垂直布局中。 6.在mainwindow.cpp文件中添加一个QPushButton组件,并将其与一个槽函数相连,该槽函数将解析用户输入的函数表达式,并将其绘制到widget上。代码如下: ```cpp void MainWindow::on_drawButton_clicked() { QString function = ui->functionEdit->text(); // 使用 functionparser 解析函数表达式 FunctionParser parser; parser.Parse(function.toStdString()); // 绘制函数图像 DrawFunction(parser); } void MainWindow::DrawFunction(const FunctionParser& parser) { // 在widget上绘制函数图像 // ... } ``` 7.我们需要在widget上绘制函数图像。我们可以使用Qt的绘图功能来实现这一点。在MainWindow类中添加一个QPainter组件,并重写paintEvent函数以绘制坐标轴和函数图像。代码如下: ```cpp void MainWindow::paintEvent(QPaintEvent* event) { QMainWindow::paintEvent(event); QPainter painter(this); painter.setRenderHint(QPainter::Antialiasing, true); // 绘制坐标轴 DrawCoordinateSystem(painter); // 绘制函数图像 // ... } void MainWindow::DrawCoordinateSystem(QPainter& painter) { painter.setPen(Qt::black); painter.drawLine(50, height() - 50, width() - 50, height() - 50); // x 轴 painter.drawLine(50, height() - 50, 50, 50); // y 轴 // 绘制坐标轴刻度 int xInterval = (width() - 100) / 10; int yInterval = (height() - 100) / 10; for (int i = 1; i < 10; i++) { painter.drawLine(50 + i * xInterval, height() - 45, 50 + i * xInterval, height() - 55); // x 轴刻度 painter.drawLine(45, height() - 50 - i * yInterval, 55, height() - 50 - i * yInterval); // y 轴刻度 } } ``` 8.在DrawFunction函数中,我们需要计算函数在每个x坐标处的值,并将结果绘制到widget上。代码如下: ```cpp void MainWindow::DrawFunction(const FunctionParser& parser) { QPainter painter(this); painter.setRenderHint(QPainter::Antialiasing, true); // 计算函数在每个x坐标处的值 QVector<QPointF> points; double xMin = 0; double xMax = width() - 100; for (double x = xMin; x <= xMax; x += 0.5) { double y = parser.Eval(x); points.append(QPointF(50 + x, height() - 50 - y)); } // 绘制函数图像 painter.setPen(Qt::red); painter.drawPolyline(points); } ``` 9.添加清除按钮。在mainwindow.cpp中添加一个QPushButton组件,并将其与一个槽函数相连,该槽函数将清除widget上的所有函数图像。代码如下: ```cpp void MainWindow::on_clearButton_clicked() { // 清除widget上的所有函数图像 // ... } ``` ```cpp void MainWindow::ClearFunctions() { // 清除widget上的所有函数图像 // ... } ``` 10.添加保存按钮。在mainwindow.cpp中添加一个QPushButton组件,并将其与一个槽函数相连,该槽函数将保存widget上的图像为jpg格式,并允许用户选择保存路径。代码如下: ```cpp void MainWindow::on_saveButton_clicked() { QString fileName = QFileDialog::getSaveFileName(this, "Save Image", "", "JPEG (*.jpg)"); if (!fileName.isNull()) { QPixmap pixmap = this->grab(); pixmap.save(fileName); } } ``` 11.添加常见函数按钮。在mainwindow.cpp中添加多个QPushButton组件,并将其与一个槽函数相连,该槽函数将在函数输入框中添加相应的函数符号。代码如下: ```cpp void MainWindow::on_sinButton_clicked() { ui->functionEdit->insert("sin()"); } void MainWindow::on_cosButton_clicked() { ui->functionEdit->insert("cos()"); } void MainWindow::on_tanButton_clicked() { ui->functionEdit->insert("tan()"); } void MainWindow::on_logButton_clicked() { ui->functionEdit->insert("log()"); } void MainWindow::on_lnButton_clicked() { ui->functionEdit->insert("ln()"); } ``` 12.最后,我们需要告诉用户函数输入框内支持的函数格式。在UI中添加一个QLabel组件,并将其放置在函数输入框下方。代码如下: ```cpp MainWindow::MainWindow(QWidget *parent) : QMainWindow(parent) , ui(new Ui::MainWindow) { ui->setupUi(this); // 创建 QLineEdit 组件 QLineEdit* functionEdit = new QLineEdit(this); functionEdit->setPlaceholderText("Input a function here"); // 为 QLineEdit 组件添加 QRegExpValidator QRegExpValidator* validator = new QRegExpValidator(QRegExp("^[a-zA-Z0-9+\\-*/()\\^\\. ]*$"), functionEdit); functionEdit->setValidator(validator); // 将 QLineEdit 组件添加到 UI 中 ui->verticalLayout->addWidget(functionEdit); // 创建 QLabel 组件 QLabel* formatLabel = new QLabel(this); formatLabel->setText("Supported formats: sin(), cos(), tan(), log(), ln(), +, -, *, /, ^, (, )"); formatLabel->setAlignment(Qt::AlignCenter); // 将 QLabel 组件添加到 UI 中 ui->verticalLayout->addWidget(formatLabel); } ``` 至此,我们已经完成了这个项目。完整的代码如下:

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Liuyc-Code boy

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值