OpenGL--恒星,卫星,行星系统

2023-10-30 03:59

本文主要是介绍OpenGL--恒星,卫星,行星系统,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

为了方便,先用金字塔,正方体,小正方体代替恒星,卫星,行星。
并用矩阵堆栈的形式实现。
在这里插入图片描述

#include <GL\glew.h>
#include <GLFW\glfw3.h>
#include <string>
#include <iostream>
#include <fstream>
#include <cmath>
#include <stack>
#include <glm\glm.hpp>
#include <glm\gtc\type_ptr.hpp> // glm::value_ptr
#include <glm\gtc\matrix_transform.hpp> // glm::translate, glm::rotate, glm::scale, glm::perspective
#include "Utils.h"
using namespace std;#define numVAOs 1
#define numVBOs 2float cameraX, cameraY, cameraZ;//视图矩阵,相机位置
GLuint renderingProgram;
GLuint vao[numVAOs];
GLuint vbo[numVBOs];// 分配在display()函数中使用的变量空间,这样它们就不必在渲染过程中分配
GLuint mvLoc, projLoc;
int width, height;
float aspect;
glm::mat4 pMat, vMat, mMat, mvMat;stack<glm::mat4>mvStack;void setupVertices(void) {//正方体//36个顶点,12个三角形,组成了放置在原点处的2×2×2立方体float vertexPositions[108] = {-1.0f,  1.0f, -1.0f, -1.0f, -1.0f, -1.0f, 1.0f, -1.0f, -1.0f,1.0f, -1.0f, -1.0f, 1.0f,  1.0f, -1.0f, -1.0f,  1.0f, -1.0f,1.0f, -1.0f, -1.0f, 1.0f, -1.0f,  1.0f, 1.0f,  1.0f, -1.0f,1.0f, -1.0f,  1.0f, 1.0f,  1.0f,  1.0f, 1.0f,  1.0f, -1.0f,1.0f, -1.0f,  1.0f, -1.0f, -1.0f,  1.0f, 1.0f,  1.0f,  1.0f,-1.0f, -1.0f,  1.0f, -1.0f,  1.0f,  1.0f, 1.0f,  1.0f,  1.0f,-1.0f, -1.0f,  1.0f, -1.0f, -1.0f, -1.0f, -1.0f,  1.0f,  1.0f,-1.0f, -1.0f, -1.0f, -1.0f,  1.0f, -1.0f, -1.0f,  1.0f,  1.0f,-1.0f, -1.0f,  1.0f,  1.0f, -1.0f,  1.0f,  1.0f, -1.0f, -1.0f,1.0f, -1.0f, -1.0f, -1.0f, -1.0f, -1.0f, -1.0f, -1.0f,  1.0f,-1.0f,  1.0f, -1.0f, 1.0f,  1.0f, -1.0f, 1.0f,  1.0f,  1.0f,1.0f,  1.0f,  1.0f, -1.0f,  1.0f,  1.0f, -1.0f,  1.0f, -1.0f};//金字塔//18个顶点,6个三角形float pyramidPositions[54] ={ -1.0f, -1.0f, 1.0f, 1.0f, -1.0f, 1.0f, 0.0f, 1.0f, 0.0f,    //front1.0f, -1.0f, 1.0f, 1.0f, -1.0f, -1.0f, 0.0f, 1.0f, 0.0f,    //right1.0f, -1.0f, -1.0f, -1.0f, -1.0f, -1.0f, 0.0f, 1.0f, 0.0f,  //back-1.0f, -1.0f, -1.0f, -1.0f, -1.0f, 1.0f, 0.0f, 1.0f, 0.0f,  //left-1.0f, -1.0f, -1.0f, 1.0f, -1.0f, 1.0f, -1.0f, -1.0f, 1.0f, //LF1.0f, -1.0f, 1.0f, -1.0f, -1.0f, -1.0f, 1.0f, -1.0f, -1.0f  //RR};glGenVertexArrays(1, vao);//创建顶点数组对象VAO,      //数据集发送给管线时,是以缓冲区形式发送的glBindVertexArray(vao[0]);//将指定的VAO标记为活跃,生成的缓冲区和这个VAO关联glGenBuffers(numVBOs, vbo);//创建VBO.//参数1,创建多少个ID,参数2,保存返回的ID的数组glBindBuffer(GL_ARRAY_BUFFER, vbo[0]);//将缓冲区【0】标记为活跃glBufferData(GL_ARRAY_BUFFER, sizeof(vertexPositions), vertexPositions, GL_STATIC_DRAW);//将包含顶点数据的数组复制进活跃缓冲区glBindBuffer(GL_ARRAY_BUFFER, vbo[1]);glBufferData(GL_ARRAY_BUFFER, sizeof(pyramidPositions), pyramidPositions, GL_STATIC_DRAW);
}//init()函数负责执行只需要一次的任务
void init(GLFWwindow* window) {renderingProgram = Utils::createShaderProgram("vertShader.glsl", "fragShader.glsl");//获取GL程序的ID,该程序创建着色器glfwGetFramebufferSize(window, &width, &height);aspect = (float)width / (float)height;//屏幕纵横比.透视矩阵需要的参数//构建透视矩阵//根据所需的视锥提供3D效果,这里放在了init里,因为只需要构建一次pMat = glm::perspective(1.0472f, aspect, 0.1f, 1000.0f);//构建透视矩阵//参数 1. 指定视场角(这里是60°,对应弧度是1.0472)//,2. 屏幕纵横比 ,3.近裁剪平面,4.远裁剪平面cameraX = 0.0f; cameraY = 0.0f; cameraZ = 12.0f;//相机放在z轴的下方setupVertices();//将顶点数据复制进缓冲区
}//调用display函数的速率被称为帧率
void display(GLFWwindow* window, double currentTime) {
//配置背景,深度缓冲区,渲染程序,以及和原来一样的投影矩阵/////清除深度缓冲区glClear(GL_DEPTH_BUFFER_BIT);//隐藏面消除需要同时用到颜色缓冲区和深度缓冲区glClearColor(1.0, 1.0, 1.0, 1.0);						//这里只清楚了深度缓冲区,不然可能会导致黑屏glClear(GL_COLOR_BUFFER_BIT);glEnable(GL_CULL_FACE);//背面剔除//启用着色器glUseProgram(renderingProgram);//将含有两个已编译着色器的程序载入OpenGL管线阶段(在GPU上!)//glUseProgram没有运行着色器,它只是将着色器加载进硬件//着色器需要视图矩阵的统一变量//获取V矩阵和投影矩阵的统一变量// m/模型矩阵在世界坐标空间中表示对象的位置和朝向mvLoc = glGetUniformLocation(renderingProgram, "mv_matrix");//获取着色器程序中MV矩阵统一变量的位置projLoc = glGetUniformLocation(renderingProgram, "proj_matrix");//获取着色器程序中投影矩阵统一变量的位置
//将视图矩阵推入堆栈vMat = glm::translate(glm::mat4(1.0f), glm::vec3(-cameraX, -cameraY, -cameraZ));//v,视图,相机,变换矩阵mvStack.push(vMat);//摄像机glUniformMatrix4fv(projLoc, 1, GL_FALSE, glm::value_ptr(pMat));//将矩阵数据发送到统一变量中//--------------------pyramid == sunmvStack.push(mvStack.top());//将新矩阵推入堆栈,对第一个对象来说,直接复制一份视图矩阵mvStack.top() *= glm::translate(glm::mat4(1.0f), glm::vec3(0.0f, 0.0f, -0.0f));//太阳的位置//将父对象的模型矩阵和复制的的视图矩阵结合mvStack.push(mvStack.top());//生成完整的MV矩阵,包括它的自转mvStack.top() *= rotate(glm::mat4(1.0f), (float)currentTime, glm::vec3(1.0f, 0.0f, 0.0f));//稍后会弹出不会影响子对象glUniformMatrix4fv(mvLoc, 1, GL_FALSE, glm::value_ptr(mvStack.top()));//将矩阵数据发送到统一变量中,value_ptr返回的是对矩阵数据的引用glBindBuffer(GL_ARRAY_BUFFER, vbo[1]);//将VBO关联给顶点着色器中相应的顶点属性glVertexAttribPointer(0, 3, GL_FLOAT, GL_FALSE, 0, 0);glEnableVertexAttribArray(0);glEnable(GL_DEPTH_TEST);	//调整OpenGL设置,绘制模型glDepthFunc(GL_LEQUAL);glFrontFace(GL_CW);glDrawArrays(GL_TRIANGLES, 0, 18);mvStack.pop();//---------------------cube == planetmvStack.push(mvStack.top());mvStack.top() *= glm::translate(glm::mat4(1.0f), glm::vec3(sin((float)currentTime) * 4.0, 0.0f, cos((float)currentTime) * 4.0));mvStack.push(mvStack.top());mvStack.top() *= rotate(glm::mat4(1.0f), (float)currentTime, glm::vec3(0.0, 1.0, 0.0));//稍后会弹出不会影响子对象glUniformMatrix4fv(mvLoc, 1, GL_FALSE, glm::value_ptr(mvStack.top()));//将矩阵数据发送到统一变量中,value_ptr返回的是对矩阵数据的引用glBindBuffer(GL_ARRAY_BUFFER, vbo[0]);//将VBO关联给顶点着色器中相应的顶点属性glVertexAttribPointer(0, 3, GL_FLOAT, GL_FALSE, 0, 0);glEnableVertexAttribArray(0);glEnable(GL_DEPTH_TEST);	//调整OpenGL设置,绘制模型glDepthFunc(GL_LEQUAL);glDrawArrays(GL_TRIANGLES, 0, 36);mvStack.pop();//-----------------------smaller cube == moonmvStack.push(mvStack.top());mvStack.top() *= glm::translate(glm::mat4(1.0f), glm::vec3(0.0f, sin((float)currentTime) * 2.0, cos((float)currentTime) * 2.0));mvStack.top() *= rotate(glm::mat4(1.0f), (float)currentTime, glm::vec3(0.0, 0.0, 1.0));mvStack.top() *= scale(glm::mat4(1.0f), glm::vec3(0.25, 0.25, 0.25));glUniformMatrix4fv(mvLoc, 1, GL_FALSE, glm::value_ptr(mvStack.top()));//将矩阵数据发送到统一变量中,value_ptr返回的是对矩阵数据的引用glBindBuffer(GL_ARRAY_BUFFER, vbo[0]);//将VBO关联给顶点着色器中相应的顶点属性glVertexAttribPointer(0, 3, GL_FLOAT, GL_FALSE, 0, 0);glEnableVertexAttribArray(0);glEnable(GL_DEPTH_TEST);	//调整OpenGL设置,绘制模型glDepthFunc(GL_LEQUAL);glDrawArrays(GL_TRIANGLES, 0, 36);mvStack.pop(); mvStack.pop(); mvStack.pop();mvStack.pop();//最后一个是视图矩阵
}
void window_size_callback(GLFWwindow* win, int newWidth, int newHeight) {aspect = (float)newWidth / (float)newHeight;glViewport(0, 0, newWidth, newHeight);pMat = glm::perspective(1.0472f, aspect, 0.1f, 1000.0f);
}
int main(void) {if (!glfwInit()) { exit(EXIT_FAILURE); }glfwWindowHint(GLFW_CONTEXT_VERSION_MAJOR, 4);//设置窗口选项glfwWindowHint(GLFW_CONTEXT_VERSION_MINOR, 6);GLFWwindow* window = glfwCreateWindow(600, 600, "Chapter 4 - program 2", NULL, NULL);glfwMakeContextCurrent(window);//让当前窗口的环境在当前线程上成为当前环境if (glewInit() != GLEW_OK) { exit(EXIT_FAILURE); }glfwSwapInterval(1);glfwSetWindowSizeCallback(window, window_size_callback);init(window);while (!glfwWindowShouldClose(window)) {display(window, glfwGetTime());glfwSwapBuffers(window);glfwPollEvents();}glfwDestroyWindow(window);glfwTerminate();exit(EXIT_SUCCESS);
}
#include <GL\glew.h>
#include <GLFW\glfw3.h>
#include <SOIL2\soil2.h>
#include <string>
#include <iostream>
#include <fstream>
#include <cmath>
#include <glm\glm.hpp>
#include <glm\gtc\type_ptr.hpp> // glm::value_ptr
#include <glm\gtc\matrix_transform.hpp> // glm::translate, glm::rotate, glm::scale, glm::perspective
#include "Utils.h"
using namespace std;Utils::Utils() {}string Utils::readShaderFile(const char *filePath) {string content;ifstream fileStream(filePath, ios::in);string line = " ";while (!fileStream.eof()) {getline(fileStream, line);content.append(line + "\n");}fileStream.close();return content;
}bool Utils::checkOpenGLError() {bool foundError = false;int glErr = glGetError();while (glErr != GL_NO_ERROR) {cout << "glError: " << glErr << endl;foundError = true;glErr = glGetError();}return foundError;
}void Utils::printShaderLog(GLuint shader) {int len = 0;int chWrittn = 0;char *log;glGetShaderiv(shader, GL_INFO_LOG_LENGTH, &len);if (len > 0) {log = (char *)malloc(len);glGetShaderInfoLog(shader, len, &chWrittn, log);cout << "Shader Info Log: " << log << endl;free(log);}
}GLuint Utils::prepareShader(int shaderTYPE, const char *shaderPath)
{	GLint shaderCompiled;string shaderStr = readShaderFile(shaderPath);const char *shaderSrc = shaderStr.c_str();//获取着色器信息的字符串GLuint shaderRef = glCreateShader(shaderTYPE);//创建着色器glShaderSource(shaderRef, 1, &shaderSrc, NULL);//将字符串复制进着色器中glCompileShader(shaderRef);//编译着色器checkOpenGLError();glGetShaderiv(shaderRef, GL_COMPILE_STATUS, &shaderCompiled);if (shaderCompiled != 1){	if (shaderTYPE == 35633) cout << "Vertex ";if (shaderTYPE == 36488) cout << "Tess Control ";if (shaderTYPE == 36487) cout << "Tess Eval ";if (shaderTYPE == 36313) cout << "Geometry ";if (shaderTYPE == 35632) cout << "Fragment ";cout << "shader compilation error." << endl;printShaderLog(shaderRef);}return shaderRef;//返回程序的ID
}void Utils::printProgramLog(int prog) {int len = 0;int chWrittn = 0;char *log;glGetProgramiv(prog, GL_INFO_LOG_LENGTH, &len);if (len > 0) {log = (char *)malloc(len);glGetProgramInfoLog(prog, len, &chWrittn, log);cout << "Program Info Log: " << log << endl;free(log);}
}int Utils::finalizeShaderProgram(GLuint sprogram)
{	GLint linked;glLinkProgram(sprogram); //请求GLSL编译器确保他们的兼容性checkOpenGLError();glGetProgramiv(sprogram, GL_LINK_STATUS, &linked);if (linked != 1){	cout << "linking failed" << endl;printProgramLog(sprogram);}return sprogram;
}GLuint Utils::createShaderProgram(const char *vp, const char *fp) {GLuint vShader = prepareShader(GL_VERTEX_SHADER, vp);//获取编译着色器后得到的着色器对象GLuint fShader = prepareShader(GL_FRAGMENT_SHADER, fp);GLuint vfprogram = glCreateProgram();//创建程序对象glAttachShader(vfprogram, vShader);//将着色器对象载入程序对象中glAttachShader(vfprogram, fShader);finalizeShaderProgram(vfprogram); //请求GLSL编译器确保他们的兼容性return vfprogram;
}GLuint Utils::createShaderProgram(const char *vp, const char *gp, const char *fp) {GLuint vShader = prepareShader(GL_VERTEX_SHADER, vp);GLuint gShader = prepareShader(GL_GEOMETRY_SHADER, gp);GLuint fShader = prepareShader(GL_FRAGMENT_SHADER, fp);GLuint vgfprogram = glCreateProgram();glAttachShader(vgfprogram, vShader);glAttachShader(vgfprogram, gShader);glAttachShader(vgfprogram, fShader);finalizeShaderProgram(vgfprogram);return vgfprogram;
}GLuint Utils::createShaderProgram(const char *vp, const char *tCS, const char* tES, const char *fp) {GLuint vShader = prepareShader(GL_VERTEX_SHADER, vp);GLuint tcShader = prepareShader(GL_TESS_CONTROL_SHADER, tCS);GLuint teShader = prepareShader(GL_TESS_EVALUATION_SHADER, tES);GLuint fShader = prepareShader(GL_FRAGMENT_SHADER, fp);GLuint vtfprogram = glCreateProgram();glAttachShader(vtfprogram, vShader);glAttachShader(vtfprogram, tcShader);glAttachShader(vtfprogram, teShader);glAttachShader(vtfprogram, fShader);finalizeShaderProgram(vtfprogram);return vtfprogram;
}GLuint Utils::createShaderProgram(const char *vp, const char *tCS, const char* tES, char *gp, const char *fp) {GLuint vShader = prepareShader(GL_VERTEX_SHADER, vp);GLuint tcShader = prepareShader(GL_TESS_CONTROL_SHADER, tCS);GLuint teShader = prepareShader(GL_TESS_EVALUATION_SHADER, tES);GLuint gShader = prepareShader(GL_GEOMETRY_SHADER, gp);GLuint fShader = prepareShader(GL_FRAGMENT_SHADER, fp);GLuint vtgfprogram = glCreateProgram();glAttachShader(vtgfprogram, vShader);glAttachShader(vtgfprogram, tcShader);glAttachShader(vtgfprogram, teShader);glAttachShader(vtgfprogram, gShader);glAttachShader(vtgfprogram, fShader);finalizeShaderProgram(vtgfprogram);return vtgfprogram;
}GLuint Utils::loadCubeMap(const char *mapDir) {GLuint textureRef;string xp = mapDir; xp = xp + "/xp.jpg";string xn = mapDir; xn = xn + "/xn.jpg";string yp = mapDir; yp = yp + "/yp.jpg";string yn = mapDir; yn = yn + "/yn.jpg";string zp = mapDir; zp = zp + "/zp.jpg";string zn = mapDir; zn = zn + "/zn.jpg";textureRef = SOIL_load_OGL_cubemap(xp.c_str(), xn.c_str(), yp.c_str(), yn.c_str(), zp.c_str(), zn.c_str(),SOIL_LOAD_AUTO, SOIL_CREATE_NEW_ID, SOIL_FLAG_MIPMAPS);if (textureRef == 0) cout << "didnt find cube map image file" << endl;//	glBindTexture(GL_TEXTURE_CUBE_MAP, textureRef);// reduce seams//	glTexParameteri(GL_TEXTURE_CUBE_MAP, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_EDGE);//	glTexParameteri(GL_TEXTURE_CUBE_MAP, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE);//	glTexParameteri(GL_TEXTURE_CUBE_MAP, GL_TEXTURE_WRAP_R, GL_CLAMP_TO_EDGE);return textureRef;
}GLuint Utils::loadTexture(const char *texImagePath)
{	GLuint textureRef;textureRef = SOIL_load_OGL_texture(texImagePath, SOIL_LOAD_AUTO, SOIL_CREATE_NEW_ID, SOIL_FLAG_INVERT_Y);if (textureRef == 0) cout << "didnt find texture file " << texImagePath << endl;// ----- mipmap/anisotropic sectionglBindTexture(GL_TEXTURE_2D, textureRef);glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR_MIPMAP_LINEAR);glGenerateMipmap(GL_TEXTURE_2D);if (glewIsSupported("GL_EXT_texture_filter_anisotropic")) {GLfloat anisoset = 0.0f;glGetFloatv(GL_MAX_TEXTURE_MAX_ANISOTROPY_EXT, &anisoset);glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_MAX_ANISOTROPY_EXT, anisoset);}// ----- end of mipmap/anisotropic sectionreturn textureRef;
}// GOLD material - ambient, diffuse, specular, and shininess
float* Utils::goldAmbient() { static float a[4] = { 0.2473f, 0.1995f, 0.0745f, 1 }; return (float*)a; }
float* Utils::goldDiffuse() { static float a[4] = { 0.7516f, 0.6065f, 0.2265f, 1 }; return (float*)a; }
float* Utils::goldSpecular() { static float a[4] = { 0.6283f, 0.5559f, 0.3661f, 1 }; return (float*)a; }
float Utils::goldShininess() { return 51.2f; }// SILVER material - ambient, diffuse, specular, and shininess
float* Utils::silverAmbient() { static float a[4] = { 0.1923f, 0.1923f, 0.1923f, 1 }; return (float*)a; }
float* Utils::silverDiffuse() { static float a[4] = { 0.5075f, 0.5075f, 0.5075f, 1 }; return (float*)a; }
float* Utils::silverSpecular() { static float a[4] = { 0.5083f, 0.5083f, 0.5083f, 1 }; return (float*)a; }
float Utils::silverShininess() { return 51.2f; }// BRONZE material - ambient, diffuse, specular, and shininess
float* Utils::bronzeAmbient() { static float a[4] = { 0.2125f, 0.1275f, 0.0540f, 1 }; return (float*)a; }
float* Utils::bronzeDiffuse() { static float a[4] = { 0.7140f, 0.4284f, 0.1814f, 1 }; return (float*)a; }
float* Utils::bronzeSpecular() { static float a[4] = { 0.3936f, 0.2719f, 0.1667f, 1 }; return (float*)a; }
float Utils::bronzeShininess() { return 25.6f; }
#include <GL\glew.h>
#include <GLFW\glfw3.h>
#include <SOIL2\soil2.h>
#include <string>
#include <iostream>
#include <fstream>
#include <cmath>
#include <vector>
#include <glm\glm.hpp>
#include <glm\gtc\type_ptr.hpp>
#include <glm\gtc\matrix_transform.hpp>class Utils
{
private:static std::string readShaderFile(const char *filePath);static void printShaderLog(GLuint shader);static void printProgramLog(int prog);static GLuint prepareShader(int shaderTYPE, const char *shaderPath);static int finalizeShaderProgram(GLuint sprogram);public:Utils();static bool checkOpenGLError();static GLuint createShaderProgram(const char *vp, const char *fp);static GLuint createShaderProgram(const char *vp, const char *gp, const char *fp);static GLuint createShaderProgram(const char *vp, const char *tCS, const char* tES, const char *fp);static GLuint createShaderProgram(const char *vp, const char *tCS, const char* tES, char *gp, const char *fp);static GLuint loadTexture(const char *texImagePath);static GLuint loadCubeMap(const char *mapDir);static float* goldAmbient();static float* goldDiffuse();static float* goldSpecular();static float goldShininess();static float* silverAmbient();static float* silverDiffuse();static float* silverSpecular();static float silverShininess();static float* bronzeAmbient();static float* bronzeDiffuse();static float* bronzeSpecular();static float bronzeShininess();
};

