1

我正在尝试将msgvar 从showUser_Info 类中的show方法传递给 Call_Win 类中的方法。我被卡住了rubyv2/call_win.rb:4:in initialize: unresolved constructor call Call_Win (ArgumentError)

主文件

require "Qt"
require "unirest"
require "redis"



class QtApp < Qt::Widget
require_relative "user_info"

slots "login()"

def initialize
    super

    setWindowTitle "Login"

    init_ui

    resize 400, 90
    move 0, 0

    show
end

def init_ui


    @show = Qt::PushButton.new "Login", self



    connect(@show, SIGNAL("clicked()"),
        self, SLOT("login()"))

        @show.move 20, 20

    @username = Qt::LineEdit.new self
    @username.move 130, 20
    @username.setText "remy@gmail.com"
    @password = Qt::LineEdit.new self
    @password.setEchoMode(2)
    @password.move 130, 50
    @password.setText "remy@gmail.com"
end   

def login

    button = sender

            if "Login" == button.text
                call()
            elsif "Logout" == button.text

                logout()
            end


end


def logout
    @app.quit
end

def call

  response = Unirest::post("http://localhost:3000/user_token",
                    headers:{
                      "content_type" => "application/json"
                    },
                    parameters:{auth: [{
                        :email => "#{@username.text}",
                        :password => "#{@password.text}"
                    }]}
                  )                       

                  $global_variable =  "#{response.body["jwt"]}"
                    puts "#{response.code} #{@username.text} #{@password.text}"

                    if response.code == 201
                        @show.setText "Logout" 
                     Qt::MessageBox.information self, "#{$global_variable}", " Logged In ;) [#{response.body["jwt"]}]"
                     User_Info.new  
                    elsif response.code == 404
                        Qt::MessageBox.warning self, "#{@username.text}", "Unkown User"

                    end




              end

    end

     @app = Qt::Application.new ARGV
     QtApp.new
     @app.exec

User_Info 类

class User_Info < Qt::Widget
require_relative 'call_win'


    def initialize
        super

        setWindowTitle "Menu"

        init_ui

        resize 400, 600
        move 401, 0

        show
    end

    def init_ui
        $redis = Redis.new(host: "192.168.43.1", port: 6379)


        show()

    end   

    def show()

        $redis.subscribe('ruby') do |on|
            on.message do |channel, msg|
              Call_Win.new("#{msg}")
            end
          end

end

end

Call_Win 类

class Call_Win < Qt::Widget

    def initialize(message)
        super

        @msg = message

        setWindowTitle  "Menu"

        init_ui

        resize 400, 600
        move 401, 0

        show
    end

    def init_ui
      puts @msg
        show(@msg)


    end   

    def show(msg)
        Qt::MessageBox.information self, "#{msg}", "#{msg}"

end

end
4

1 回答 1

1

Qt::Widget该问题是由通过调用传递给构造函数的错误数量的参数引起的super

class Call_Win < Qt::Widget
  def initialize(message)
    super # HERE
    ...
  end
  ...
end

Qt::Widget#initialize 不接受论据。要调用super不带参数的方法,应该明确地不向它传递任何参数:

class Call_Win < Qt::Widget
  def initialize(message)
    super() # HERE

super不带括号的调用将重新传递给祖先函数的所有参数。由于 的构造函数Call_Win接收单个参数,因此它通过 传递给祖先的构造函数super。显式调用super()不会向 传递任何参数Qt::Widget#initialize,从而使继承按预期工作。

于 2018-01-02T07:53:17.290 回答