Click here to Skip to main content
16,021,169 members
Please Sign up or sign in to vote.
0.00/5 (No votes)
See more:
-q12-
I have a UserControl named Background and a simple class named NavigationArrows.

This NavigationArrows class is loading a bunch of *.png's images displaying some arrows that are lit OR unlit, depending on keypressed by user.
The UC Background, is containing the BIG Background image and is panning it through the Background_KeyPress event.
----
What I want is simple:
I want to connect the arrows to the KeyPress event.
(to show the lit arrow image when a key is pressed)
----
BUT !
I can do it very simple, all inside UC. But I dont want that.
I want the NavigationArrows Class to contain every aspect of the arrows!!!!
loading the images, the !!!Events!!!, position on canvas, size of the arrows, and the rest that I can't think of now. In a word, to contain all the properties, events, methods, that are related to the arrows class/(or object if you want).
My big problem is the connections between the 2 clases. How to connect them in a simple and elegant way, in a LOGICAL way, in a NON-Confusing way.
My way of linking these 2 clases is very confusing in code. Too many arguments here and there. (It is not confusing because of the names I gave - not that) It is confusing because of the structure i must build !!! It is extremely convoluted and wtf at every corner.
----
Right now, in this stage I am presenting the code, it is the begining.
But I will have to load and link the rest of the arrow images (i did not show that here)- it is not scripted yet. But I know from experience, it will become agglomerated very quickly.
Also, I will have to load OTHER classes/objects into canvas too. This Arrow class is just a test. If I have to load 100 clases, each of them containing it's own SET of images (let's say 50 img per class), and with their own Methods and properties, and with their own !!EVENTS!!, that they must be conected to the Background object (somehow).
Do you see what I mean by LOGICAL way and NON-Confusing ?
It must be like a on/off switch this link between object and class. Something like:
UI.NavigationArrows navArrows = new UI.NavigationArrows();
navArrows.Active();
navArrows.pozition(0,0);
navArrows.size(20,20);
And thats it. And they must perform and do their jobs!
How can I achieve this?
Thank you,
-q12-

What I have tried:

public partial class Background : UserControl
//...................

        //UI.NavigationArrows navArrows = new UI.NavigationArrows();
        Rectangle navArrowsRectangle = new Rectangle(10, 10, 100, 100);
        void Background_Paint(object sender, PaintEventArgs e)
        {
            e.Graphics.DrawImage(q1.backgroundImage, q1.rectangle);//BackgroundImage
             
            string imgName = "UI\\NavigationArrows OFF.png";
            Image BaseImg = Image.FromFile(imgName);
            e.Graphics.DrawImage(BaseImg, navArrowsRectangle);//NavigationArrows OFF
        }

        void Background_KeyPress(object sender, KeyPressEventArgs e)
        {
            int th12 = 0;
            if (e.KeyChar == 'w')
            {
                if (q1.rectangle.Y < 0) q1.rectangle.Y += q1.amount;
                else q1.rectangle.Y = 0;
            }
            if (e.KeyChar == 's')
            {
                th12 = -q1.imgy + this.Height;
                if (q1.rectangle.Y > th12) q1.rectangle.Y -= q1.amount;
                else q1.rectangle.Y = th12;
            }
            if (e.KeyChar == 'a')
            {
                if (q1.rectangle.X < 0) q1.rectangle.X += q1.amount;
                else q1.rectangle.X = 0;
            }
            if (e.KeyChar == 'd')
            {
                th12 = -q1.imgx + this.Width;
                if (q1.rectangle.X > th12) q1.rectangle.X -= q1.amount;
                else q1.rectangle.X = th12;
            }
            this.Refresh();//forPaintEvent
        }

and this is my second class that I want it remodeled to become "In Itself".
I mean that it should plug and play into Background class.
public class NavigationArrows
{