vertShader.glsl

#version 430layout (location=0) in vec3 position;uniform mat4 mv_matrix;
uniform mat4 proj_matrix;out vec4 varyingColor;void main(void)
{gl_Position = proj_matrix * mv_matrix * vec4(position,1.0);varyingColor = vec4(position,1.0)*0.5 + vec4(0.5, 0.5, 0.5, 0.5);
} 

fragShader.glsl

#version 430in vec4 varyingColor;
out vec4 color;uniform mat4 mv_matrix;
uniform mat4 proj_matrix;void main(void)
{	color = varyingColor;
}

这篇关于OpenGL--恒星,卫星,行星系统的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/305461

相关文章

在C#中获取端口号与系统信息的高效实践

《在C#中获取端口号与系统信息的高效实践》在现代软件开发中,尤其是系统管理、运维、监控和性能优化等场景中,了解计算机硬件和网络的状态至关重要,C#作为一种广泛应用的编程语言,提供了丰富的API来帮助开... 目录引言1. 获取端口号信息1.1 获取活动的 TCP 和 UDP 连接说明:应用场景:2. 获取硬

JAVA系统中Spring Boot应用程序的配置文件application.yml使用详解

《JAVA系统中SpringBoot应用程序的配置文件application.yml使用详解》:本文主要介绍JAVA系统中SpringBoot应用程序的配置文件application.yml的... 目录文件路径文件内容解释1. Server 配置2. Spring 配置3. Logging 配置4. Ma

