mirror of
				https://github.com/JohnBreaux/Boat-Battle.git
				synced 2025-02-04 12:28:35 +00:00 
			
		
		
		
	Crosshair now snaps into place
This commit is contained in:
		| @@ -29,7 +29,7 @@ func _on_Confirm_Placement_pressed(): | ||||
| 			valid = false | ||||
| 	print ("Placement: ", valid) | ||||
| 	if valid == false: | ||||
| 		get_node("AcceptDialog").popup() | ||||
| 		get_node("PlaceShipDialog").popup() | ||||
| 	else: | ||||
| 		#Saves the location of ships and length of ship into an array | ||||
| 		var shipLocation = [] | ||||
| @@ -75,5 +75,17 @@ func _on_Clear_pressed(): | ||||
|  | ||||
| func _on_Fire_pressed(): | ||||
| 	var crosshair = get_node("Crosshair") | ||||
| 	print("Fire at position: ", crosshair.position) | ||||
| 	# hides crosshair | ||||
| 	crosshair.visible = false | ||||
| 	if crosshair.validate_position(crosshair.position) == true: | ||||
| 		# fires at position | ||||
| 		print("Fire at position: ", crosshair.position) | ||||
| 	else: | ||||
| 		#if invalid position popup appears | ||||
| 		var dialog = get_node("FireDialog") | ||||
| 		dialog.popup_centered() | ||||
| 	pass # Replace with function body. | ||||
|  | ||||
| func _on_FireDialog_confirmed(): | ||||
| 	get_node("Crosshair").visible = true | ||||
| 	pass # Replace with function body. | ||||
|   | ||||
| @@ -16,14 +16,44 @@ func _physics_process(delta): | ||||
| 		position += (get_global_mouse_position() - position)/10 | ||||
|  | ||||
| func _input(event): | ||||
| 	#Check if left click is being clicked and the sprite is visible (i.e only checks for inputs after ship positions are confirmed) | ||||
| 	# Check if left click is being clicked and the sprite is visible (i.e only checks for inputs after ship positions are confirmed) | ||||
| 	if event is InputEventMouseButton and event.button_index == BUTTON_LEFT and visible == true: | ||||
| 		#Locks the position of the crosshair with left click | ||||
| 		snapped = true | ||||
| 		# Locks the position of the crosshair with left click | ||||
| 		if validate_position(position) == true: | ||||
| 			# rounds the board position to the nearest integer | ||||
| 			snapped = true | ||||
| 			position.x = int(round(world_to_board_space(position).x)) | ||||
| 			position.y = int(round(world_to_board_space(position).y)) | ||||
| 			position = board_to_world_space(position) | ||||
| 	# Check if left click is being clicked and the sprite is visible (i.e only checks for inputs after ship positions are confirmed) | ||||
| 	if event is InputEventMouseButton and event.button_index == BUTTON_RIGHT and visible == true: | ||||
| 		#Unlocks the position of the crosshair with right click | ||||
| 		# Unlocks the position of the crosshair with right click | ||||
| 		snapped = false | ||||
|  | ||||
| func validate_position(vector): | ||||
| 	# rounds the board position to the nearest integer | ||||
| 	var boardx = int(round(world_to_board_space(vector).x)) | ||||
| 	var boardy = int(round(world_to_board_space(vector).y)) | ||||
| 	# Checks if the board position is within bounds of the board | ||||
| 	if boardx < 11 and boardx > 0 and boardy < 11 and boardy > 0: | ||||
| 		# changes the position of the crosshair | ||||
| 		return true | ||||
| 	else: | ||||
| 		# unlocks the crosshair if not within bounds | ||||
| 		return false | ||||
|  | ||||
| # Convert the world-space coordinates to positions on the board | ||||
| func world_to_board_space(vector): | ||||
| 	# Do math | ||||
| 	var res = (vector - offset) / 32 # Basically Fahrenheit/Celcius conversion, but in 2D | ||||
| 	return res | ||||
|  | ||||
| # Inverse of the above function. | ||||
| func board_to_world_space(vector): | ||||
| 	# Do math | ||||
| 	var res = (vector * 32) + offset #Invert the above function | ||||
| 	return res #Truncate decimals | ||||
|  | ||||
| # Called every frame. 'delta' is the elapsed time since the previous frame. | ||||
| #func _process(delta): | ||||
| #	pass | ||||
|   | ||||
		Reference in New Issue
	
	Block a user