mirror of
				https://github.com/slint-ui/slint.git
				synced 2025-10-25 17:38:06 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			72 lines
		
	
	
	
		
			3.8 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			72 lines
		
	
	
	
		
			3.8 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| <!-- Copyright © SixtyFPS GmbH <info@slint.dev> ; SPDX-License-Identifier: MIT -->
 | |
| # Overview
 | |
| 
 | |
| The following sections explain how to integrate your `.slint` designs into your
 | |
| C++ application. The entry point is the `.slint` file containing the primary
 | |
| component you need to instantiate from C++.
 | |
| 
 | |
| Slint is a very flexible system and allows for different integration options.
 | |
| 
 | |
| First you can compile your Slint designs ahead of time into C++ code. This
 | |
| code is then built into your application. This allows for the smallest
 | |
| possible memory footprint and the best possible performance.
 | |
| 
 | |
| The second approach is to load your Slint designs at run-time, interpreting
 | |
| them as needed. This enables even more dynamic user interfaces that can be
 | |
| changed at run-time, but comes at the price of having less opportunity to apply
 | |
| optimizations.
 | |
| 
 | |
| Either way, once your user interface is shown, you interact with it from C++,
 | |
| for example by setting properties, populating data models or setting up and
 | |
| handling callbacks to react to events triggered by the user.
 | |
| 
 | |
| ## Compiled `.slint` Designs
 | |
| 
 | |
| The provided CMake integration makes it easy to compile your Slint sources:
 | |
| The [`slint_target_sources` CMake command](cmake_reference.md#slint_target_sources) makes the translation automatic. The
 | |
| [generated code](generated_code.md) has an API to set and get property values,
 | |
| etc. This API uses types from the {ref}`slint <namespace_slint>` namespace, for
 | |
| example {cpp:class}`slint::SharedString` or {cpp:class}`slint::Color`.
 | |
| 
 | |
| ## Run-Time Interpreted `.slint` Designs
 | |
| 
 | |
| Instead of compiling `.slint` designs to C++, you can dynamically load `.slint`
 | |
| files at run-time. This is slower than compiling them ahead of time and requires
 | |
| more memory, however it provides more flexibility in your application design.
 | |
| 
 | |
| The entry point to loading a `.slint` file is the
 | |
| {cpp:class}`slint::interpreter::ComponentCompiler` class in the
 | |
| {ref}`slint::interpreter <namespace_slint__interpreter>` namespace.
 | |
| 
 | |
| With the help of {cpp:class}`slint::interpreter::ComponentCompiler` you create
 | |
| a {cpp:class}`slint::interpreter::ComponentDefinition`, which provides
 | |
| information on properties and callbacks common to all instances. The
 | |
| {cpp:func}`slint::interpreter::ComponentDefinition::create()` function creates
 | |
| new instances, wrapped in a {cpp:class}`slint::ComponentHandle`. This is a smart
 | |
| pointer that owns the actual instance and keeps it alive as long as at least one
 | |
| {cpp:class}`slint::ComponentHandle` is in scope, similar to
 | |
| `std::shared_ptr<T>`.
 | |
| 
 | |
| All property values in `.slint` are mapped to
 | |
| {cpp:class}`slint::interpreter::Value` in C++. This is a polymorphic data type
 | |
| that can hold different kinds of values, such as numbers, strings or even data
 | |
| models.
 | |
| 
 | |
| More complex user interfaces commonly consume data in the form of an abstract
 | |
| data model, that is used with <a href="../slint/src/reference/repetitions.html">`for` - `in`</a>
 | |
| repetitions or <a href="../slint/src/language/widgets/listview">`ListView`</a> elements in the
 | |
| `.slint` language. All models in C++ with the interpreter API are sub-classes
 | |
| of the {cpp:class}`slint::Model` where the template parameter is
 | |
| {cpp:class}`slint::interpreter::Value`. To provide your own data model, you can
 | |
| subclass `slint::Model<slint::interpreter::Value>`.
 | |
| 
 | |
| It's possible to declare [singletons that are globally available](../slint/src/globals.html)
 | |
| in `.slint` files. You can access them from to your C++ code by exporting them
 | |
| and using the getter and setter functions on
 | |
| {cpp:class}`slint::interpreter::ComponentInstance` to change properties and
 | |
| callbacks:
 | |
| 
 | |
| 1. {cpp:func}`slint::interpreter::ComponentInstance::set_global_property()`
 | |
| 1. {cpp:func}`slint::interpreter::ComponentInstance::get_global_property()`
 | |
| 1. {cpp:func}`slint::interpreter::ComponentInstance::set_global_callback()`
 | |
| 1. {cpp:func}`slint::interpreter::ComponentInstance::invoke_global_callback()`
 | 
