Skip to content

Commit

Permalink
Merge pull request #3009 from rajat2004/weather-api-crash
Browse files Browse the repository at this point in the history
Fix Weather API crash
  • Loading branch information
zimmy87 authored Jul 23, 2021
2 parents 602be60 + c9cd185 commit a072a1b
Show file tree
Hide file tree
Showing 2 changed files with 60 additions and 2 deletions.
52 changes: 52 additions & 0 deletions PythonClient/environment/setup_path.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,52 @@
# Import this module to automatically setup path to local airsim module
# This module first tries to see if airsim module is installed via pip
# If it does then we don't do anything else
# Else we look up grand-parent folder to see if it has airsim folder
# and if it does then we add that in sys.path

import os,sys,inspect,logging

#this class simply tries to see if airsim
class SetupPath:
@staticmethod
def getDirLevels(path):
path_norm = os.path.normpath(path)
return len(path_norm.split(os.sep))

@staticmethod
def getCurrentPath():
cur_filepath = os.path.abspath(inspect.getfile(inspect.currentframe()))
return os.path.dirname(cur_filepath)

@staticmethod
def getGrandParentDir():
cur_path = SetupPath.getCurrentPath()
if SetupPath.getDirLevels(cur_path) >= 2:
return os.path.dirname(os.path.dirname(cur_path))
return ''

@staticmethod
def getParentDir():
cur_path = SetupPath.getCurrentPath()
if SetupPath.getDirLevels(cur_path) >= 1:
return os.path.dirname(cur_path)
return ''

@staticmethod
def addAirSimModulePath():
# if airsim module is installed then don't do anything else
#import pkgutil
#airsim_loader = pkgutil.find_loader('airsim')
#if airsim_loader is not None:
# return

parent = SetupPath.getParentDir()
if parent != '':
airsim_path = os.path.join(parent, 'airsim')
client_path = os.path.join(airsim_path, 'client.py')
if os.path.exists(client_path):
sys.path.insert(0, parent)
else:
logging.warning("airsim module not found in parent folder. Using installed package (pip install airsim).")

SetupPath.addAirSimModulePath()
10 changes: 8 additions & 2 deletions Unreal/Plugins/AirSim/Source/WorldSimApi.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -378,15 +378,21 @@ bool WorldSimApi::setObjectScale(const std::string& object_name, const Vector3r&

void WorldSimApi::enableWeather(bool enable)
{
UWeatherLib::setWeatherEnabled(simmode_->GetWorld(), enable);
UAirBlueprintLib::RunCommandOnGameThread([this, enable]() {
UWeatherLib::setWeatherEnabled(simmode_->GetWorld(), enable);
},
true);
}

void WorldSimApi::setWeatherParameter(WeatherParameter param, float val)
{
unsigned char param_n = static_cast<unsigned char>(msr::airlib::Utils::toNumeric<WeatherParameter>(param));
EWeatherParamScalar param_e = msr::airlib::Utils::toEnum<EWeatherParamScalar>(param_n);

UWeatherLib::setWeatherParamScalar(simmode_->GetWorld(), param_e, val);
UAirBlueprintLib::RunCommandOnGameThread([this, param_e, val]() {
UWeatherLib::setWeatherParamScalar(simmode_->GetWorld(), param_e, val);
},
true);
}

std::unique_ptr<std::vector<std::string>> WorldSimApi::swapTextures(const std::string& tag, int tex_id, int component_id, int material_id)
Expand Down

0 comments on commit a072a1b

Please sign in to comment.