    public void  InitializeNavigationArrows()
    {
        string imgName = "UI\\NavigationArrows OFF.png";
        BaseImg = Image.FromFile(imgName);
    }
    public Image BaseImg;
Posted
Updated 13-Mar-17 20:35pm
v3
Comments
Ralf Meier 10-Mar-17 13:59pm    
For my understanding ... because of your text I'm a little bit confused.

What do you want to move with the Arrow-Control ? Something on the Form where the Arrow-Control is positioned on ?
Should this Arrow-Control allways work with the Keys - independent if this Control has the Focus or not ?
_Q12_ 10-Mar-17 14:29pm    
... and to give you specific answers to your questions:
you"-What do you want to move with the Arrow-Control ? "
me: -nothing at the moment- I want them load on each specific keypressed.(w,a,s,d and combinations).
you"-Something on the Form where the Arrow-Control is positioned on ?"
me- on the form, on the background control, anywhere is position on.
you "Should this Arrow-Control allways work with the Keys?
- independent if this Control has the Focus or not ?"
me - Yes, work with the Keys. And Yes, independent of Focus.
_Q12_ 10-Mar-17 14:19pm    
The background is the UserControl; The NavigationArrows is a class(but can be anything - a control too) - but in my example, to be easy to explain, is a class.
For the moment, the NavigationArrows Class, must respond to user Keypressed and call a coresponding image per key pressed.
If 'w' is pressed, arrowUp is made visible, When 'w' is released, the "NavigationArrows OFF.png" is shown as the default. Very easy!
I did not say anything about arrows functionality (when user press on a arrow with mouse - it should move stuff around) Not yet. But is it a very good point that it will be implemented sometime.
My question is not about the arrows per say , but the management of the code, files, and when everything is agglomerated to manage it and keep it clean enough.
When I will have all 9 images for the arrows loaded, each of them must be linked to the keypressed event and fire to a specific key pressed and combinations of keys (like "wa" or "sd").
And believe me when I say, that 9 images are making chaos in code if they are not 'properly'(i dont know how to do it yet) managed and planned.
And 9 is simple and few, but what to do when I have 50 other clases, for the characters, enemies, bullets, explosions, etc... How I will [integrate] them all in the same page of code, and [SEE] them without confusion. All I can do with my knowledge so far is a nice code soup, with a lot of head hurts and extreme intense concentration, when it should be more relaxed and ordered. But I dont know this yet - you must throw a smart fart for me. And I will catch it and I will be happy. :)))
Ralf Meier 10-Mar-17 14:48pm    
OK ... I try to resume what you have said :
- normally there is nothing to be seen on the Screen
- if you press (for example) the "w" the Arrow-Up-Picture will appear at a defined position on the Screen. The same with the other Keys.

If you would say "Yes" to it you should do something like this :
- the Keys normally belong to the Control which has the Focus. The easiest way to solve that is : this functionality is part of the Form. Other Forms which should have the same functionality could derive from this form.
- the images you need for this could belong to this class (perhaps it could be a Component - that will allow you to make some settings with the UI)

I think, you try to develop a kind of game.
In the moment it is very difficult for me to be more specific because I can't imagine what is you goal for the moment and which is the final goal.
_Q12_ 10-Mar-17 15:10pm    
you-"if you press (for example) the "w" the Arrow-Up-Picture will appear at a defined position on the Screen. The same with the other Keys."
me- Correct!
you: "the Keys normally belong to the Control which has the Focus. "
me- very good this point! My control that will have the focus will be the Background UserControl. On this control I already paint the big background image. Now I will paint a secondary image named NavigationArrows. But I want to paint it from outside this UC Background. I want to paint from a class. Something that will hold together all the little details about this arrows.

This is what I was talking about!
And I am complaining because is very frustrating and annoying;
Look in how MANY places the navArrow is screw in.
I will highlight them for you.
Is a very ugly code - and I can not do other that this one.
It is the basic code I can normally do.

Imagine now I have to add another class(es) with images inside it.
Just imagine the WTF size when I am looking for something to find in this haystack of code!

Re-edited: I show the entire UserControl !
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Drawing;
using System.Data;
using System.Linq;
using System.Text;
using System.Windows.Forms;

