Star Citizen Wichtige Tastaturbefehle

Einfach mal so die wichtigen Tasten aus meiner Sicht um in das Spiel zu kommen.

Immer aktivierbar:

F1= Mobiglass

F4=Kamera ändern

T=Taschenlampe

F11=Freuende liste

F12=Chat

F=Aktion

Zu Fuß:

STRG=Ducken

STRG(Lang)=Kriechen

1=Waffe ziehen

V=Waffe weg

Y=Wenn die Kamera draußen ist diese frei bewegen

Im Schiff:

ALT+F(Halten)=Aussteigen

Q,W,E,A,S,D,STRG,Leer=Fliegen

X=Handbremse

V=Geschwindigkeitsmodi wechseln

shift*2=Booster aktivieren

F3=Cursor aktivieren

F=Gegenmaßnahmen wechseln

F(halten)=Gegenmaßnahmen auswerfen

B=Quantantrieb

R=Nächster Gegner

T=Nächstes Ziel

 

N=Landemodus –> F=Landeerlaubnis erfragen

ALT GR+N=Automatisches Landen

JavaFX Scenebuilder speedup

Ich hatte kürzlich das Problem das ich eine FXML im Scenebuilder bearbeiten wollte und die FX-IDs vergeben wollte.

Das auswählen einer Textbox hat ca. 30 Sekunden gedauert sowie das anschließende auswählen der ID über die Combobox.

Hintergrund war der das der Controller der zu der FXML gehört recht groß ist und dieser bei jedem klick im Scenebuilder neu geparst wird.

Der Hack wird in folgender Klasse gemacht: com.oracle.javafx.scenebuilder.kit.glossary.BuiltinGlossary

Hierzu wird das letzte Ergebnis + das Letzte Editierdatum der Datei gemerkt:

[codesyntax lang=“java“]

    //NEU
    private long lastUpdatequeryControllerClasses = 0;
    //NEU
    private List<String> resqueryControllerClasses ;

    @Override

    public List<String> queryControllerClasses(URL fxmlLocation) {

        if (fxmlLocation == null ) {

            return Collections.emptyList();

        } else {

            File fxmlFile = getFileFromURL(fxmlLocation);

            if (! fxmlFile.exists()) {

                // Suspicious ! May I print some warning ? or assert the file exists ?

                return Collections.emptyList();

            } else {

                //Speedhack

                if(resqueryControllerClasses == null || lastUpdatequeryControllerClasses < fxmlFile.lastModified()){

                List<String> res = new ArrayList<>();

                for (ControllerClass cc : ControllerClass.discoverFXMLControllerClasses(fxmlFile)) {

                    if (! res.contains(cc.getClassName())) {

                        res.add(cc.getClassName());

                    }

                }

                Collections.sort(res);
		//NEU
                resqueryControllerClasses=res;

                lastUpdatequeryControllerClasses = fxmlFile.lastModified();

                return res;

                }

                return resqueryControllerClasses;

            }

        }

    }
    //NEU
    private long lastUpdatequeryFxIds = 0;

    private List<String> resqueryFxIds ;

    @Override

    public List<String> queryFxIds(URL fxmlLocation, String controllerClass, Class<?> targetType) {

        // TODO fix DTL-5878

        assert controllerClass != null;

        if (fxmlLocation == null ) {

            return Collections.emptyList();

        } else {

            File fxmlFile = getFileFromURL(fxmlLocation);

            if (! fxmlFile.exists()) {

                // Suspicious ! May I print some warning ? or assert the file exists ?

                return Collections.emptyList();

            } else {
		//NEU
                if(resqueryFxIds == null || lastUpdatequeryFxIds < fxmlFile.lastModified()){

                List<String> res = new ArrayList<>();

                for (ControllerClass cc : ControllerClass.discoverFXMLControllerClasses(fxmlFile)) {

                    if (controllerClass.equals(cc.getClassName())) {

                        res.addAll(cc.getFxIds());

                        break;  // discoverFXMLControllerClasses may return duplicates.

                                // The first matching class name is good enough for now.

                    }

                }

                Collections.sort(res);

                resQueryEventHandlers=res;

                lastUpdatequeryFxIds = fxmlFile.lastModified();

                return res;

                }

                return resqueryFxIds;

            }

        }

    }
    //NEU
    private long lastUpdatequeryEventHandlers = 0;

    private List<String> resQueryEventHandlers ;

    @Override

    public List<String> queryEventHandlers(URL fxmlLocation, String controllerClass) {

        assert controllerClass != null;

        if (fxmlLocation == null ) {

            return Collections.emptyList();

        } else {

            File fxmlFile = getFileFromURL(fxmlLocation);

            if (! fxmlFile.exists()) {

                // Suspicious ! May I print some warning ? or assert the file exists ?

                return Collections.emptyList();

            } else {
		//NEU
                if(resQueryEventHandlers == null || lastUpdatequeryEventHandlers < fxmlFile.lastModified()){

                List<String> res = new ArrayList<>();

                for (ControllerClass cc : ControllerClass.discoverFXMLControllerClasses(fxmlFile)) {

                    if (controllerClass.equals(cc.getClassName())) {

                        res.addAll(cc.getEventHandlers());

                        break;  // discoverFXMLControllerClasses may return duplicates.

                                // The first matching class name is good enough for now.

                    }

                }

               

                Collections.sort(res);

                resQueryEventHandlers = res;

                lastUpdatequeryEventHandlers = fxmlFile.lastModified();

                return res;

                }return resQueryEventHandlers;

            }

        }

    }