2.1/5.1和7.1声道系统有什么区别? 音频声道的专业知识科普

《2.1/5.1和7.1声道系统有什么区别?音频声道的专业知识科普》当设置环绕声系统时,会遇到2.1、5.1、7.1、7.1.2、9.1等数字,当一遍又一遍地看到它们时,可能想知道它们是什... 想要把智能电视自带的音响升级成专业级的家庭影院系统吗?那么你将面临一个重要的选择——使用 2.1、5.1 还是

高效管理你的Linux系统: Debian操作系统常用命令指南

《高效管理你的Linux系统:Debian操作系统常用命令指南》在Debian操作系统中,了解和掌握常用命令对于提高工作效率和系统管理至关重要,本文将详细介绍Debian的常用命令,帮助读者更好地使... Debian是一个流行的linux发行版,它以其稳定性、强大的软件包管理和丰富的社区资源而闻名。在使用

Ubuntu系统怎么安装Warp? 新一代AI 终端神器安装使用方法

《Ubuntu系统怎么安装Warp?新一代AI终端神器安装使用方法》Warp是一款使用Rust开发的现代化AI终端工具,该怎么再Ubuntu系统中安装使用呢?下面我们就来看看详细教程... Warp Terminal 是一款使用 Rust 开发的现代化「AI 终端」工具。最初它只支持 MACOS,但在 20

