Comments (4)
Thank you very much for the descriptive description. From your explanations, I have realized that the issue was the margin between the elements and not the padding. I sorted it out using nodesep
and ranksep
.
from c4-plantuml.
Hi! To make it easier to help, could you post a (simplified) diagram, so we have an example to work with?
from c4-plantuml.
In the meantime, I've looked into this some more. Sadly, PlantUML does not offer an easy way to add spacing inside an element.
TL;DR (short version)
Use a dummy container inside the boundary as a workaround.
@startuml
!include <C4/C4_Container>
skinparam {
rectangle<<DUMMY>> {
borderColor transparent
stereotypeFontSize 0
fontSize 0
}
}
Boundary(b, "Boundary") {
rectangle padding <<DUMMY>> {
Container(c, "Container")
Person(p, "Person")
System(s, "System")
Boundary(b1, "Boundary")
}
}
@enduml |
Full details
I'll use this diagram as the basis for further examples:
@startuml
!include <C4/C4_Container>
Boundary(b, "Boundary") {
Container(c, "Container")
Person(p, "Person")
System(s, "System")
Boundary(b1, "Boundary")
}
@enduml |
See full details
No skinparam "margin" or "padding"
Sadly, there is no skinparam for "margin" or "padding":
@startuml
!include <C4/C4_Container>
skinparam rectangle<<boundary>> {
margin 100 100 100 100
padding 100 100 100 100
}
Boundary(b, "Boundary") {
Container(c, "Container")
Person(p, "Person")
System(s, "System")
Boundary(b1, "Boundary")
}
@enduml |
Skinparam nodesep
and ranksep
There is skinparam nodesep
and ranksep
which can be used to increase the space between elements but not around them. That is to say: the space between an element and the boundary does not change.
@startuml
!include <C4/C4_Container>
skinparam nodesep 100 /' horizontal margin '/
skinparam ranksep 100 /' vertical margin '/
Boundary(b, "Boundary") {
Container(c, "Container")
Person(p, "Person")
System(s, "System")
Boundary(b1, "Boundary")
}
@enduml |
Padding and Margin (new CSS-like style) not working
There are padding and margin instruction using the new CSS-like style, but they do not seem to be implemented for the elements used by C4. This could be a bug in PlantUML and might be worth reporting there.
@startuml
!include <C4/C4_Container>
<style>
root {
BackgroundColor #FFE
Margin 100
Padding 100
}
rectangle {
Margin 100
Padding 100
}
.boundary {
Margin 100
Padding 100
}
</style>
Boundary(b, "Boundary") {
Container(c, "Container")
Person(p, "Person")
System(s, "System")
Boundary(b1, "Boundary")
}
@enduml |
Workaround
What could work is a workaround, putting the elements in an invisible container. This does mean adding a container inside every boundary. Not ideal.
@startuml
!include <C4/C4_Container>
skinparam {
rectangle<<DUMMY>> {
borderColor transparent
stereotypeFontSize 0
fontSize 0
}
}
Boundary(b, "Boundary") {
rectangle padding <<DUMMY>> {
Container(c, "Container")
Person(p, "Person")
System(s, "System")
Boundary(b1, "Boundary")
}
}
@enduml |
from c4-plantuml.
Glad to be of help. Happy diagramming!
from c4-plantuml.
Related Issues (20)
- Tags and sprites conflict in Rel (update: sprites have white background, should be transparent) HOT 4
- Image gets cut on the side HOT 1
- Adjust thickness of element border HOT 6
- C4_Dynamic no longer numbers all relationships HOT 6
- error a001 on all diagrams HOT 2
- Odd Legend Rendering for Sequence Diagrams HOT 5
- Question: How do I split functions over multiple lines? HOT 1
- Wrong rendering for Rel_R HOT 4
- AddNodeTag in C4_Deployment throws an error HOT 5
- Support of "all" PlantUML elements can be enabled HOT 4
- Line styling not recognized when using ELK HOT 2
- "Cannot open URL" on Online Server HOT 2
- Legend text includes unexpected properties (e.g. $lineStyle) HOT 3
- Wrong layout: "== Base Query" <<boundary>> as Base Query HOT 3
- C4_Container diagram not rendering properly HOT 3
- Java OutOfMemoryError with some Sequence diagrams HOT 6
- $baseShape="label" does not use the correct color (size, ...?) in combination with themes
- Descriptions for boundaries HOT 8
- Separating model and view HOT 5
- Single column properties or header lead to rendering error HOT 3
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from c4-plantuml.