[/codesyntax]

Android ADB manuell verbinden

Da in Eclipse das Android Development Tool nicht mehr weiterentwickelt wird gibt es ein paar Probleme.

Ich möchte wenigstens das Debugging in Eclipse nutzen.

Wie Funktioniert das.

  1. Wir gehen in unser Android SDK dort existiert der Ordner „platform-tools“
  2. Commandline öffnen
  3. Prüfen ob das Gerät verbunden ist „adb devices“

1

4. Wenn die App gestartet ist prüfen ob es einen Debugbaren Prozess gibt

2

5. Wenn es mehr als einen Prozess gibt müssen wir herausfinden welcher unser Prozess ist.

Hierfür gibt es das Command „adb shell ps $FILTER“ mein Filter ist „hecreator.manga“ wobei meine App ID diese ist „eu.thecreator.manga“

Wichtig es sind die letzten 15 Zeichen von eurem App Namen

3

6. jetzt müssen wir noch den Port freischalten mit „adb forward tcp:21407 jdwp:XXXX“ bei mir ist es gerade 21731

7. In Eclipse nun einfach noch verbinden gegen den Port 21407

4

Mongodb: Suche in Arrays

Wir haben folgende 2 Mongo Elemente mit internen Arrays „posts“

[codesyntax lang=“glsl“]

{
  "_id" : ObjectId("56d34d6f4f6634a340b8da81"),
  "good" : 478,
  "bad" : 108,
  "extId" : "/ASD",
  "id" : NumberLong(746),
  "posts" : [{
      "order" : 0,
      "time" : "18:53",
      "text" : "Ich hab Block1",
      "leftSide" : true
    }, {
      "order" : 1,
      "time" : null,
      "text" : "Ich suche Block 2",
      "leftSide" : false
    }]
}

/* 1 */
{
  "_id" : ObjectId("56d34d9f4f6634a340b8ddc7"),
  "good" : 836,
  "bad" : 303,
  "extId" : "/chat239782",
  "id" : NumberLong(1482),
  "posts" : [{
      "order" : 0,
      "time" : "23:21",
      "text" : "wirklich ein Highlight.",
      "leftSide" : true
    }]
}

[/codesyntax]

 

Wenn wir jetzt innerhalb der Elemente suchen wollen brauchen wir etwas um in den Arrays zu suchen.

„$elemMatch “ übernimmt dieser Rolle:

find({ „posts“ : { „$elemMatch“ : { „text“ : /.*Highlight.*/ } } })