namespace game_GameMap
{
    public partial class Background : UserControl
    {
        public struct BackgroundImage_
        {
            public int imgx, imgy;
            public int amount;
            public Image backgroundImage;
            public Rectangle rectangle;
            public Size windowSize;
        }
        public BackgroundImage_ bg = new BackgroundImage_();
        void Initialize_bg()
        {
            bg.amount = 50;
            string imgName = "assets\\map1Moon.jpg";
            bg.backgroundImage = Image.FromFile(imgName);
            bg.imgx = 736 * 3; bg.imgy = 552 * 3;
            bg.rectangle = new Rectangle(0, 0, bg.imgx, bg.imgy);
            bg.windowSize = this.Size;
        }
        public Background()
        {
            InitializeComponent();
        }
        private void Background_Load(object sender, EventArgs e)
        {
            DoubleBuffered = true;
            this.KeyDown += new KeyEventHandler(Background_KeyDown);
            this.KeyUp += new KeyEventHandler(Background_KeyUp);
            this.Paint += new PaintEventHandler(Background_Paint);
            Initialize_bg();

            navArrow.aInitializeNavigationArrows(); //navArrowPos();
        }




       
        void Background_Paint(object sender, PaintEventArgs e)
        {
            e.Graphics.DrawImage(bg.backgroundImage, bg.rectangle);//BackgroundImage
            e.Graphics.DrawImage(navArrow.Active(), navArrowsRectangle);//NavigationArrows
        }

       
        UI.NavigationArrows navArrow = new UI.NavigationArrows();
        int navarrowX = 100, navarrowY = 100;
        Rectangle navArrowsRectangle;
        void navArrowUpdatePosition()
        {
            navarrowX = this.Width / 2 - 50; navarrowY = this.Height - 100;
            navArrowsRectangle = new Rectangle(navarrowX, navarrowY, 100, 100);
        }
        void Background_KeyDown(object sender, KeyEventArgs e)
        {
            navArrowUpdatePosition();

            int th12 = 0;
            if (e.KeyCode == Keys.W)
            {
                navArrow.GetKey("w");
                if (bg.rectangle.Y < 0) bg.rectangle.Y += bg.amount;
                else bg.rectangle.Y = 0;
            }
            if (e.KeyCode == Keys.S)
            {
                navArrow.GetKey("s");
                th12 = -bg.imgy + this.Height;
                if (bg.rectangle.Y > th12) bg.rectangle.Y -= bg.amount;
                else bg.rectangle.Y = th12;
            }
            if (e.KeyCode == Keys.A)
            {
                navArrow.GetKey("a");
                if (bg.rectangle.X < 0) bg.rectangle.X += bg.amount;
                else bg.rectangle.X = 0;
            }
            if (e.KeyCode == Keys.D)
            {
                navArrow.GetKey("d");
                th12 = -bg.imgx + this.Width;
                if (bg.rectangle.X > th12) bg.rectangle.X -= bg.amount;
                else bg.rectangle.X = th12;
            }
            this.Refresh();//forPaintEvent
        }
        void Background_KeyUp(object sender, KeyEventArgs e)
        {
            navArrow.GetKey("none");
            this.Refresh();
        }
        private void Background_SizeChanged(object sender, EventArgs e)
        {
            navArrowUpdatePosition(); 
            this.Refresh();
        }

    }
}
 
Share this answer
 
v5
Comments
BillWoodruff 10-Mar-17 22:46pm    
Please do not post edits and updates of your question as a solution; instead, incorporate them into your original post.
_Q12_ 10-Mar-17 23:46pm    
please understand, that this is an actual solution - the code here is working in reality - you can test it yourself if you want. Nothing here is misplaced. Also, the original post is very long already, adding this I make it enormous. Do you want me to make it enormous? But this solution is wrong in the same time, I wrote why already... I hope is not that hard to understand what I am after to obtain.
Thank you for your understanding.
(sorry for making multiple solutions, but is for the sake of a clear visualization and understanding.)
I simplified my problem further...
And I have 1 NavigationArrows reference in each Event!
If I can filter MORE...
I imagine that it should be something like this:
Inside NavigationArrows class, to be able to implement each event like it is here in the Background UserControl. To have a paralel implementation of an event in 2 places, but in fact to be the same event.
It is possible such maneuver ?


using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Drawing;
using System.Data;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using game_GameMap_v2.UI;

namespace game_GameMap_v2
{

    public partial class Background : UserControl
    {
        public static int Width_ = 0, Height_ = 0;
        public Background()
        {
            InitializeComponent();
            DoubleBuffered = true;
            this.KeyDown += new KeyEventHandler(Background_KeyDown);
            this.KeyUp += new KeyEventHandler(Background_KeyUp);
            this.Paint += new PaintEventHandler(Background_Paint);

            Map.Initialize();
            NavigationArrows.Initialize();
        }

    
        void Background_Paint(object sender, PaintEventArgs e)
        {
            e.Graphics.DrawImage(Map.Img1, Map.rectangle);//BackgroundImage

            e.Graphics.DrawImage(NavigationArrows.Active(), NavigationArrows.Rectangle_);//NavigationArrows
        }



        void Background_KeyDown(object sender, KeyEventArgs e)
        {
            Map.GetKey(e.KeyCode.ToString());
            NavigationArrows.GetKey(e.KeyCode.ToString());
            this.Refresh();
        }
        void Background_KeyUp(object sender, KeyEventArgs e)
        {
            Map.GetKey("none");
            NavigationArrows.GetKey("none");
            this.Refresh();
        }
        private void Background_SizeChanged(object sender, EventArgs e)
        {
            Width_ = this.Width; Height_ = this.Height;//update this first
            NavigationArrows.UpdatePosition();
            this.Refresh();
        }

    }
}
 
Share this answer
 
v3

This content, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)



CodeProject, 20 Bay Street, 11th Floor Toronto, Ontario, Canada M5J 2N8 +1 (416) 849-8900