- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在从我的 fragment roboguice 膨胀 View 时遇到问题,不知道为什么会发生这种情况..
这是我的代码
头等舱
public class AppController extends RoboFragmentActivity {
@InjectView(R.id.rtlPrincipalPaginaPrincipal) RelativeLayout rtlPrincipal;
@InjectView(R.id.rtlPrincipalMenuQr) RelativeLayout rtlMenuQr;
@InjectView(R.id.rtlPrincipalPaginaTrasera) RelativeLayout rtlTraera;
private FragmentManager fragment_manager;
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
this.requestWindowFeature(Window.FEATURE_NO_TITLE);
objFragmenManager = AppController.this.getSupportFragmentManager();
setContentView(R.layout.activitylayout);
objAnimationbjar = AnimationUtils.loadAnimation(this, R.anim.linear);
objAnimationSubir = AnimationUtils.loadAnimation(this, R.anim.linear2);
final SharedPreferences prefs =
AppController.this.getSharedPreferences("MisPreferencias",Context.MODE_PRIVATE);
LlenarHandler();//para podr recibir llamadas de las otras clases
LlenarPaginaPrincipal();// pagina principal donde mostramos las poromociones
}
private void LlenarPaginaPrincipal(){
objNavegar = new Cnavegar();
Cnavegar objNavegar= new Cnavegar();
Fragment frmTopmen = new AfrmProciones();
objNavegar.RemplazarFragmento(R.id.rtlPrincipalPaginaTrasera,frmTopmen, "AfrmProciones",objFragmenManager);
}
现在是 fragment
public class AfrmProciones extends RoboFragment{
@InjectView(R.id.btnCity) Button btnBajar;
@InjectView(R.id.vfShow) ViewFlipper vfPromociones;
@InjectView(R.id.prgProgresoPomos) ProgressBar pgrProgreso;
@InjectView(R.id.Crono) Chronometer objCrono;
View vPromos;
private Handler mHandler;
private static final int SWIPE_MIN_DISTANCE = 120;
private static final int SWIPE_THRESHOLD_VELOCITY = 200;
ArrayList<Cpromocion> lstPromo;
@SuppressWarnings("deprecation")
private final GestureDetector detector = new GestureDetector(new MyGestureDetector());
AccesoBd objAcceso;
Promociones taspromociones;
ObjectAnimator objAnimFondo;
AlarmManager objAlarma;
BroadcastReceiver objBroadcast;
int itiempo;
public AfrmProciones(Handler rHandler){
mHandler = rHandler;
}
public AfrmProciones(){
}
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
super.onCreateView(inflater, container, savedInstanceState);
RoboGuice.getInjector(getActivity()).injectMembers(this);
RegistrarEventos();
LlenarPromociones();
return vPromos;
}
private void RegistrarEventos(){
btnBajar.setOnClickListener(new OnClickListener(){
public void onClick(View v) {
Message msg = new Message();
msg.setTarget(mHandler);
msg.obj = "TriggerMenu";
msg.sendToTarget();
}
});
vfPromociones.setOnTouchListener(new OnTouchListener() {
@Override
public boolean onTouch(final View view, final MotionEvent event) {
detector.onTouchEvent(event);
return true;
}
});
objCrono.setOnChronometerTickListener(new OnChronometerTickListener() {
@Override
public void onChronometerTick(Chronometer chronometer) {
// TODO Auto-generated method stub
if (itiempo==2){
vfPromociones.showNext();
itiempo=0;
}else{
itiempo+=1;
}
}
});
}
这是我的日志
04-02 21:28:47.536: E/AndroidRuntime(17947): FATAL EXCEPTION: main
04-02 21:28:47.536: E/AndroidRuntime(17947): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.silice.qrstorecomerciales/com.silice.qrstore.AppController}: java.lang.NullPointerException
04-02 21:28:47.536: E/AndroidRuntime(17947): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2110)
04-02 21:28:47.536: E/AndroidRuntime(17947): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2135)
04-02 21:28:47.536: E/AndroidRuntime(17947): at android.app.ActivityThread.access$700(ActivityThread.java:140)
04-02 21:28:47.536: E/AndroidRuntime(17947): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1237)
04-02 21:28:47.536: E/AndroidRuntime(17947): at android.os.Handler.dispatchMessage(Handler.java:99)
04-02 21:28:47.536: E/AndroidRuntime(17947): at android.os.Looper.loop(Looper.java:137)
04-02 21:28:47.536: E/AndroidRuntime(17947): at android.app.ActivityThread.main(ActivityThread.java:4921)
04-02 21:28:47.536: E/AndroidRuntime(17947): at java.lang.reflect.Method.invokeNative(Native Method)
04-02 21:28:47.536: E/AndroidRuntime(17947): at java.lang.reflect.Method.invoke(Method.java:511)
04-02 21:28:47.536: E/AndroidRuntime(17947): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1027)
04-02 21:28:47.536: E/AndroidRuntime(17947): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:794)
04-02 21:28:47.536: E/AndroidRuntime(17947): at dalvik.system.NativeStart.main(Native Method)
04-02 21:28:47.536: E/AndroidRuntime(17947): Caused by: java.lang.NullPointerException
04-02 21:28:47.536: E/AndroidRuntime(17947): at com.jesus.PrincipalPromociones.AfrmProciones.RegistrarEventos(AfrmProciones.java:116)
04-02 21:28:47.536: E/AndroidRuntime(17947): at com.jesus.PrincipalPromociones.AfrmProciones.onCreateView(AfrmProciones.java:96)
04-02 21:28:47.536: E/AndroidRuntime(17947): at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:871)
04-02 21:28:47.536: E/AndroidRuntime(17947): at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1083)
04-02 21:28:47.536: E/AndroidRuntime(17947): at android.support.v4.app.BackStackRecord.run(BackStackRecord.java:635)
04-02 21:28:47.536: E/AndroidRuntime(17947): at android.support.v4.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:1431)
04-02 21:28:47.536: E/AndroidRuntime(17947): at android.support.v4.app.FragmentActivity.onStart(FragmentActivity.java:523)
04-02 21:28:47.536: E/AndroidRuntime(17947): at roboguice.activity.RoboFragmentActivity.onStart(RoboFragmentActivity.java:53)
04-02 21:28:47.536: E/AndroidRuntime(17947): at android.app.Instrumentation.callActivityOnStart(Instrumentation.java:1178)
04-02 21:28:47.536: E/AndroidRuntime(17947): at android.app.Activity.performStart(Activity.java:5216)
04-02 21:28:47.536: E/AndroidRuntime(17947): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2083)
04-02 21:28:47.536: E/AndroidRuntime(17947): ... 11 more
我一直在寻找云,但找不到与此相关的任何内容。事实上,在类里面,如果他们扩展它会正确注入(inject) robofragmentactivity,一旦发生这种情况,robofragment 就会停止为我工作。
是因为这个我要留下设置吗?
谢谢
最佳答案
在 RoboFragment 中, View 是在 onViewCreated
方法中注入(inject)的。
您的 RegistrarEventos()
方法在此之前被调用,因此当您尝试引用 btnBajar
View 时,您会得到一个 NullPointerException
。
注意:在 Java 中,习惯上使用小写首字母命名您的方法,对于类则使用大写首字母
关于android - 我的 robofragment 无法注入(inject) View (roboguice 2.0),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15772809/
我一直在尝试让 Roboguice 处理在 中声明的 fragment block 在布局文件中,然后注入(inject)到 Activity 中,但是,尽管 fragment 存在于屏幕外的某个地
我一直在尝试使用 RoboGuice 和 fragment ,但没有成功。我有一个扩展 RoboFragment 的 fragment 和一个扩展 RoboActivity 的 Activity ,但
我想将 xml 布局中的一些 View 注入(inject) RoboFragment,但不幸的是我遇到了 Nullpointer 异常。由于 RoboGuice(除了是一个很棒的 DI 框架之外)的
我有 public class ItemDetailFragment extends RoboFragment 我尝试从另一个 Activity 创建它: public class ItemDetai
我在从我的 fragment roboguice 膨胀 View 时遇到问题,不知道为什么会发生这种情况.. 这是我的代码 头等舱 public class AppController extends
我是一名优秀的程序员,十分优秀!