Skip to content

Commit ac8850e

Browse files
Update lawnmower tutorial
Based off feedback from G7: -switched inline code backticks to phrases wrapped in single quotation marks - added more images + webm video. - added linebraks underneath most H2s. Also deleted redundant 'daedric-test.md
1 parent 7a4f32f commit ac8850e

File tree

8 files changed

+74
-47
lines changed

8 files changed

+74
-47
lines changed

mmw-content/daedric-test.md

-2
This file was deleted.

mmw-content/guides/groundcover/index.md

+2-2
Original file line numberDiff line numberDiff line change
@@ -4,7 +4,7 @@ aliases:
44
- Groundcover
55
tags:
66
- Groundcover
7-
- Lawnmower
7+
- LawnMower
88
- Mesh-Gen
99
- Groundcoverify
1010
- Grass
@@ -28,7 +28,7 @@ description: Creating and managing animated grass for MGE-XE and OpenMW
2828
> ### This article is part of a series on Groundcover
2929
>
3030
> - [[modding-tools/generating-groundcover/index|Generating Groundcover]]
31-
> - [[the-lawnmower|The Lawnmower]]
31+
> - [[the-lawnmower|The LawnMower]]
3232
> - [[mesh-gen|MeshGen]]
3333
> - [[habasi|Habasi]]
3434
> - [[groundcoverify|Groundcoverify]]

mmw-content/guides/groundcover/lawnmower-tutorial.md

+65-36
Original file line numberDiff line numberDiff line change
@@ -1,20 +1,17 @@
11
---
2-
title: Using Lawnmower to Delete Clipping Groundcover
2+
title: Using LawnMower to Delete Clipping Groundcover
33
aliases:
4-
- Using Lawnmower to Delete Clipping Groundcover
5-
- Lawnmower Groundcover Tutorial
4+
- Using LawnMower to Delete Clipping Groundcover
5+
- LawnMower Groundcover Tutorial
66
tags:
77
- Groundcover
8-
- Lawnmower
8+
- LawnMower
99
- Tutorial
1010
- Grass
1111
- Cleaning-Mods
1212
- Python
1313
- Tes3conv
14-
description: How to use `lawnmower.py` script to clean groundcover mods of excess grass
15-
parent: "[[the-lawnmower|Lawnmower]]"
16-
related articles:
17-
- "[[the-lawnmower|Lawnmower]]"
14+
description: How to use 'lawnmower.py' script to clean groundcover mods of excess grass
1815
---
1916
## About
2017

