mirror of
https://github.com/Relintai/pandemonium_engine.git
synced 2025-01-08 20:09:36 +01:00
Fix LayeredTileMapPattern::get_used_cells().
This commit is contained in:
parent
fe901f22bd
commit
c67d45375b
@ -900,8 +900,10 @@ void LayeredTileMapLayerEditorTilesPlugin::forward_canvas_draw_over_viewport(Con
|
|||||||
|
|
||||||
PoolVector2iArray selection_used_cells = selection_pattern->get_used_cells();
|
PoolVector2iArray selection_used_cells = selection_pattern->get_used_cells();
|
||||||
for (int i = 0; i < selection_used_cells.size(); i++) {
|
for (int i = 0; i < selection_used_cells.size(); i++) {
|
||||||
Vector2i coords = tile_set->map_pattern(offset + top_left, selection_used_cells[i], selection_pattern);
|
Vector2i cc = selection_used_cells[i];
|
||||||
preview[coords] = LayeredTileMapCell(selection_pattern->get_cell_source_id(selection_used_cells[i]), selection_pattern->get_cell_atlas_coords(selection_used_cells[i]), selection_pattern->get_cell_alternative_tile(selection_used_cells[i]));
|
Vector2i coords = tile_set->map_pattern(offset + top_left, cc, selection_pattern);
|
||||||
|
|
||||||
|
preview[coords] = LayeredTileMapCell(selection_pattern->get_cell_source_id(cc), selection_pattern->get_cell_atlas_coords(cc), selection_pattern->get_cell_alternative_tile(cc));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (drag_type == DRAG_TYPE_CLIPBOARD_PASTE) {
|
} else if (drag_type == DRAG_TYPE_CLIPBOARD_PASTE) {
|
||||||
@ -1139,19 +1141,23 @@ HashMap<Vector2i, LayeredTileMapCell> LayeredTileMapLayerEditorTilesPlugin::_dra
|
|||||||
} else {
|
} else {
|
||||||
// Paint the pattern.
|
// Paint the pattern.
|
||||||
// If we paint several tiles, we virtually move the mouse as if it was in the center of the "brush"
|
// If we paint several tiles, we virtually move the mouse as if it was in the center of the "brush"
|
||||||
Vector2 mouse_offset = (Vector2(pattern->get_size()) / 2.0 - Vector2(0.5, 0.5)) * tile_set->get_tile_size();
|
Vector2i pattern_size = pattern->get_size();
|
||||||
|
Vector2 mouse_offset = (Vector2(pattern_size) / 2.0 - Vector2(0.5, 0.5)) * tile_set->get_tile_size();
|
||||||
Vector2i last_hovered_cell = tile_set->local_to_map(p_from_mouse_pos - mouse_offset);
|
Vector2i last_hovered_cell = tile_set->local_to_map(p_from_mouse_pos - mouse_offset);
|
||||||
Vector2i new_hovered_cell = tile_set->local_to_map(p_to_mouse_pos - mouse_offset);
|
Vector2i new_hovered_cell = tile_set->local_to_map(p_to_mouse_pos - mouse_offset);
|
||||||
Vector2i drag_start_cell = tile_set->local_to_map(p_start_drag_mouse_pos - mouse_offset);
|
Vector2i drag_start_cell = tile_set->local_to_map(p_start_drag_mouse_pos - mouse_offset);
|
||||||
|
|
||||||
PoolVector2iArray used_cells = pattern->get_used_cells();
|
PoolVector2iArray used_cells = pattern->get_used_cells();
|
||||||
Vector2i offset = Vector2i(Math::posmod(drag_start_cell.x, pattern->get_size().x), Math::posmod(drag_start_cell.y, pattern->get_size().y)); // Note: no posmodv for Vector2i for now. Meh.s
|
|
||||||
Vector<Vector2i> line = LayeredTileMapLayerEditor::get_line(edited_layer, (last_hovered_cell - offset) / pattern->get_size(), (new_hovered_cell - offset) / pattern->get_size());
|
Vector2i offset = Vector2i(Math::posmod(drag_start_cell.x, pattern_size.x), Math::posmod(drag_start_cell.y, pattern_size.y)); // Note: no posmodv for Vector2i for now. Meh.s
|
||||||
|
Vector<Vector2i> line = LayeredTileMapLayerEditor::get_line(edited_layer, (last_hovered_cell - offset) / pattern_size, (new_hovered_cell - offset) / pattern_size);
|
||||||
for (int i = 0; i < line.size(); i++) {
|
for (int i = 0; i < line.size(); i++) {
|
||||||
Vector2i top_left = line[i] * pattern->get_size() + offset;
|
Vector2i top_left = line[i] * pattern_size + offset;
|
||||||
for (int j = 0; j < used_cells.size(); j++) {
|
for (int j = 0; j < used_cells.size(); j++) {
|
||||||
Vector2i coords = tile_set->map_pattern(top_left, used_cells[j], pattern);
|
Vector2i cc = used_cells[j];
|
||||||
output.insert(coords, LayeredTileMapCell(pattern->get_cell_source_id(used_cells[j]), pattern->get_cell_atlas_coords(used_cells[j]), pattern->get_cell_alternative_tile(used_cells[j])));
|
Vector2i coords = tile_set->map_pattern(top_left, cc, pattern);
|
||||||
|
|
||||||
|
output.insert(coords, LayeredTileMapCell(pattern->get_cell_source_id(cc), pattern->get_cell_atlas_coords(cc), pattern->get_cell_alternative_tile(cc)));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -152,10 +152,13 @@ PoolVector2iArray LayeredTileMapPattern::get_used_cells() const {
|
|||||||
// Returns the cells used in the tilemap.
|
// Returns the cells used in the tilemap.
|
||||||
PoolVector2iArray a;
|
PoolVector2iArray a;
|
||||||
a.resize(pattern.size());
|
a.resize(pattern.size());
|
||||||
|
PoolVector2iArray::Write w = a.write();
|
||||||
|
Vector2i *wptr = w.ptr();
|
||||||
|
|
||||||
int i = 0;
|
int i = 0;
|
||||||
|
|
||||||
for (const HashMap<Vector2i, LayeredTileMapCell>::Element *E = pattern.front(); E; E = E->next) {
|
for (const HashMap<Vector2i, LayeredTileMapCell>::Element *E = pattern.front(); E; E = E->next) {
|
||||||
Vector2i p(E->key().x, E->key().y);
|
wptr[i++] = E->key();
|
||||||
a[i++] = p;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return a;
|
return a;
|
||||||
|
Loading…
Reference in New Issue
Block a user