windows系统下shutdown重启关机命令超详细教程

《windows系统下shutdown重启关机命令超详细教程》shutdown命令是一个强大的工具,允许你通过命令行快速完成关机、重启或注销操作,本文将为你详细解析shutdown命令的使用方法,并提... 目录一、shutdown 命令简介二、shutdown 命令的基本用法三、远程关机与重启四、实际应用

Debian如何查看系统版本? 7种轻松查看Debian版本信息的实用方法

《Debian如何查看系统版本?7种轻松查看Debian版本信息的实用方法》Debian是一个广泛使用的Linux发行版,用户有时需要查看其版本信息以进行系统管理、故障排除或兼容性检查,在Debia... 作为最受欢迎的 linux 发行版之一,Debian 的版本信息在日常使用和系统维护中起着至关重要的作

什么是cron? Linux系统下Cron定时任务使用指南

《什么是cron?Linux系统下Cron定时任务使用指南》在日常的Linux系统管理和维护中,定时执行任务是非常常见的需求,你可能需要每天执行备份任务、清理系统日志或运行特定的脚本,而不想每天... 在管理 linux 服务器的过程中,总有一些任务需要我们定期或重复执行。就比如备份任务,通常会选在服务器资

TP-LINK/水星和hasivo交换机怎么选? 三款网管交换机系统功能对比

《TP-LINK/水星和hasivo交换机怎么选?三款网管交换机系统功能对比》今天选了三款都是”8+1″的2.5G网管交换机,分别是TP-LINK水星和hasivo交换机,该怎么选呢?这些交换机功... TP-LINK、水星和hasivo这三台交换机都是”8+1″的2.5G网管交换机,我手里的China编程has

基于Qt实现系统主题感知功能

《基于Qt实现系统主题感知功能》在现代桌面应用程序开发中,系统主题感知是一项重要的功能,它使得应用程序能够根据用户的系统主题设置(如深色模式或浅色模式)自动调整其外观,Qt作为一个跨平台的C++图形用... 目录【正文开始】一、使用效果二、系统主题感知助手类(SystemThemeHelper)三、实现细节