@@ -32,12 +29,12 @@ related articles:
3229
>
3330
> | Type | Name |
3431
> | --- | --- |
35-
> | **Requirements** | - [[the-lawnmower\|The Lawnmower]]<br>- [[tes3conv\|Tes3conv]]<br>- [Python 3.5+](https://www.python.org/)<br>- [[tes3cmd\|Tes3cmd]] (optional)<br>- [[testool\|TESTool]] (optional) |
32+
> | **Requirements** | - [[the-lawnmower\|The LawnMower]]<br>- [[tes3conv\|Tes3conv]]<br>- [Python 3.5+](https://www.python.org/)<br>- [[tes3cmd\|Tes3cmd]] (optional)<br>- [[testool\|TESTool]] (optional) |
3633
> | **Tutorial Files** | Any groundcover plugin you like that has not already had Lawnmower ran on it (the mod description will likely state whether this is the case) |
3734
3835
![[guides/groundcover/index#^groundcover-navbox|clean right]]
3936

40-
This tutorial covers how to use [[the-lawnmower|The Lawnmower]] tool to clean [[guides/groundcover/index|groundcover]] mods of excess grass - specifically, grass which clips through or is hidden under other objects.
37+
This tutorial covers how to use [[the-lawnmower|The LawnMower]] tool to clean [[guides/groundcover/index|groundcover]] mods of excess grass - specifically, grass which clips through or is hidden under other objects.
4138

4239
![[the-lawnmower#^2eccab|clean]]
4340

@@ -47,23 +44,25 @@ However, for the purposes of this tutorial we will only be focusing on the titul
4744

4845
By the end of this tutorial, you should be able to:
4946

50-
1. Run `lawnmower.py` Python script on a groundcover plugin
47+
1. Run 'lawnmower.py' Python script on a groundcover plugin
5148
2. Compare a groundcover plugin against multiple mods ('chaining')
52-
3. Understand how to use the 'autoclean' plugins to increase the accuracy of The Lawnmower
49+
3. Understand how to use the 'autoclean' plugins to increase the accuracy of The LawnMower
5350
4. Clean the patched groundcover plugin
5451

5552
### Prerequisites
5653

57-
> [!Info|right wm-sm txt-s] Installing Python
54+
In addition to downloading The LawnMower (tools only), the tool also requires that you have [[tes3conv|Tes3conv]] and [Python](https://www.python.org/) installed.
55+
56+
Copy 'tes3conv.exe' to your Morrowind 'Data Files' folder, or install it using a mod manager.
57+
58+
Likewise, copy 'lawnmower.py' from The LawnMower to 'Data Files' or install it with a mod manager.
59+
60+
> [!Info|txt-s] Installing Python
5861
> Whilst it may seem daunting, installation is unremarkable on most platforms.[^1]
5962
>
6063
> See Python [BeginnersGuide / Download](https://wiki.python.org/moin/BeginnersGuide/Download) for help.
6164
62-
In addition to downloading The Lawnmower (tools only), the tool also requires that you have [[tes3conv|Tes3conv]] and [Python](https://www.python.org/) installed.
63-
64-
Copy `tes3conv.exe` to your Morrowind `Data Files` folder, or install it using a mod manager.
65-
66-
Likewise, copy `lawnmower.py` from The Lawnmower to `Data Files` or install it with a mod manager.
65+
---
6766

6867
## Running the Script
6968

@@ -80,26 +79,52 @@ flowchart LR
8079
8180
```
8281

83-
`lawnmower.py` is a Python script. To run it, open a command-line terminal (e.g., Windows Powershell) and enter `python lawnmower.py`, followed by three plugin names:
82+
'lawnmower.py' is a Python script. To run it, open a command-line terminal (e.g., Windows Powershell) and enter `python lawnmower.py`, followed by three plugin names:
8483

85-
1. **Input**: The plugin to compare the groundcover against, e.g., `Morrowind.esm`.
86-
2. **Groundcover mod**: The groundcover plugin Lawnmower will trim, e.g., `Rem_AC.esp`
87-
3. **Output**: The name you give to the trimmed groundcover mod, e.g., `Rem_AC_out.esp`
88-
- Output can be named anything you like, as long as it ends with the extension `.esp` or `.esm`, e.g., `trimmed_mod.esm`.
84+
1. **Input**: The plugin to compare the groundcover against (e.g., 'Morrowind.esm').
85+
2. **Groundcover mod**: The groundcover plugin Lawnmower will trim (e.g., 'Rem_AC.esp').
86+
3. **Output**: The name you give to the trimmed groundcover mod (e.g., 'Rem_AC_out.esp').
87+
- Output can be named anything you like, as long as it ends with the extension '.esp' or '.esm' (e.g., 'trimmed_mod.esm').
8988

9089
This would be entered as:
9190

9291
```
9392
python lawnmower.py Morrowind.esm Rem_AC.esp Rem_AC_out.esp
9493
```
9594

96-
Press <kbd>Enter</kbd> to execute the script, and Lawnmower will create the freshly trimmed groundcover plugin '`Rem_AC_out.esp`'.
95+
Press <kbd>Enter</kbd> to execute the script, and Lawnmower will create the freshly trimmed groundcover plugin ''Rem_AC_out.esp''.
96+
97+
> [!caption|center wfull]
98+
>
99+
> ![[running-lawnmower-in-windows-command-prompt.webm|center]]
100+
> Running 'lawnmower.py' in Windows Command Prompt.
101+
> (video source: user upload)
102+
103+
> [!column|flex 2 clean]
104+
> > [!caption|wfull]
105+
> >
106+
> > ![[rem-ac-groundcover-before-lawnmower.webp]]
107+
> > 'Rem\_AC.esp' before LawnMower,
108+
> > _Outside Vas_ (image source: user upload).
109+
>
110+
> > [!caption|wfull]
111+
> >
112+
> > ![[rem-ac-groundcover-after-lawnmower.webp]]
113+
> > 'Rem\_AC.esp' after LawnMower,
114+
> > _Outside Vas_ (image source: user upload).
115+
116+
---
97117

98118
## Running Lawnmower Against Mutiple Plugins
99119

120+
> [!tip|txt-s wm-sm right] Using Lawnmower with your Entire Mod-List
121+
> Some tools for [[modding-tools/merging-plugins/index|merging plugins]], such as [[habasi|Habasi]], can generate a single merged plugin of your entire mod list. This merged plugin can be used as the 'input' plugin for Lawnmower, saving you the trouble of running the script on individual mods.
122+
>
123+
> To generate a merged plugin with **Habasi**, run the command `habasi -O` in a terminal.
124+
100125
Also known as 'Chaining' - The steps taken above in [[lawnmower-tutorial#Running the Script|'Running the Script']] can be repeated by substituting different input plugins.
101126

102-
For example, if you add a city overhaul mod which adds numerous buildings to cities (e.g., `cool cities.esp`, and you wish for your previous `Rem_AC_out.esp` to be trimmed of grass clipping through the new buildings, the command can be formatted like so:
127+
For example, if you add a city overhaul mod which adds numerous buildings to cities (e.g., 'cool cities.esp'), and you wish for your previous 'Rem_AC_out.esp' to be trimmed of grass clipping through the new buildings, the command can be formatted like so:
103128

104129
```
105130
python lawnmower.py "cool cities.esp" Rem_AC_out.esp "Rem_AC_out 2.esp"
@@ -120,31 +145,30 @@ flowchart LR
120145

121146
This can be repeated for any plugins you wish to compare the groundcover against, and even turned into a <abbr title="Batch File">BAT file</abbr> to be reused.
122147

123-
> [!tip|txt-s] Using Lawnmower with your Entire Mod-List
124-
> Some tools for [[modding-tools/merging-plugins/index|merging plugins]], such as [[habasi|Habasi]], can generate a single merged plugin of your entire mod list. This merged plugin can be used as the `input` plugin for Lawnmower, saving you the trouble of running the script on individual mods.
125-
>
126-
> To generate a merged plugin with **Habasi**, run the command `habasi -O` in a terminal.
148+
---
127149

128150
## Utilizing Autoclean Plugins
129151

130152
Autoclean plugins can be used to increase the accuracy of Lawnmower in detecting clipping groundcover.
131153

132154
Lawnmower comes packaged with two autoclean plugins:
133155

134-
- `autoclean_cities_vanilla.esp`: &nbsp; For Vvardenfell cities
135-
- `autoclean_cities_TR.ESP`: &nbsp; For [Tamriel Rebuilt](https://www.tamriel-rebuilt.org/) cities
156+
- **'autoclean_cities_vanilla.esp'**: &nbsp; For Vvardenfell cities
157+
- **'autoclean_cities_TR.ESP'**: &nbsp; For [Tamriel Rebuilt](https://www.tamriel-rebuilt.org/) cities
136158

137-
These plugins utilize the invisible marker meshes from [[the-lawnmower#Grassblocker|Grassblocker]], which `lawnmower.py` treats as objects when detecting whether grass is clipping. The plugins place these meshes in common areas where unwanted grass is often generated by [[mesh-gen|Mesh Generator]], but which otherwise won't be detected by `lawnmower.py` unless an object covers the area - i.e., a Grassblocker mesh. Mod makers can also create Lawnmower autoclean patches for their own mods using Grassblocker.
159+
These plugins utilize the invisible marker meshes from [[the-lawnmower#Grassblocker|Grassblocker]], which 'lawnmower.py' treats as objects when detecting whether grass is clipping. The plugins place these meshes in common areas where unwanted grass is often generated by [[mesh-gen|Mesh Generator]], but which otherwise won't be detected by 'lawnmower.py' unless an object covers the area - i.e., a Grassblocker mesh. Mod makers can also create Lawnmower autoclean patches for their own mods using Grassblocker.
138160

139161
The syntax for cleaning a groundcover plugin with an autoclean plugin is the same as any other:
140162

141163
```
142164
python lawnmower.py autoclean_cities_vanilla.esp "my grassmod.esp" "my grassmod_out.esp"
143165
```
144166

167+
---
168+
145169
## Advanced - Cleaning the Plugin
146170

147-
The caveat to The Lawnmower is that it does not truly delete the grass references it detects.
171+
The caveat to The LawnMower is that it does not truly delete the grass references it detects.
148172

149173
Instead, it moves their coordinates to `X: 0`, `Y: 0`, `Z: -20,000`, far below the surface of the game world. As groundcover plugins contain tens of thousands of references, these moved references are still taking up file space, even if they are never encountered in-game. Deleting these will not improve performance markedly, but it can make analyzing the output plugin easier.
150174

@@ -179,13 +203,18 @@ Replace `<path-to-plugin>` with your plugin name.
179203

180204
### Step 2 - TESTool
181205

182-
TESTool can clean empty cells which are otherwise not considered by Tesecmd as 'junk cells'.
206+
> [!caption|right txt-s wm-sm]
207+
>
208+
> ![[screenshot-of-testool-from-nexus-mods.webp]]
209+
> TESTool **'Clean ESP/ESM files'** can clean empty cells from plugins.
210+
211+
TESTool can clean empty cells which are otherwise not considered by Tes3cmd as 'junk cells'.
183212

184-
Simply run TESTool `Clean ESP/ESM files` on the output plugin.
213+
Simply run TESTool **'Clean ESP/ESM files'** on the output plugin.
185214

186215
## Further Reading
187216

188-
- [[the-lawnmower|The Lawnmower]]
217+
- [[the-lawnmower|The LawnMower]]
189218
- [[mesh-gen|Mesh Generator]]
190219
- [[habasi|Habasi]]
191220

mmw-content/modding-tools/generating-groundcover/index.md

+1-1
Original file line numberDiff line numberDiff line change
@@ -5,7 +5,7 @@ aliases:
55
tags:
66
- Groundcover
77
- Mesh-Gen
8-
- Lawnmower
8+
- LawnMower
99
description: Generating and culling groundcover and other meshes
1010
---
1111
## Generating and Culling Groundcover and Other Meshes

mmw-content/modding-tools/generating-groundcover/the-lawnmower.md

+6-6
Original file line numberDiff line numberDiff line change
@@ -1,13 +1,13 @@
11
---
2-
title: The Lawnmower
2+
title: The LawnMower
33
aliases:
4-
- The Lawnmower
4+
- The LawnMower
55
- Lawnmower
66
- Weedwhacker
77
- Grassclipper
88
- Grassblocker
99
tags:
10-
- Lawnmower
10+
- LawnMower
1111
- Cleaning-Mods
1212
- Groundcover
1313
- Python
@@ -24,7 +24,7 @@ related articles:
2424

2525
> [!infobox|n-th]
2626
>
27-
> ## The Lawnmower
27+
> ## The LawnMower
2828
>
2929
> > [!caption|center wfull txt-s]
3030
> >
@@ -42,10 +42,10 @@ related articles:
4242
4343
![[guides/groundcover/index#^groundcover-navbox|clean right]]
4444

45-
**The Lawnmower** is a tool for cleaning [[guides/groundcover/index|groundcover]] mods of excess grass using Python scripts and Tes3conv.
45+
**The LawnMower** is a tool for cleaning [[guides/groundcover/index|groundcover]] mods of excess grass using Python scripts and Tes3conv.
4646

4747
> [!NOTE|clean no-t] %%outline of lawnmower tools%%
48-
> The Lawnmower actually comprises four separate tools:
48+
> The LawnMower actually comprises four separate tools:
4949
>
5050
> - **[[the-lawnmower#Lawnmower|'Lawnmower']]**: removes clipping and unwanted grass
5151
> - **[[the-lawnmower#Weedwhacker|'Weedwhacker']]**: thins out grass

0 commit comments

Comments
 (0)