mirror of
				https://github.com/ArthurSonzogni/FTXUI.git
				synced 2025-10-25 06:58:07 +08:00 
			
		
		
		
	 14da21b0ee
			
		
	
	14da21b0ee
	
	
	
		
			
			* Remove @ingroup from class member definitions * Add the documentation for every public classes.
		
			
				
	
	
		
			59 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			59 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| // Copyright 2023 Arthur Sonzogni. All rights reserved.
 | |
| // Use of this source code is governed by the MIT license that can be found in
 | |
| // the LICENSE file.
 | |
| #ifndef FTXUI_DOM_LINEAR_GRADIENT_HPP
 | |
| #define FTXUI_DOM_LINEAR_GRADIENT_HPP
 | |
| 
 | |
| #include <optional>
 | |
| #include <vector>
 | |
| 
 | |
| #include "ftxui/screen/color.hpp"  // for Colors
 | |
| 
 | |
| namespace ftxui {
 | |
| 
 | |
| /// @brief A class representing the settings for linear-gradient color effect.
 | |
| ///
 | |
| /// Example:
 | |
| /// ```cpp
 | |
| /// LinearGradient()
 | |
| ///    .Angle(45)
 | |
| ///    .Stop(Color::Red, 0.0)
 | |
| ///    .Stop(Color::Green, 0.5)
 | |
| ///    .Stop(Color::Blue, 1.0);
 | |
| /// ```
 | |
| ///
 | |
| /// There are also shorthand constructors:
 | |
| /// ```cpp
 | |
| /// LinearGradient(Color::Red, Color::Blue);
 | |
| /// LinearGradient(45, Color::Red, Color::Blue);
 | |
| /// ```
 | |
| ///
 | |
| /// @ingroup dom
 | |
| struct LinearGradient {
 | |
|   float angle = 0.f;
 | |
| 
 | |
|   /// A stop is a color at a specific position in the gradient.
 | |
|   /// The position is a value between 0.0 and 1.0,
 | |
|   /// where 0.0 is the start of the gradient
 | |
|   /// and 1.0 is the end of the gradient.
 | |
|   struct Stop {
 | |
|     Color color = Color::Default;
 | |
|     std::optional<float> position;
 | |
|   };
 | |
|   std::vector<Stop> stops;
 | |
| 
 | |
|   // Simple constructor
 | |
|   LinearGradient();
 | |
|   LinearGradient(Color begin, Color end);
 | |
|   LinearGradient(float angle, Color begin, Color end);
 | |
| 
 | |
|   // Modifier using the builder pattern.
 | |
|   LinearGradient& Angle(float angle);
 | |
|   LinearGradient& Stop(Color color, float position);
 | |
|   LinearGradient& Stop(Color color);
 | |
| };
 | |
| 
 | |
| }  // namespace ftxui
 | |
| 
 | |
| #endif  // FTXUI_DOM_LINEAR_GRADIENT_HPP
 |