-
Notifications
You must be signed in to change notification settings - Fork 120
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add scanner node #540
base: master
Are you sure you want to change the base?
Add scanner node #540
Conversation
I'll look at the mod and source later today or tomorrow. The recipe should be more expensive, see detector. Maybe add a microcontroller and wire up the center and remove the torches. You could allow the values to be configured via digilines, I think the detector allows that. The detector can also return which node it sees over digiline, perhaps this could return the exact slot count along with output status in its GET message. |
Yeah, given that it's pretty powerful it can be more expensive. That's why I added the crystal but maybe that's not enough? Digiline functionality can also be expanded. Have it be programmable via digilines was on my roadmap but I wanted to get the PR done in reasonable time. I'll take a look at the detector and maybe push some more digiline code to the branch. |
Maybe also leave digiline channel field empty and only send messages in case it has been configured. |
Place an inventory and scanner, click empty button and save. Place wire or lightstone on output... does it work for you? |
Nope, it doesn't power the the wire. Might have been introduced when I added the "only update on change" part. |
Didn't test. |
Which is exactly why it's needed :) |
…nodes placed after state change also are updated
@auouymous I fixed the output update bug by always updating the mesecon state on timer callback and not only when output is changed. To avoid this, is there a callback that is called when adjacent nodes are updated/changed so we can just do the mesecon state update there instead of on every timeout? Another issue is the wield image. If I set the image it just looks flat. If I don't set the image, it renders the node fine but it's too low on the screen and barely visible. Is there a wield_offset, like wield_scale? Edit: Or a wield_rotate might work also to show it on it's side. |
The problem is that you set both nodes to the off state. Change the "on" node to the "on" state and it works fine. And then undo the fifth patch that always sets state.
|
If I do that the scanner will power adjecent nodes, also on the sides. |
That is what output rules are for. Only the output side should be returned. |
…nups and changes.
Ah I see now. I based this off the switch at first and then I realized it was more like the delayer and started looking at that code instead. I see now what I missed. |
on_timer should recalculate low/high if i_size ~= meta:get_int("inventory_size"), otherwise a chest upgrade/downgrade will have incorrect low/high values. Am I right to assume that a chest with 101 slots will have low=2 for "has items"? |
…n inventory has changed
Good catch on both points. Should work as intended now. |
Sorry for the late reply, it seems to work as expected. Although, it would be nice if it could power from its two sides to allow more compact setups. |
After building with it a few times I was thinking the same thing. I will fix that. Another thing that I'm not quite sure how to fix is how to make it look good when wielding. Currently it's just a flat texture. If I use the 3D model, it's way too low and barely visible. Is there a way to change the offset of how it is displayed when wielding? |
I removed the wield image so that the 3d model is displayed in hand. I think that's better. Even though it's low, you can still see it. This problem can also be seen with insulated mesecon which isn't visible at all so I think it's ok. |
Logic gates and luacontroller use their model and are hard to see as well. |
i'm no expert in this, but maybe this should be integrated into another mod like https://github.com/minetest-mods/MoreMesecons |
The Scanner Node
The scanner node will scan any inventory of the node behind it and output a signal depending on its configuration. It also has digilines support (which means every node with inventory has suddenly become digiline aware, albeit in a limited manner).
Functions:
I'm not sure about the timer though. Currently it checks once per second. Don't know what's appropriate here.
This is my first ever Minetest mod development and first contact with Lua as well so please be gentle :)