-
Content Count
1,559 -
Joined
-
Last visited
-
Days Won
133
Content Type
Profiles
Forums
Blogs
Forum & Tracker Requests
Downloads
Gallery
Store
Calendar
Everything posted by JCarter426
-
Does anyone have a lightmap tutorial? Even through Archive.org I can't find any with the content intact.
-
Jedi Academy's KotOR Lightsabers to be put into KotOR
JCarter426 replied to Rooxon's topic in General Kotor/TSL Modding
When something like that happens, I convert the model back to ASCII through MDLOps and then work from there. This usually fixes the discrepancy between what you see in your modeling program and what you see in the game. If you still have problems, I can take a closer look at your hilts in a few days, and see about making that extended tutorial too. Just backed up with a bit of work at the moment. -
This part is problematic. Local booleans behave a little weirdly, so to avoid issues I'd recommend calling them in the following ways: if( GetLocalBoolean(OBJECT_SELF, 53) ) { or if( !GetLocalBoolean(OBJECT_SELF, 53) ) { I forget what the issue is precisely, but it's something along the lines of they can never be set to false; they're either true or not true.
-
Jedi Academy's KotOR Lightsabers to be put into KotOR
JCarter426 replied to Rooxon's topic in General Kotor/TSL Modding
Ah, I'm familiar with some of your previous lightsaber hilts. Converting them for KOTOR isn't too difficult, but its modding tools are a bit finicky. Firstly, you need to export an existing lightsaber hilt of the same type. The models are w_lghtsbr_***, w_dblsbr_***, and w_shortsbr_***, in either models.bif or items.bif depending on the game. You need both the MDL and MDX files; put them in a folder somewhere, unedited. Next you need MDLOps to convert the binary models (MDL and MDX) to an ASCII format that NWMax can read. Load the saber MDL and select "read and write model". It'll automatically generate a new model (for example, w_lghtsbr_001-ascii.mdl). This is the file you want to import into your modeling program through NWMax (import geometry & animations, on the left under "MDL Loading"). Merge your own saber geometry (just the hilt) into the scene, then move and resize it so it more or less matches the original saber. After you're done with that, delete the old saber and then use ResetXForm in NWMax's Mesh Tools on your saber geometry. That's basically a safety to make it use the correct transformation data, because it can get confused and use the original settings sometimes. Link the saber blade geometry to your hilt, then link your hilt to the saber dummy (not the Aurora Base, the other one). Once you're done editing your model, select the Aurora Base and export it through the Modify panel. Make sure you export this in a new location so you don't mess up any models you've been working with (I usually send it straight to the desktop). Export geometry and animations, and you can ignore the sanity check as that thing is never helpful. This will generate a file with the same name as your Aurora Base, but it's still in ASCII format and has to be converted back to binary to be loaded in the game. Rename the file, adding the extension "-ascii_new" (e.g. w_lghtsbr_001-ascii_new.mdl) and put it in the folder with all your other models. You'll need MDLOps 0.5 for this next step; it doesn't work in version 0.6 and 0.7 doesn't currently support it. Select the Replacer tool and load the binary model (the one you extracted from the game files) and the ASCII model (your own edited one). When you hit "read models" a new window will come up, asking you to replace stuff. Select the original hilt (it will be named "lshandle" or some such) and replace it with your saber hilt geometry. Essentially, you're taking the hilt from your edited model and placing it in the original binary model with the correct blades. The blade color will depend on the model (001 is blue, 002 is red, 003 is green, 004 is yellow, 005 is violet, and the K2 colors aren't consistent so you'll have to look those up). You'll either have to run the replacer several times for each color, or duplicate the compiled models and hex edit the saber names and blade colors, whichever you prefer. You will have to use the replacer for the red saber anyway, because the blade texture has a different number of characters (w_lsabrered01 as opposed to, for example, w_lsabregren01 for green). Anyway, after you have all your models, move them to Override and rename them. Copy all your textures as well. If your textures use an alpha channel for shaders, you'll need to generate another file for that, but it's pretty simple. A simple metallic shader is a text file that says "envmaptexture cm_baremetal". Rename the file to match the hilt texture's name and change the file extension to TXI. One last thing: K1 and K2 models are in a slightly different format, and may cause the game to crash if one is placed in the other. So you'll need to repeat these steps separately with binary files extracted from each game. I think that's everything. I can go over it in more detail later (with pictures and such) if you want. -
No, as I said that's the only element in the rendering engine that functions that way. Models are 3D objects that have texture applied across the whole geometry and that texture is visible (or not visible) from any angle. Only particles have variant rendering.
-
It's not possible. Currently, anyway. The only visual effect that functions the way you want is the particle system. I ran into this problem when I was trying to make my own weather. The end result of that was I got SS to teach me how to use the particle system. Lightsabers don't use particles. Instead they have a rather hacked method of two planes perpendicular to each other, with some trickery with the alpha channels. Even if we could add particle emitter support for lightsaber models - which they currently do not have - I don't believe there's any existing emitter that creates a single, stationary particle... nor am I sure you could get the blade to retract properly.
-
Bastila Shan should have been a Jedi Knight
JCarter426 replied to Salk's topic in Knights of the Old Republic General
Well, I suppose technically he was a knight for the duration of one conversation. Then he became a master. But that's beside the point. I don't know how else to explain it. Every Jedi character that appears in the game is called either a padawan or a master. Bastila is a padawan in training to become a master. Apprentices are bestowed the rank of padawan upon completing trials, which is exactly how knighting works in other stories. No, she was still a padawan too. She still had a master and was in training. That's the collective term again. I'm talking about knight as a distinct rank between padawan and master. For example, "A small squadron of Jedi Knights in snub fighters could penetrate the Sith blockade and dock on the space station." Vandar isn't talking about Jedi with the rank of knight, specifically. Surely some of them are masters. Some of them may be padawans. But they're all "Jedi Knights". The only named characters ever called knights in the game are actually Revan and Malak, but I don't see any clear mention of that as their specific either - just that Revan was a "charismatic knight" and so on. The word only shows up 44 times in the TLK, and a lot of those instances are due to the game's title or item names. -
Bastila Shan should have been a Jedi Knight
JCarter426 replied to Salk's topic in Knights of the Old Republic General
The problem is they didn't use Jedi Knight as a rank at all. The only ranks mentioned in the game are apprentice, padawan, and master. The player goes from apprentice to padawan; Bastila is explicitly called a padawan and she speculates the Council is testing her to see if she's ready to be a master, so presumably that's the next step for her - no knights. The first thing wrong with this is that apprentice and padawan are not distinct ranks in other works. When Obi-Wan is Qui-Gon's apprentice, he is also a padawan. Tales of the Jedi predates the term "padawan", but has Arca's apprentices transition immediately to knighthood. Also, in a modern guild system, apprenticeship is only attained upon completing the first level of education; so if one were to make a distinction, I'd say padawan would be the lowest rank, with an apprentice specifically being a padawan that has a master. The second problem is that apparently you go right from padawan to master. While in some situations this is true (Obi-Wan again), there's clearly meant to be the intervening rank of knight because there are knights that are not masters, but also no longer have masters (e.g. Anakin in Revenge of the Sith, Luke in Return of the Jedi). Essentially, they used padawan in place of knight. Perhaps it was to avoid the confusion of how Jedi as a whole are called "Jedi Knights" regardless of their rank. -
Placeables and doors have no scripts for us to look at, and I have no knowledge of a script governing what the security spike actually does, either. It's not a spell and the baseitem.2da lines for K1 and K2 are identical, and I don't see anything obvious in the source scripts, or a function in NWScript. So on that front I don't believe there's anything we can do. There's simply no code for us to look at. However, I don't think that's the issue anyway. My guess is it's a GUI problem. If the security spike simply doesn't show up in the PC GUI, that is. I don't recall what happens, because I've been ignoring the things for over a decade. But if that's the case, that would be my guess. They did change the GUI for the PC version, so it's possible that was left out somehow. We'd have to compare the GUI files to be sure. Unfortunately, the Xbox files for K1 are not included in the PC version. However, both the PC and Xbox files for K2 are, so it might be worth a look still. If it's as simple as a missing entry or a typo, it can be fixed... but it very well still could be something hard coded.
-
Need help from all the great texture artists around here
JCarter426 replied to Kexikus's topic in General Kotor/TSL Modding
I was primarily thinking of the clouds, yeah. Although the International Space Station is above the stratosphere, as you can see here. The lights I was referring to are the red ones that seem to be randomly distributed on control towers or some such, not just lights from buildings. You can see them pretty clearly in MalMov01.bik. -
Need help from all the great texture artists around here
JCarter426 replied to Kexikus's topic in General Kotor/TSL Modding
I had this problem as well. I've made 3D models of most of the game's planets, but I could never get Telos right either. Yours looks much better than any of my attempts, but it looks like you've run into the same problem I did with the station. First, it looks a little flat. It's hard to make it have depth because of how small the height is relative to the width, but a little more drop shadow or emboss might help. Second, it looks uniform. In the Bink videos, there are bits sticking out that are just scaffolding with nothing built on them, there are buildings noticeably larger than the ones around them, and there are red lights dispersed across the station. I think part of why it looks uniform is all the detailing sticks out so much, so if you add another layer for the larger buildings, and then one for control towers with the lights, you could tone down the contrast of the station layer so the outlines aren't as obvious. In the Bink video, most of the gridwork blurs together. Putting a scaffolding layer underneath might also help with the depth. Another thing the Bink videos have are more prominent longitudinal lines... like the station was constructed from vertical strips. And I agree about the atmosphere. It makes the station look translucent. Great work so far, though. Really, it looks far better than mine did. -
There are Selkath VOs on the Xbox version. The name Liskis sounds like a Trandoshan, Quarren, or Twi'lek to me, though.
-
Kotor/Neverwinter III Legacy???
JCarter426 replied to Jorak Uln's topic in General Kotor/TSL Modding
Actually, there are belt models in the game - i_belt_001 through 014. As has been discussed before, though, you need a hook on the body models for anything to appear (and I don't believe they have belt hooks) and you also need a way of telling the game to render the belt model on the belt hook when it's equipped... which nobody has figured out how to do in KOTOR, to my knowledge. Some of it seems to be in the 2DAs but I could never get anything new to show up when I messed around with it. The key data could very well be hard coded. -
Here's my folder and its contents so far. Now it's time to convert this file with MDLOps. Load your edited ASCII file, then read and write. MDLOps will generate a new MDL and MDX. Run the Head Fixer on the MDL. The Head Fixer creates a new, fixed MDL file to put the animations back. Rename the fixed MDL and the MDX file from the previous step to whatever you want. However, the file name must have the same number of characters as the original (in this case 8). You could get around this by renaming before you export, but it requires more setup work, so I resign to keeping it the same. Once you've chosen your name, open the MDL in a hex editor. Find and replace the original name (mine was P_AttonH) with your new name (mine is JC_DuH01). Be careful to only replace characters, not delete them; that would break the model and cause your game to crash, most likely. There are 5 Duros textures in the game, so at this stage I use the same process to create duplicate models for each texture variation. After some 2DA editing to get the head in the game, or in my case simply keeping it as P_AttonH for a quick test, we can see our final result: Behold, a new head that can go on any body. You can use roughly the same process to create new full body models if you like, mixing heads and bodies from different models. That's what I did for the Handmaiden Sisters and I've made a tutorial here. So, go make new heads, and good luck!
-
Open your original head project (Atton Template for me). Select and rename everything with Tools -> Rename Objects. Add a prefix, something that makes it obvious which head these objects belong to. Now merge it with everything from your head project (I called mine Duros Head 1). With that imported, you should see one head at the origin and one above it. Select everything on the top half and move it down. Make it overlap the other head as much as it can. Now that everything is in position, you can link the MaskHook and GoggleHook helpers to head_g with the Select and Link tool. For this next part, hide everything except the two head geometries to make it easier to see them. Then you need to turn on the Snap Toggle so you can snap to vertices. Select your new head geometry and go edit the editable mesh. Move each vertex along the bottom circumference of the neck into the corresponding positions on the template head. These two heads have the same number of vertices so it's pretty easy. If you're not so lucky, you might need a bit more modeling skill to get them in place. You may also have to adjust the vertex weighting, which is not very fun. I didn't have to for the Duros, or the majority of the heads I've done so far, so I'm not going to cover that here. I also decide to scale down the second layer of vertices to match Atton's neck more closely, so there isn't a bulge. Once you're satisfied with your vertices, unhide everything and then delete all the objects in the template head. You won't need them anymore. The Duros model was lacking a texture, so I applied one here using the material editor. I notice his head includes a turtleneck, so later I might remap the model to remove it. Or maybe Duros just get cold easily. Now, this part is important. I only learned this through experimentation, because frankly it's not a very intuitive part of the design. Animations are applied to the head and body separately, meaning you can end up with each part playing entirely different animations if you don't give them the same setting. We don't want the Duros to use Atton's animations, so I change the supermodel to S_Female02, the default male supermodel. We do this by selecting the Aurora base and changing the text in the box next to Super in the MDL Base Parameters. We could change it to something else if we like; I might decide I want the Duros to retain his hunched over posture... if so, I would make some new body models that use those animations and then set the head's supermodel correspondingly. Now's a good time to save again. I save in different slots; that way if I screw something up, I won't have to start over from the beginning. I also notice the goggle and mask hooks are most certainly in the wrong places, so I reposition them. There's only so much I can do, however, as the shape of the head is just too different from a human's; only the breath mask looks any good. When you're finished editing, select the Aurora base and export as geometry only. Export it anywhere except in your folder, so you don't accidentally overwrite something. Now rename your file to something new - again, so you don't overwrite. The naming scheme I use is the original model name, plus "-ascii", plus "_new". Move this file to your folder now.
-
Now save this as a new project. In a new project, import your full body model (mine is N_Duros). Now delete everything except the highlighted items below. Again, it will differ from model to model. What you're trying to keep is the object necklwr_g and all its children, as well as the head geometry - called here simply "head", but it may be "Head_Geo" or even part of "torso". This head is already its own object so that's it. Other models have the head as part of the torso - but that's fine, as you can simply delete all the vertices below the neck for those. In any case, save this project once you're finished. With this project still open, go to File -> Merge and import everything from your head template project (mine was Head Template Male). Select necklwr_g and link it to torsoUpr_g with the Select and Link tool. Now it should look like this. Next, select the head geometry and the Aurora base (here, P_AttonH). Link them using the Fast Linker tool in NWMax. Now save this as a new project. There's a point to all these separate files, I assure you.
-
Fascinating discoveries researching NWN tools
JCarter426 replied to xander2077's topic in General Kotor/TSL Modding
When I was working on something unrelated earlier, I noticed that the model PMBBL actually does have hooks for the collar and left forearm. So I wonder if there is some usable material left after all. -
Yeah, I'll get on the K1 soon. Just a few adjustments because K1 lacks a few functions and I have to remove that info from it, and also account for a bug in K1. I didn't feel like doing that with an untested script but since it is working then I'll go ahead with that. All that's needed for compatibility is for the other modder to add the ExecuteScript line to fire your script, in addition to their changes. So it's not difficult, but it requires awareness of other mods that edit it and cooperation and such. And regarding the head stuff... I did some testing and basically got nowhere. There's no way to consistently force an NPC outside the module, it's just too random. I had another idea that seemed like it was going to work, creating an NPC with no body, just the head hook, and placing the head hook below the module... but that didn't cooperate with the DuplicateHeadAppearance function, so it was a dead end. But it was close... so close. Although, I did confirm the convoluted process does work. It's still just a matter of hiding the NPC from view.
-
This is a repost of an old tutorial I did on LucasForums. The original discussion thread is HERE. This tutorial will go over the process of ripping heads from a full body model, as I did in my modding resource JC's Heads for K2. Through this method, we'll be able to take a Duros character and let him use any body model in the game, just as most human characters as well as Twi'leks and Devaronians can. No longer will he be cursed to wear a white jumpsuit. I'll note that at the time I'm writing this, I have only made heads for Knights of the Old Republic II: The Sith Lords. But I believe the process is the same for the first game. Tools you will need: KOTOR Tool MDLOps 0.7a2 (or later) a 3D modeling program that supports NWMax (such as 3ds Max or Gmax) NWMax a hex editor To start, extract the model you want to turn into a head. In this case, n_duros. Extract both the MDL and MDX files. Next, extract a head to use as a template. It should be similar to your final result, so that means roughly the same size, and at least the same gender. Make sure to get one with the mask and goggle hooks already on it. I like to use Atton's head, as that makes it easy to test as well. Again, extract both the MDL and MDX. Now extract the texture for your head. In this case, N_Duros01. Save as TGA. Place all these files in a folder somewhere, then convert each model to ASCII using using MDLOps. In your modeling program, import your head template model (mine is P_AttonH). Import geometry only. Immediately save this project. After it saves, delete all the highlighted items below. The names will differ slightly depending on which head you're using, but the stuff you keep should all be the same (except the Aurora base, which has the name of the model).
-
This is a repost of an old tutorial I did on LucasForums. The original discussion thread is HERE. So, one benefit of plot usable items is that if they have an activate property you can use them even if you don't have them equipped, so long as the item is in your inventory. But one thing I've noticed is there are over 200 existing icons, and the engine only supports up to 255 (well, 256 if it accepts 000, but I've never actually checked). So there isn't much room for your items to have custom icons like there is with other item types. However, there are a whole bunch of icons left over from K1 which are not used at all. So I made a list of all the ones I could find that are currently used (it's not inconceivable that I missed some): 22 7 10 12 16 17 23 25 29 35 42 55 56 59 60 61 62 63 64 65 66 67 68 71 72 77 78 84 85 86 88 89 90 91 92 94 95 96 98 99 100 101 102 103 106 107 108 109 110 111 122-251Again, those are the ones that are used. If you use one of those, it will affect other items in the game. So don't use them. 69, 70, 74, 75, 113-122 and 252-255 don't exist at all; the others exist but shouldn't appear in the game. And in case you don't know... Plot Usable Item is a base item type that appears in your inventory but cannot be equipped. It is similar to the Aesthetic Item type, which uses the same icon set (and thus meaning there are even fewer numbers for us to use). The difference between the two types (I think) is that if a Plot Usable Item has an Activate Item property, the item will appear in your action menu. This allows you to have access to usable item equipping it - meaning a) you don't use up and equipment slot, so you can equip other things, and the whole party will have access to the item. I don't think this feature was actually used in the game, however. To create a plot usable item, create a new item and set the base item type to Plot Usable Items. Model Variation determines the icon number. The icons themselves are located in ERFs -> Texture Packs -> ***_GUI -> I, and the files all begin with "ip_pltuseitm_" (e.g. the unused holocron is ip_pltuseitm_072.tpc). Some additional information: 1 is a book of some kind. 11 is a Mandalorian helmet. 12 (used), 28, and 35 (used) all have Czerka logos. 15 has the Star Forge symbol on it - I think it's the Sith medallion from K1. 24 and 39 are crystals. 32 is the krayt dragon pearl. 33 is a Sand Person. 40 is Sith armor. 44-53 are all keycards. 72 is a holocron (107 is also a holocron, but is used for an HK part). 79 is the dancer's outfit, but the icon that is actually used is ia_slave_001 (I believe this is true of the Sith and Sand People disguises as well - so they wouldn't even be used in K1). 83 is another dancer's outfit, resembling Leia's more than the one in the game. Anyway, long story short, feel free to use any number that is not on this list. The only issue would be compatibility with other mods that do the same thing.
-
This is a repost of an old tutorial I did on LucasForums. Original posts can be found HERE. The combat animations are in fact in the regular old animations.2da; combatanimations.2da is more like a seating arrangement. It lists all the attacks and then states which animation goes with it - hit, parry, dodge, and so on. It's entirely numbers so it can be a mess. animations.2da gives you more of a clue, but the naming scheme can seem a bit weird at first glance. The animation name is an alphanumeric code with four parts, alternating letters and numbers. The first part corresponds to the attack type - a generic attack, a feat, or a monster attack. There also seems to be some attempt to divide it into ranged and melee, but I can't discern it entirely. b - ranged c- melee f - feat g - generic m - monsterNext, it's divided into weapon type as well as whether the character wielding one or two. These are given abbreviations for K2 only. 0 - N/A - droid 1 - SB - stun baton 2 - SS - single saber 3 - 2HS - two-handed saber (double-bladed) 4 - DS - dual sabers 5 - SB - single blaster 6 - DB - dual blasters 7 - RF - rifle 8 - NT - natural attack (unarmed, I believe) 9 - HC - heavy carbine 10 - UC - unarmed, complex (K2 only) 11 - N/A - wrist launcher (K2 only)Next, what the character is doing. a - attack d - damage f - appears unused g - dodge n - deflection p - parry r - ready w - wieldAnd finally, another number. In most cases this is simply a variation number; some in K2 have an additional letter, for even more variation. So, for example, if you want a character wielding a blaster rifle to dodge, the animation would be g7g1. g: generic 7: rifle g: dodge 1: variation (in this case there's only one) In the original thread, Fallen Guardian asked about power blast. This is where it gets complicated. Some of these variables are limited by other variables. Parry, for instance, is only a melee occurrence. I believe this is the reason for the distinction between ranged and melee that I mentioned above. Let's look at the first part again. 1:b - ranged 1:c - melee, complex 1:f - melee, feats 1:m - melee, monster 1:g - both, genericAnd now let's look at the third part. 3:a - both, attack 3:d - both, damage 3:g - ranged, dodge 3:n - melee, deflection 3:p - melee, parry(Putting this in code because of the emoticon.) 1:b is used for [i]all[/i] blaster attack animations. 1:c covers complex melee animations such as parries and clashes. 1:f is reserved for melee feats - critical strike, flurry, and power attack, as well as Force Jump. 1:m is for engaging a monster in melee. 1:g is anything else. 3:a is used for any attack. 3:d is used for any damage. 3:g is used for dodging ranged attacks. 3:n is used for deflecting ranged attacks with a lightsaber. 3:p is used for parrying melee attacks.Because of these specifications, certain ones do not belong with certain other ones. If that's not confusing enough, the final number is not always a simple variation; what it is depends on both of the above letter slots. I'll go over the feats for you. MELEE (f***) 1 - critical strike 2 - flurry 3 - power 4 - jump RANGED (b***) 1 - attack 2 - attack 2 3 - sniper shot 4 - power blast So, finally, a power blast animation is b*a4. The asterisk is either 5, 6, 7, or 9, depending on whether you are dealing with a single blaster, dual blasters, a rifle, or a heavy carbine. To make things even more confusing, there are a couple other animations that use the same scheme, in a way. The knocked down animations, for instance, are g1x1, g1y1, and g1z1. And in K2, there are multiple ready animations for lightsabers, the final number corresponding to the saber form, but I don't know if they ever finished the animations for them. If you're still confused, the 2DA for K2 has a description column that might help. The format is virtually the same as K1's, but of course K2 has more animations so you shouldn't go by it entirely.
-
No, it... those are two different things. There are some areas with just corrupted walkmesh data. There's a tiny bit that counts as a walkable point, even though it's not connected to anything else. As far as I'm aware it's not actually part of any room's walkmesh - probably just garbage data. But it happens with a lot of modules, not just Telos. And it's usually far below the rest of the module. One example is 950COR. It's possible to teleport into the skybox and for some reason HK-47 is hanging out there. As for the second thing, what I mean is that when you spawn a creature it spawns in at the nearest possible location. So if you spawn one, for example, a meter below the floor, it will usually spawn it on the floor. It ignores the Z value you input because there's no walkmesh there, instead getting the nearest workable location. Generally this location has the correct X and Y value, but if you try to spawn something inside a wall or another object or whatever, it will similarly be displaced along those axes. So if you spawn a creature with an extreme negative Z value, there's a chance it will end up at one of those weird points instead of any legitimate coordinates. But it's highly dependent on the module. I don't want to change the direction the camera's facing, though... that would probably be more distracting. I'd only want to get the direction, and as far as I'm aware there is no such function.
-
It works with some modules. The walkmesh is a bit wonky at points, and it's possible to teleport to locations outside the main area, usually far below it. Even if it doesn't work, the game should ignore the Z value in such a case but not the X or Y so it wouldn't hurt to try. There is one other problem though. It's possible to have the camera facing in a different direction than the player is.
-
Yeah, I might try that... Maybe cycle through each creature until there's no line of sight, and if that doesn't work spawn behind the player outside their field of vision, with an extreme negative Z value to try to force them below the module if possible.
-
Under the module might work... I'm not sure if it would work with every module, though. I thought about doing it in relation to the player's location, but the problem is there's still no way to tell where in the module the player is. To spawn them outside of the player's field of vision, right? The problem is if the player is at the very edge of the module and facing towards the other end, there is nowhere behind the player and the creature could end up spawning right next to them. Then again, the creature only has to exist for a fraction of a second, so it's not a huge issue. And it's possible to put in a few different options, depending on what works best. For example, getting the location of whatever object is farthest away from the player, and if that's not far enough away then to try some other option.