Skip to content

Latest commit

 

History

History
99 lines (68 loc) · 5.06 KB

Branding.md

File metadata and controls

99 lines (68 loc) · 5.06 KB

Branding/ko

요약 설명

이 문서는 프리캐드를 Branding (개조)하는 것을 설명합니다. Branding 이란, FreeCAD 을 모체로 한 개인 전용 프로그램을 만드는 것을 의미합니다. 그것은 완전히 다시 만들어진 프로그램과 비슷하게 실행이나 시작 화면 을 보여주며 당신만 사용하게 만들 수 있습니다. On base of the flexible architecture of FreeCAD it's easy to use it as base for your own special purpose program.

Warning

Although FreeCAD is offered to you free of charge, and the FreeCAD community is happy to see other applications emerging, that are based on FreeCAD, we have on the other hand seen a lot of unfair use of the information contained on this page by people who simply rebranded FreeCAD into a closed-source application to make profit from it.

Although the LGPL license allows to use the FreeCAD source code in closed-source applications, it also gives strict rules to do so, and does not allow simply taking FreeCAD, renaming it and stripping it of its license.

Would you be interested in using FreeCAD in a closed-source application, be sure to check thoroughly the implications of the LGPL license, and, even better, contact any FreeCAD developer, administrator or moderator before doing so.

General

Most of the branding is done in the MainCmd.cpp or MainGui.cpp. These Projects generate the executable files of FreeCAD. To make your own Brand just copy the Main or MainGui projects and give the executable its own name, e.g. FooApp.exe. The most important settings for a new look are made in one place in the main() function. Here is the code section that controls the branding:

C int main( int argc, char ** argv ) { // Name and Version of the Application App::Application::Config()["ExeName"] = "FooApp"; App::Application::Config()["ExeVersion"] = "0.7";

// set the banner (for loging and console)
App::Application::Config()["CopyrightInfo"] = sBanner;
App::Application::Config()["AppIcon"] = "FooAppIcon";
App::Application::Config()["SplashScreen"] = "FooAppSplasher";
App::Application::Config()["StartWorkbench"] = "Part design";
App::Application::Config()["HiddenDockWindow"] = "Property editor";
App::Application::Config()["SplashAlignment" ] = "Bottom|Left";
App::Application::Config()["SplashTextColor" ] = "#000000"; // black

// Inits the Application 
App::Application::Config()["RunMode"] = "Gui";
App::Application::init(argc,argv);

Gui::BitmapFactory().addXPM("FooAppSplasher", ( const char** ) splash_screen);

Gui::Application::initApplication();
Gui::Application::runApplication();
App::Application::destruct();

return 0;

}

The first Config entry defines the program name. This is not the executable name, which can be changed by renaming or by compiler settings, but the name that is displayed in the task bar on windows or in the program list on Unix systems.

The next lines define the Config entries of your FooApp Application. A description of the Config and its entries you find in Start up and Configuration.

Images

Image resources are compiled into FreeCAD using Qt's resource system. Therefore you have to write a .qrc file, an XML-based file format that lists image files on the disk but also any other kind of resource files. To load the compiled resources inside the application you have to add a line

Q_INIT_RESOURCE(FooApp); 

into the main() function. Alternatively, if you have an image in XPM format you can directly include it into your main.cpp and add the following line to register it:

Gui::BitmapFactory().addXPM("FooAppSplasher", ( const char** ) splash_screen);

Branding XML

In FreeCAD there is also a method supported without writing a customized main() function. For this method you must write a file name called branding.xml and put it into the installation directory of FreeCAD. Here is an example with all supported tags:

XML

FooApp Foo App in title bar 1 0 1234 2014/1/1 (c) My copyright Foo App URL Path to logo (appears in bottom right corner) Path to icon file Path to program icons splashscreen.png Bottom|Left #ffffff #c8c8c8 PartDesignWorkbench

All listed tags are optional.


documentation index > Developer Documentation > Branding/ko